鱼C论坛

 找回密码
 立即注册
查看: 1061|回复: 5

[已解决]类和对象疑问

[复制链接]
发表于 2021-10-17 16:37:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
class Cat:
    def eat(self):
        print('%s爱跑'%self)

tom = Cat()
tom.eat()

print('')

class Cat1:
    def eat1(self):
        print('%s爱跑'%self.name)

jom = Cat1()
jom.name = 'JOM'
jom.eat1()


结果:
<__main__.Cat object at 0x000001C11F82FEB0>爱跑

JOM爱跑

为什么第一个不会输出tom爱跑,而是输出了个地址(应该是地址吧?不是很确定),tom.eat时,self就是tom了,哪为什么我print语句的结果那么奇怪,但是我重新设个变量的时候又可以成功print我要的结果
最佳答案
2021-10-17 16:55:34
本帖最后由 suchocolate 于 2021-10-17 17:09 编辑
class Cat:
    def eat(self):
        print('%s爱跑' % self)  # 此时self是实例本身,类中没有定义__str__方法,print的话就是对象的地址信息,并不是tom


tom = Cat()
tom.eat()

print('')


class Cat1:
    def eat1(self):
        print('%s爱跑' % self.name)


jom = Cat1()
jom.name = 'JOM'   # 此处为jom对象的变量name赋了值。
jom.eat1()   # 调用eat1方法后会被打印
一个类如果没有定义__str__方法,打印的时候就是对象的地址信息:
>>> class A:
        pass

>>> a = A()
>>> print(a)
<__main__.A object at 0x00000178ACB51E10>
>>> class B:
        def __str__(self):
                return 'Class B'

        
>>> b = B()
>>> print(b)
Class B
>>> 

常规对象变量使用
class Cat:
    def __init__(self, name):
        self.name = name   # 这是常规的对象变量

    def run(self):
        print(f'{self.name} 快跑!')


t = Cat('Tom')
t.run()

j = Cat('Jim')
j.run()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-10-17 16:40:38 | 显示全部楼层
想不明白为什么要jom.name = 'JOM' 这一步
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-17 16:55:34 | 显示全部楼层    本楼为最佳答案   
本帖最后由 suchocolate 于 2021-10-17 17:09 编辑
class Cat:
    def eat(self):
        print('%s爱跑' % self)  # 此时self是实例本身,类中没有定义__str__方法,print的话就是对象的地址信息,并不是tom


tom = Cat()
tom.eat()

print('')


class Cat1:
    def eat1(self):
        print('%s爱跑' % self.name)


jom = Cat1()
jom.name = 'JOM'   # 此处为jom对象的变量name赋了值。
jom.eat1()   # 调用eat1方法后会被打印
一个类如果没有定义__str__方法,打印的时候就是对象的地址信息:
>>> class A:
        pass

>>> a = A()
>>> print(a)
<__main__.A object at 0x00000178ACB51E10>
>>> class B:
        def __str__(self):
                return 'Class B'

        
>>> b = B()
>>> print(b)
Class B
>>> 

常规对象变量使用
class Cat:
    def __init__(self, name):
        self.name = name   # 这是常规的对象变量

    def run(self):
        print(f'{self.name} 快跑!')


t = Cat('Tom')
t.run()

j = Cat('Jim')
j.run()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-10-17 17:03:36 | 显示全部楼层


class Cat:
    def eat(self):
        print('%s爱跑' % self)  # 此时self是实例本身,类中没有定义__str__方法,print的话就是对象的地址信息,并不是tom
        #我下文已经是tom.eat了这句相当于Cat().eat(tom),然后这里原来的self不就被定义成tom了吗(我认为类似于赋值)


tom = Cat()
tom.eat()

print('')


class Cat1:
    def eat1(self):
        print('%s爱跑' % self.name)


jom = Cat1()
jom.name = 'JOM'   # 此处为jom对象的变量name赋了值。
jom.eat1()   # 调用eat1方法后会被打印
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-10-17 17:06:14 | 显示全部楼层
我好像懂了,tom.eat了这句相当于Cat().eat(),所以那个self没有被赋值为tom,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-17 17:08:20 | 显示全部楼层
全桥整流 发表于 2021-10-17 17:03
class Cat:
    def eat(self):
        print('%s爱跑' % self)  # 此时self是实例本身,类中没有定 ...

1.标红的那里self是对象本身,不是‘tom’。
2.就算你在标红的那里写了self.name,但是代码是从上到下执行的,你定义self.name是在后面了,所以tom.eat()还是打印self。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 02:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表