本文实例讲述了Python面向对象中类(class)的简单理解与用法。分享给大家供大家参考,具体如下:

我们先来创建一个简单的类

class Fish(object):
   pass
xiaoming = Fish()

一个基础类(base class) Fish(鱼)类就创建好了。class Fish(object)等同于class Fish()

caoyu = Fish() 语句创建了一个对象:xiaoming(小明)。变量名 = 类名+() 实例化 类

下面对Fish类进行扩充

class Fish():
  def weight(self,weight):
    print("鱼的重量:{}".format(weight))
xiaoming = Fish()
xiaoming.weight(100)

运行结果:

鱼的重量:100

关于self:

  • self代表类(class)的实例(instance)
  • self可以用其他词汇代替,name,you等,这只不过是约定俗成的
  • self必须定义,但不需要手动传值

我们在这个类里面定义了一个函数weight(),函数有两个参数self和weight,self我们只需要在创建函数时定义即可,传值调用时不用管。

当我们想给这个Fish类预设一些属性,初始化创建的实例化对象时,就可以定义一个__init__方法,在创建对象时自动进行初始化,

__init__前面是两个下划线

class Fish():
  def __init__(self):
    print("鱼都生活在水里。")
  def weight(self,weight):
    print("鱼的重量:{}".format(weight))
xiaoming = Fish()
#xiaoming.weight(100)

注释掉caoyu.weight(100)得到结果为:

鱼都生活在水里。

上面的代码定义了一个__init__方法,在caoyu这个对象建立的时候自动运行这个方法,打印输出了“鱼都生活在水里。”

创建了Fish() 鱼 类,突然觉得这个类包括的鱼太多了,那我们再来一个细分,即从Fish() 这个父类的基础之上,创建一个子类。子类继承了父类的一些属性,比如鱼都生活在水里,但又具有自己独有的特征,即属性。我们通过 class caoyu(Fish)定义了Fish父类下的caoyu(草鱼)子类。

class x(y)创建一个x类是y类的子类,就是创建子类的一般方法

class Fish():
  def __init__(self):
    print("鱼都生活在水里。")
  def weight(self,weight):
    print("鱼的重量:{}".format(weight))
class caoyu(Fish):
   pass
xiaoli = caoyu()

输出结果:

鱼都生活在水里。

从上面的代码可以看到,class caoyu(Fish)这个类是Fish的子类,子类会继承父类的属性。我们实例化caoyu类后,就输出了“鱼生活在水里”,继承自父类Fish()的__init__方法。我们也可以重新定义子类的__init__方法,父类的__init__方法就会失效,就像下面这样:

class Fish():
  def __init__(self):
    print("鱼都生活在水里。")
  def weight(self,weight):
    print("鱼的重量:{}".format(weight))
class caoyu(Fish):
   def __init__(self):
    print("鱼类都有鳃。但不会得腮腺炎。")
xiaoli = caoyu()

输出结果为:

鱼类都有鳃。但不会得腮腺炎。

我们也可以在子类中调用父类的函数

xiaoli.weight(100)

输出结果为:

鱼类都有鳃。但不会得腮腺炎。
鱼的重量:100

总结:

我们首先创建了一个基础类Fish(鱼)类(class),然后我们需要进行实例化(instance)出一个对象(object),我们实例化对象的名字叫做xiaoming(小明),就像我在菜市场买了一条鱼,我必须通过买这个动作(实例化),买了之后才拥有了一条鱼,一条属于我的“鱼”:xiaoming。然后我能用xiaoming这条鱼来煲汤(函数),做菜或者看他在水里游,这些动作就像调用类里面的函数一样,只有来了鱼才能做这些动作,为了做这些动作还需要加入葱姜蒜这些佐料(参数)。

而我们创建了子类caoyu(草鱼),草鱼也是鱼的一种,所以它也有父类Fish()的一些基本的属性,有鳃,可以在水里自由呼吸,同时也可以拿来煲汤,(这就继承了鱼的普遍属性)但它也有自己的特点,它可能做水煮鱼片比做酸菜鱼好吃,这是与其他鱼区别的地方。

  • class Fish(): 创建一个基本类 Fish
  • class caoyu(Fish): 创建一个类caoyu,它是类Fish()的子类
  • class Fish(): def init(self): 定义一个方法__init__,作用是对类class 进行初始化,比如给鱼基本属性:能在水中呼吸。
  • class Fish(): def weight(self, J):Fish()类下定义一个weight函数,接收self和J作为参数,用于说明鱼的重量
  • xiaoming = Fish(): 将xiaoming设置为类Fish()的一个实例
  • xiaoming.weight(J): 从xiaoming对象中找到函数weight,并用self和J参数调用它,self由Python自动填入,所以调用时只传入参数J

以上只是个人粗浅的理解,面向对象是个很深的东西,还需多多练习,慢慢消化理解!

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。