面向对象编程
-
面向过程(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)
<ipython-input-47-64fff9debd3c> in <module>
14 print(babyHorse.color) #此时自带一个颜色属性为白色
15 print(babyHorse.wheelsNumber) #也有一个轮子数量的属性
---> 16 Car.drive_car()
<ipython-input-47-64fff9debd3c> 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