9 面向对象编程 类成员和对象成员

面向对象编程

  • 面向过程(Procedure Oriented 简称PO :如C语言)

    从名字可以看出它是注重过程的。当解决一个问题的时候,面向过程会把事情拆分成: 一个个函数和数据(用于方法的参数) 。然后按照一定的顺序,执行完这些方法(每个方法看作一个过程),等方法执行完了,事情就搞定了。

  • 面向对象(Object Oriented简称OO :如C++,JAVA iOS等语言)

    看名字它是注重对象的。当解决一个问题的时候,面向对象会把事物抽象成对象的概念,就是说这个问题里面有哪些对象,然后给对象赋一些属性和方法,然后让每个对象去执行自己的方法,问题得到解决。

    摘自2分钟让你明白什么是面向对象编程, 更多内容请自行查阅

类、 对象、实例

类是对象的一个模板,对象是类的一个实例
类是抽象出来的, 实例是具体的东西

class Person: #这是一个类, Person类, 使用class关键字进行
#     pass 可占位使用
#__init__
#1.对象的第一个方法, 用于初始化对象
#2. __init__ 第一个参数永远是self, self不需要穿参
   def __init__(self, name, gender): #可以把*我们认为*必须需要的*属性*, 即name, gender 绑定进去
       self.name = name
       self.gender = gender

#这样在进行创建一个对象时, 每个对象都会拥有一个叫name和gender的属性。 eg:
person1 = Person('lili', 'woman') #person1 就是一个类为Person的实例,也是对象。
print(person1)
print(person1.name)#访问这个对象【实例】的name属性
print(person1.gender)
person2 = Person('Gavin', 'man')
print(person2)
print(person2.name)
print(person2.gender)#访问这个对象【实例】的gender属性
---------------------------------------------------
<__main__.Person object at 0x1109fb990>
lili
woman
<__main__.Person object at 0x1109fbed0>
Gavin
man

实例是类一个一个具体的对象,各个实例拥有的数据都互相独立,互不影响

class Car:
   wheelsNumber = 4 #有一个默认为轮子数量为4的属性
#self
#在python中, 成员函数使用“self”来指代对象自身。 类似于“this”。
#在调用时, 直接调用即可, 不需要传递self本身
#在使用时, 需要先将self定义为第一个参数。
#在函数内使用时, 对象的成员需要用self.xx方式来使用
#self不是关键词, 也不是强制名称, 它只是函数的第一个参数, 但是为了保持传统, 请不要将他改为其他名称。
   def __init__(self):
       print("i am init")
       self.color = 'white' #如果这么写, 则可以默认为在进行实例初始化时可以默认车的颜色为白色
   
benz = Car() ##当我创建一个‘奔驰’的实例对象的时候, 会发现__init__已经执行
print(benz.wheelsNumber)
print(benz.color)
benz.engine = "best" #给奔驰的实例添加了一个属性
print(benz.engine)
maserati = Car()
print(maserati.wheelsNumber)
print(maserati.color)
maserati.bodyDesign = 'advanced'
print(maserati.bodyDesign)
--------------------------------------------------------
i am init
4
white
best
i am init
4
white
advanced
  • 实例属性属于各个实例所有,互不干扰;

  • 类属性属于类所有,所有实例共享一个属性;

  • 不要对实例属性和类属性使用相同的名字,否则将产生难以发现的错误。

类方法

class Dog:
    hair = 'yellow'
    def __init__(self, name='wangwang', age = 0):
        self.name = name
        self.age = age
    def jump(self): #定义一个jump方法
        print('i am jumping')
    def say_hi(self, content):
        print(content)
    def run(self):
        self.jump()
        print("i am here") #通过run方法, 调用了jump方法
haba = Dog()  
haba.jump()
haba.say_hi('i am happy wangwangwang')
haba.run()
----------------------------------------------------
i am jumping
i am happy wangwangwang
i am jumping
i am here

@classmethod的使用

  • @classmethod是Python内置(built-in)的函数装饰器,其主要作用将类方法中的函数方法(实例方法)转换为类方法。

  • 如果不想通过实例来调用类的函数属性,而直接用类调用函数方法,则这就是类方法,通过内置装饰器@calssmethod

  • 类方法只是【专门】给类使用(无论是否存在实例)

class Car:
    wheelsNumber = 4 #有一个默认为轮子数量为4的属性
    def __init__(self):
        print("i am init")
        self.color = 'white' #注意注意
    

    @classmethod     # 类方法(不需要实例化类就可以被类本身调用)
    def drive_car(cls):
        print('You are driving a {} car'.format(cls.color))
        if cls.wheelsNumber > 0:
            print('ha ha')
babyHorse = Car() #当我创建一个‘宝马’的实例的时候, 会发现__init__已经执行
print(babyHorse.color) #此时自带一个颜色属性为白色
print(babyHorse.wheelsNumber) #也有一个轮子数量的属性
Car.drive_car()
-----------------------------------------------------
i am init
white
4
---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
 in 
     14 print(babyHorse.color) #此时自带一个颜色属性为白色
     15 print(babyHorse.wheelsNumber) #也有一个轮子数量的属性
---> 16 Car.drive_car()

 in drive_car(cls)
      8     @classmethod     # 类方法(不需要实例化类就可以被类本身调用)
      9     def drive_car(cls):
---> 10         print('You are driving a {} car'.format(cls.color))
     11         if cls.wheelsNumber > 0:
     12             print('ha ha')

AttributeError: type object 'Car' has no attribute 'color'

  • 报错原因在于属性 color, 在调用类方法时, 此时还没有该属性????

正解

class Car:
    wheelsNumber = 4 #有一个默认为轮子数量为4的属性
    color = 'white'
    def __init__(self):
        print("i am init")
    

    @classmethod     # 类方法(不需要实例化类就可以被类本身调用)
    def drive_car(cls):
        print('You are driving a {} car'.format(cls.color))
        if cls.wheelsNumber > 0:
            print('ha ha')
Car.drive_car()
------------------------------------------------------
You are driving a white car
ha ha

你可能感兴趣的:(9 面向对象编程 类成员和对象成员)