首页 > 代码库 > 学习python_day6

学习python_day6

面向对象

面向对象的特性:封装、继承、多态

类、方法

一、面向对象编程

OOP编程是利用“类”和“对象”来创建各种模型来实现对真实世界的描述,使用面向对象编程的原因一方面是因为它可以使程序的维护和扩展变得更简单,并且可以大大提高程序开发效率 ,另外,基于面向对象的程序可以使它人更加容易理解你的代码逻辑,从而使团队开发变得更从容。

面向对象的几个核心特性如下

Class 类

一个类即是对一类拥有相同属性的对象的抽象、蓝图、原型。在类中定义了这些对象的都具备的属性(variables(data))、共同的方法

Object 对象 

一个对象即是一个类的实例化后实例,一个类必须经过实例化后方可在程序中调用,一个类可以实例化多个对象,每个对象亦可以有不同的属性,就像人类是指所有人,每个人是指具体的对象,人与人之前有共性,亦有不同

Encapsulation 封装

在类中对数据的赋值、内部调用对外部用户是透明的,这使类变成了一个胶囊或容器,里面包含着类的数据和方法

Inheritance 继承

一个类可以派生出子类,在这个父类里定义的属性、方法自动被子类继承

Polymorphism 多态

多态是面向对象的重要特性,简单点说:“一个接口,多种实现”,指一个基类中派生出了不同的子类,且每个子类在继承了同样的方法名的同时又对父类的方法做了不同的实现,这就是同一种事物表现出的多种形态。例如len() 可以传递str、list、tuple等就是一个借口多种实现。

类的语法

最简单的语法:

class Dog(object):
    print("I am a dog")

d = Dog()#实例化这个类
#此时的d就是类Dog的实例化对象
#实例化,其实就是以这个类Dog为模板。在内存里开辟一块空间,存上数据,赋值成一个变量名

给dog传名字加功能

class Dog(object):
    def __init__(self,name,type):#初始化对象
        self.name = name#d.name = name
        self.type = type#d.type = type
    def balk(self):#定义其功能,所以在调用初始化函数定义的name时把d传进来,此时的self=d
        print("[%s] wang wang ..."%self.name)
    def eat(self,food):
        print("[%s] eating %s"%(self.name,food))
d = Dog("AA","京巴")
d.balk()#调用balk功能

#对class中self的例子解析
def dog(name,type):
    data ={"name":name,"type":type}
    return data
def balk(dog_name):
    print("[%s] wang wang ..."%dog_name["name"])
d1 = dog("BBB","京巴")#把dog的执行结果赋给d1,d1["name"]=name d1["type"]=type
balk(d1)#balk函数想要调用dog函数中定义的变量name 只能把d1当做参数传进去,调用name就是d1["name"]

小结:
你执行d = Dog("AAA","京巴")时,python的解释器其实干了两件事:

  1. 在内存中开辟一块空间指向d这个变量名
  2. 调用Dog这个类并执行其中的__init__(…)方法,相当于Dog.__init__(d,"AAA","京巴"),这么做是为什么呢? 是为了把‘d,"AAA","京巴"这3个值跟刚开辟的d关联起来, 因为关联起来后,你就可以直接d.name, d.type 这样来调用啦。所以,为实现这种关联,在调用__init__方法时,就必须把r1这个变量也传进去,否则__init__不知道要把那3个参数跟谁关联呀。
  3. 明白了么哥?所以这个__init__(…)方法里的,self.name = name , self.type = type 等等的意思就是要把这几个值 存到d的内存空间里。

技术分享

 

根据上图我们得知,其实self,就是实例本身!你实例化时python会自动把这个实例本身通过self参数传进去。

类变量、实例变量、私用变量、封装

 

class Dog(object):
    age = 22#类变量,存在类的内存地址中,可以被所有实例共享引用,作用:作为默认共有属性,全局修改或增加新属性
    def __init__(self,name,type):
        self.name = name#这些都是实例变量(成员属性),每个实例存在自己内存空间里的属性
        self.type = type#
    def balk(self):
        print("[%s] wang wang ..."%(self.name,self.age))#当构造函数中没有定义self.age = 22时,可以引用类变量中的
                                                          #当构造方法中定义时则直接引中构造方法中的
d = Dog("AAA","京巴")
class Pepole(object):
    def __init__(self,name,sex):
        self.name = name
        self.__sex = sex#定义私有属性用两个下划线__,外部调用不到,内部各函数中可以被调用,封装的一个特性
    def go_to_toilet(self):
        if self.__sex == "F":
            print("standup")
        else:
            print("跪着。。。")
    def get_sex(self):#封装的另一个特性:隐藏一些功能的实现细节,只给外部暴露调用接口
        return self.__sex
p = Pepole("alex","F")
# print(p.__sex)#这样会报错,外面调用不到
p.go_to_toilet() #内部可以调用
print(p.get_sex())#这样就可以访问到,但不能修改

 

学习python_day6