码迷,mamicode.com
首页 > 编程语言 > 详细

python初识面向对象

时间:2018-12-30 16:25:51      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:nop   and   一模一样   红色   属性   money   代码   name   value   

类与对象的关系
类: 就是创建对象的第一步,先写类
对象: 通过类来创建对象

类是对某事物的归类(类就是对属性和方法的封装)
    __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)
结果
老虎吃肉
大象吃香蕉

 

python初识面向对象

标签:nop   and   一模一样   红色   属性   money   代码   name   value   

原文地址:https://www.cnblogs.com/wangm-0824/p/10199597.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!