一、面向对象的基本信息
1、面向过程编程最易被初学者接受,其往往用一长段代码来实现指定功能,开发过程的思路是将数据与函数按照执行的逻辑顺序组织在一起,数据与函数分开考虑。
面向对象和面向过程都是解决问题的一种思路而已
2、面向对象编程的2个非常重要的概念:类和对象
对象是面向对象编程的核心,在使用对象的过程中,为了将具有共同特征和行为的一组对象抽象定义,提出了另外一个新的概念——类
3、类:
定义:人以类聚 物以群分
1)具有相似内部状态和运动规律的实体的集合(或统称为抽象)。
2)具有相同属性和行为事物的统称
特点:1)类是抽象的,在使用的时候通常会找到这个类的一个具体的存在,使用这个具体的存在。
2)一个类可以找到多个对象
4、对象
定义:某一个具体事物的存在 ,在现实世界中可以是看得见摸得着的。
可以是直接使用的
5、类的构成
类(Class) 由3个部分构成
1)类的名称:类名
2)类的属性:一组数据
3)类的方法:允许对进行操作的方法 (行为)
举例: 人类设计,只关心3样东西: 事物名称(类名):人(Person) 属性:身高(height)、年龄(age) 方法(行为/功能):跑(run)、打架(fight)
6、类的抽象
拥有相同(或者类似)属性和行为的对象都可以抽像出一个类
案例: 小明在公车上牵着一条叼着热狗的狗
小明--》 人类
公车--》 交通工具类
热狗--》 食物类
狗--》 狗类
二、类和对象定义
格式:
class 类名:
方法列表
1、类的形式:
# class Hero: # 经典类(旧式类)定义形式
class Hero(object): # 新式类定义形式
def info(self):
print("英雄各有见,何必问出处。")
说明:定义类时有2种形式:新式类和经典类,上面代码中的Hero为新式类,注释部分则为经典类;
object 是Python 里所有类的最顶级父类;
类名 的命名规则按照"大驼峰命名法";
info 是一个实例方法,第一个参数一般是self,表示实例对象本身,当然了可以将self换为其它的名字,其作用是一个变量 这个变量指向了实例对象
2、创建对象
python中,可以根据已经定义的类去创建出一个或多个对象。
创建对象的格式为:(实例化对象):对象名1 = 类名()
案例:
class Hero:
name="zs"
def inif(self):
print("self",id(self))
print("英雄各有见,何必问出处.")
hero=Hero()
hero.inif()
print("hero",id(hero))
print(hero.name)
结果:
# id(hero) 则是内存地址的十进制形式表示
三、类中的方法
1、魔法方法__init__
说明: # Python 的类里提供的,两个下划线开始,两个下划线结束的方法,就是魔法方法,__init__()就是一个魔法方法,通常用来做属性初始化 或 赋值 操作(作用)。
# 如果类面没有写__init__方法,Python会自动创建,但是不执行任何操作,
# 如果为了能够在完成自己想要的功能,可以自己定义__init__方法, 所以一个类里无论自己是否编写__init__方法 一定有__init__方法。
案例1:有参数的__init__(self)方法
class Hero():
def __init__(self,name,hp):
self.name=name
self.hp=hp
def move(self):
print("还有30秒到达战场")
def info(self):
print("我是英雄%s,我的生命值是%d"%(self.name,self.hp))
taida=Hero("蛮王",2600)
taida.info()
taida.move()
zhaoxin=Hero("赵信",2200)
zhaoxin.info()
zhaoxin.move()
结果:
说明: 通过一个类,可以创建多个对象,就好比 通过一个模具创建多个实体一样 __init__(self)中,默认有1个参数名字为self,如果在创建对象时传递了2个实参,那么__init__(self)中出了self作为第一个形参外还需要2个形参,例如__init__(self,x,y)
注意: 1). 在类内部获取 属性 和 实例方法,通过self获取;
2). 在类外部获取 属性 和 实例方法,通过对象名获取。
3). 如果一个类有多个对象,每个对象的属性是各自保存的,都有各自独立的地址;
4). 但是实例方法是所有对象共享的,只占用一份内存空间。类会通过self来判断是哪个对象调用了实例方法。
案例2:没有参数的__init__(self)方法
class Hero():
def __init__(self):
self.name="蛮王"
self.hp=2600
def move(self):
print("还有30秒到达战场")
def info(self):
print("我是英雄%s,我的生命值是%d"%(self.name,self.hp))
taida=Hero()
taida.info()
taida.move()
结果:
说明:__init__()方法,在创建一个对象时默认被调用,不需要手动调用
__init__(self)中的self参数,不需要开发者传递,python解释器会自动把当前的对象引用传递过去。
2、魔法方法:__str__()方法
案例1:没有__str__()方法
class Hero(): def __init__(self): self.name="蛮王" self.hp=2600 def move(self): print("还有30秒到达战场") def info(self): print("我是英雄%s,我的生命值是%d"%(self.name,self.hp)) taida=Hero() taida.info() print(taida)
结果:
案例2:
class Hero(): def __init__(self): self.name="蛮王" self.hp=2600 def move(self): print("还有30秒到达战场") def info(self): print("我是英雄%s,我的生命值是%d"%(self.name,self.hp)) def __str__(self): return "我是英雄%s,我的生命值是%d"%(self.name,self.hp) taida=Hero() taida.info() print(taida)
结果:
说明: 在python中方法名如果是__xxxx__()的,那么就有特殊的功能,因此叫做“魔法”方法 当使用print输出对象的时候,默认打印对象的内存地址。
如果类定义了__str__(self)方法,那么就会打印从在这个方法中 return 的数据 __str__方法通常返回一个字符串,作为这个对象的描述信息
3、魔法方法:__del__()方法
说明: 1). 创建对象后,python解释器默认调用__init__()方法; 2). 当删除对象时,python解释器也会默认调用一个方法,这个方法为__del__()方法
案例:
class Hero(object): def __init__(self,name,hp): self.name=name self.hp=hp def move(self): print("还有30秒到达战场") def __del__(self): print("%s被干掉了。。。"%self.name) def info(self): print("我是英雄%s,我的生命值是%d"%(self.name,self.hp)) taida=Hero("蛮王",2600) taida1=taida taida2=taida taida.info() taida.move() print("%d第一次被干掉"%id(taida)) del(taida) print("%d第一次被干掉"%id(taida1)) del(taida1) print("%d第一次被干掉"%id(taida2)) del(taida2) zhaoxin=Hero("赵信",2200) zhaoxin.info() zhaoxin.move()
结果:
总结: 1). 当有变量保存了一个对象的引用时,此对象的引用计数就会加1;
2). 当使用del() 删除变量指向的对象时,则会减少对象的引用计数。如果对象的引用计数不为1,那么会让这个对象的引用计数减1,当对象的引用计数为0的时候,则对象才会被真正删除(内存被回收)。
4、调用__doc__,用于对象的注解(万物皆对象)
案例:
class Hero(object): '''创建英雄类''' def __init__(self): self.name="蛮王" self.hp=2600 def move(self): print("还有30秒到达战场") def info(self): print("我是英雄%s,我的生命值是%d"%(self.name,self.hp)) def __str__(self): return "我是英雄%s,我的生命值是%d"%(self.name,self.hp) taida=Hero() print(taida.__doc__) taida.info() print(taida)
结果: