python基础之面向对象介绍

一、对象的概念

1、对象的概念

对象是 数据和功能 的结合体。或者说:对象时一个盛放数据和功能的容器。

 

2、面向对象编程的优缺点是什么?

优点:可扩展性高
缺点:比编写面向过程的代码难度大

 

二、类与对象

1、类

用来存放多个对象相同的数据和功能的容器。

 

2、强调:

在程序中,必须要先定义类,后调用类产生对象(调用类拿到的返回值就是对象)。

 

三、面向对象编程

1、类的定义与实例化

首先定义类

class Student:

    #数据( 变量 ) 数据
    school = 'star'

    #功能 ( 函数 )
    def study(self):
        print('studying')

类体的代码在类定义阶段就会执行,因而会产生新的名称空间用来存放类中定义的名字,可以打印Student__dict__查看类这个容器内盛放的东西

print(Student)  #<class '__main__.Student'>
print(Student.__dict__)
#{'__module__': '__main__', 'school': 'star', 'study': <function Student.study at 0x0000000002985620>,
# '__dict__': <attribute '__dict__' of 'Student' objects>,
# '__weakref__': <attribute '__weakref__' of 'Student' objects>, '__doc__': None}

调用类的过程称之为将类实例化,拿到的返回值就是程序中的对象,或称之为一个实例。

#实例化
stu1 = Student()
print(stu1)  #<__main__.Student object at 0x00000000029C3EF0>
stu2 = Student()
print(stu2)  #<__main__.Student object at 0x00000000028C30F0>
stu3 = Student()
print(stu3)   #<__main__.Student object at 0x0000000002981CC0>

如此stu1、stu2、stu3 全都一样了(只有类中共有的内容,没有各自独有的数据),想定制独有,需要在类内部新增一个__init__方法

class Student:

    #数据( 变量 ) 数据
    school = 'star'

    #__init__专门为对象进行初始化操作,可以有任意代码,但一定不能反回非None的值
    def __init__(self,name,age):
        self.name = name
        self.age = age

    #功能 ( 函数 )
    def study(self):
        print('studying')
        
       
stu1 = Student('xioabao', 17)
stu2 = Student('dabao', 18)

此时,调用类会先产生一个空对象stu1,然后将stu1连同调用类时括号内的参数一起传给Student.__init__('xioabao', 17),会产生对象的名称空间,同样可以用__dict__查看。

print(stu1.__dict__) #{'name': 'xioabao', 'age': 17}

至此,我们造出了2个对象,1个类,对象中存放各自独有的数据,类中存放对象们共有的内容。

 

 

 

 

 

2、属性访问

2.1、类属性与对象属性

 

在类中定义的名字,都是类的属性,分为:数据属性和函数属性。

可以通过__init__访问属性的值,如:Student.__init__[ ' school ' ] , python提供了专门的属性访问方法。

print(Student.school  )  #star
print(Student.study)  #<function Student.study at 0x0000000009E352F0>

操作对象的属性:

查:

print(stu1.name)  #xioabao
print(stu1.age)  #17

增:

stu1.country = 'China'
print(stu1.country)  #China

改:

stu1.country = '中国'
print(stu1.country)  #中国

删:

del stu1.country
print(stu1.country)  #AttributeError: 'Student' object has no attribute 'country'

 

3、属性查找顺序与绑定方法

对象的名称空间只存放对象独有的属性,而对象们相似的属性是存放于类中的。对象在访问属性时,会优先从对象本身的__dict__中查找,未找到,则去类的__dict__中查找。

 

3.1、类中的数据属性,是共享给所有对象用的,指向相同的内存地址

print(id(Student.school))  #38450208
print(id(stu1.school))    #38450208
print(id(stu1.school))   #38450208

 

3.2、类中的函数属性,类可以使用,但必须遵循函数的参数规则,有几个参数需要传几个参数。

Student.study(stu1)   
Student.study(stu2)

 类中定义的函数主要是给对象使用的,绑定到不同对象就是不同的绑定方法,内存地址不同。

print(stu1.study) 
#<bound method Student.study of <__main__.Student object at 0x0000000009E16898>>
print(stu2.study)
#<bound method Student.study of <__main__.Student object at 0x0000000009E162B0>>

 

由对象来调用类内部的函数,称之为对象的绑定方法。

对象的绑定方法特殊之处:会将对象当做第一个参数传给该方法。

print(id(stu1.study))  #4921160  等同于Stundent.study( stu1 )
print(id(stu2.study))  #4921160 等同于Student.study( stu2 ) 

注意:绑定到对象方法的这种自动传值的特征,决定了在类中定义的函数都要默认写一个参数self,self可以是任意名字,但命名为self是约定俗成的。

 

3.3、小结

对象是一个高度整合的产物,有了对象,我们只需使用 “ 对象. xxx ” 的语法就可以得到跟这个对象相关的所有数据和功能。

 

posted @ 2019-11-25 19:28  小猪皮蛋  阅读(198)  评论(0编辑  收藏  举报