python初识面向对象
类与对象的关系
类: 就是创建对象的第一步,先写类
对象: 通过类来创建对象
类是对某事物的归类(类就是对属性和方法的封装)
__init__(self, 参数): 参数一般作为属性设置给对象,对象就是self,对属性的封装,(根据需要,如果在类中传参就用__init__,如果不需要传参,就直在类里定义函数即可)
def 方法(self, 参数): 方法,第一个参数一般是固定的self,当前类的对象
创建类:
class 类名:
对象是某类型的一个具体
创建对象:
变量 = 类名() #实例化 <-> 创建对象
变量.属性 #访问对象的属性信息
变量.方法() #访问类中的方法
class 类名: def __init__(self,值1,值2): # __init__(初始化方法,又被成为构造方法) self.属性 = 值1 self.属性 = 值2 def 方法(self): 方法体 def 方法2(self): 方法体2 对象名 = 类名(值1,值2) 对象名.方法() 对象名.方法2()
创建类
class Car: #类名首字母大写,严格遵守变量命名规则 pass c = Car() #创建对象,对象名=类名() c.color = '红色' # 对象.属性(.意思就是'的')当属性不存在的时候,添加一个属性 c.pai = '京A88888' c.color = '黑色' # 当属性存在的时候是修改属性信息(类似于字典根据key修改value) print(c.color) print(c.pai) 结果 红色 黑色 京A88888
创建一个类并调用这个类
__init__方法是一个特殊的方法,初始化方法(构造方法),在创建对象的时候,默认执行这个函数
在创建对象的时候会自动的调用__init__()
self就是创建出来的对象
class Car: def __init__(self,color,pai): self.a = color self.pai = pai def pao(self): #在类中写的函数就是方法,self当前类的对象 print('我%s的%s车能跑'%(self.a,self.pai)) def jump(self): print('我的%s车能飞'%self.pai) c=Car('红色','京A88888') # 创建Car类型对象,self参数不需要管 c.pao() c.jump() c2 = Car('黑色','京B66666') c2.pao() c2.jump() 结果 我红色的京A88888车能跑 我的京A88888车能飞 我黑色的京B66666车能跑 我的京B66666车能飞 事例2,对象传参 class Car: def __init__(self,color,pai): self.a = color self.pai = pai def pao(self,ret): print('我%s的%s车能跑%s'%(self.a,self.pai,ret)) def jump(self): print('我的%s车能飞'%self.pai) c=Car('红色','京A88888') c.pao('太空') c.jump() 结果 我红色的京A88888车能跑太空 我的京A88888车能飞 练习 用向对象的思维来模拟LOL里的盖伦上阵杀敌 class Hero: def __init__(self,name,nickname): self.name = name self.nickname = nickname def synopsis(self): print('%s外号%s'%(self.name,self.nickname)) def q(self): print('拎着大宝剑嗷嗷跑') def w(self): print('护盾') def r(self): print('大宝剑') gw = Hero('盖伦','德玛西亚之力') gw.synopsis() gw.q() gw.w() gw.r() 结果 盖伦外号德玛西亚之力 拎着大宝剑嗷嗷跑 护盾 大宝剑 用向对象的思维来完成用户登录 class People: def __init__(self,user,pwd): self.user = user self.passwd = pwd def login(self): use = input('user:') password = input('passwd:') if use == self.user and password == self.passwd: print('登陆成功') else: print('登陆失败') Lgin = People('bob','123') Lgin.login()
面向对象和面向过程对比
脚本:(简单)
一切以事务的发展流程为中心
根据业务逻辑从上到下写垒代码
print('开冰箱门') print('装大象') print('关闭冰箱')
函数式(比脚本麻烦)
将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可
def kai(): print('开冰箱门') def zhuang(): print('装大象') def guan(): print('关闭冰箱') kai() zhuang() zhuang() guan()
面向对象:
一切以对象为中心,一切皆为对象,具体的某一个事务就是对象
对函数进行分类和封装,让开发"更快更好更强..."
对整个系统进行分析,分析出需要哪些对象,然后给对象进行归类
先写类,然后使用类创建对象,最后用对象去执行相关的操作
class Elephant: def __init__(self): print('创建大象') def kai(self): print('开冰箱门') def zhuang(self): print('装大象') def guan(self): print('关闭冰箱') e = Elephant() e.kai() e.zhuang() e.guan()
总结
脚本简单,不需要构思整个程序的概况
函数侧重的是功能,对功能有了概况
面向对象侧重的是归类
面向过程: 代码非常的冗余. 尤其是参数
面向对象的程序:
优点: 不需要像原来一样传递同样的参数了,结果相对清晰,可维护性好
缺点: 代码量比原来大,上手太难
应用场景:
如果写一些比较小的程序用面向过程
程序很复杂,很庞大建议用面向对象
python同时支持面向对象和面向过程:
面向过程: 应用程序相对比较小,不需要大规模的设计
面向对象: 程序非常大,项目管理维护成本很高,此时更适合用面向对象(结构)
封装
1. 对属性的封装
2. 对功能的封装
3. 模块的封装
4. 包的封装
class Game: def login(self): print("登录") def recharge(self): print("充钱") def uninstall(self): print("卸载") def zhaoduixiang(self): print("找对象") class Game1: def recharge(self): print("充钱") def uninstall(self): print("卸载") class Game2: def recharge(self): print("充钱") def uninstall(self): print("卸载") g = Game2() g.uninstall() 结果 卸载
继承
子类自动拥有父类中除了私有内容外的其他所有内容
继承目的: 对父类进行扩展
class Foo: def getmoney(self): print('多花钱') class Bar(Foo): pass b = Bar() b.getmoney() 结果 多花钱 事例2 class Animal: def dong(self): print('动物会叫') class Cat(Animal): def an(self): print('猫捉老鼠') c = Cat() c.dong() c.an() #子类可以执行子类和父类中的方法 c = Animal() #父类的对象不能执行子类中的功能 c.dong() # c.an() # 创建的是Animal,所以不能执行子类中的方法 事例3 class Animal: def dong(self): print('动物会叫') class Cat(Animal): # 子类其实是对父类的一种扩展 def dong(self): # 子类中写了和父类一模一样的方法. 这个叫方法的覆盖, 重写 print('猫捉老鼠') def cat(self): print('猫上蹿下跳') c = Cat() c.dong() # 类中的方法的查询顺序,先找自己,然后再找父类 结果 猫捉老鼠 python支持多继承 class Foo1: def dong(self): print('动物会叫') def cat(self): print('猫上蹿下跳') class Foo2: def dong(self): print('猫捉老鼠') class Bar(Foo2,Foo1): #哪个类在前优先使用哪个类 pass b = Bar() # 就近原则 b.dong() 结果 猫捉老鼠
多态(同一个对象. 多种形态)
优点:超强的可扩展性,面向对象的核心就是多态
class Animal: def chi(self): print("会吃") class Tiger(Animal): def chi(self): print("老虎吃肉") class Elephant(Animal): def chi(self): print("大象吃香蕉") def wei_animal(ani): ani.chi() t = Tiger() e = Elephant() wei_animal(t) wei_animal(e) 结果 老虎吃肉 大象吃香蕉