面向对象-2

属性查找

  类有两种属性:数据属性和函数属性

    1) 类的数据属性是所有对象共享的

    2) 类的函数属性是绑定给对象用的

class school:

    def __init__(self,name):
        self.name = name

    def addr(self):
        addr = 'yingguo'



s1 = school('jianqiao')
s2 = school('jianqiao')
s3 = school('jianqiao')

'''
2349212424560
2349212424560
2349212424560
'''


print(s1.addr)
print(s2.addr)
print(s3.addr)

'''
<bound method school.addr of <__main__.school object at 0x0000024BCEFA0240>>
<bound method school.addr of <__main__.school object at 0x0000024BCEFA0198>>
<bound method school.addr of <__main__.school object at 0x0000024BCF124160>>
'''

绑定到对象的方法的特殊之处

  类中定义的函数(没有被任何装饰器装饰的)是类的函数属性,类可以使用,但必须遵循函数的参数规则,有几个参数需要传几个参数。

  类中定义的函数(没有被任何装饰器装饰的),其实主要是给对象使用的,而且是绑定到对象的,虽然所有对象指向的都是相同的功能,但是绑定到不同的对象就是不同的绑定方法。

  强调:绑定到对象的方法的特殊之处在于,绑定给谁就由谁来调用,谁来调用,就会将‘谁’本身当做第一个参数传给方法,即自动传值(方法__init__也是一样的道理)

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

  注意:python中一切皆为对象,且python3中类与类型是一个概念,类型就是类

#类型dict就是类dict
>>> list
<class 'list'>

#实例化的到3个对象l1,l2,l3
>>> l1=list()
>>> l2=list()
>>> l3=list()

#三个对象都有绑定方法append,是相同的功能,但内存地址不同
>>> l1.append
<built-in method append of list object at 0x10b482b48>
>>> l2.append
<built-in method append of list object at 0x10b482b88>
>>> l3.append
<built-in method append of list object at 0x10b482bc8>

#操作绑定方法l1.append(3),就是在往l1添加3,绝对不会将3添加到l2或l3
>>> l1.append(3)
>>> l1
[3]
>>> l2
[]
>>> l3
[]
#调用类list.append(l3,111)等同于l3.append(111)
>>> list.append(l3,111) #l3.append(111)
>>> l3
[111]
View Code

下面引用一段大神的话:  

    程序越早面向对象,死的越早,为啥面向对象,因为我们要将数据与功能结合到一起,程序整体的结构都没有出来,或者说需要考虑的问题你都没有搞清楚个八九不离十,

  你就开始面向对象了,这就导致了,你在那里干想,自以为想通了,定义了一堆属性,结果后来又都用不到,或者想不通到底应该定义啥,那就一直想吧,想着想着就疯了。

  你见过哪家公司要开发一个软件,上来就开始写,肯定是频繁的开会讨论计划。

python中关于OOP的常用术语

  1)抽象/实现

    抽象指对现实世界问题和实体的本质表现,行为和特征建模,建立一个相关的子集,可以用于 绘程序结构,从而实现这种模型。抽象不仅包括这种模型的数据属性,还定义了这些数据的接口。

  对某种抽象的实现就是对此数据及与之相关接口的现实化(realization)。现实化这个过程对于客户 程序应当是透明而且无关的。

  2)封装/接口  

      封装描述了对数据/信息进行隐藏的观念,它对数据属性提供接口和访问函数。通过任何客户端直接对数据的访问,无视接口,与封装性都是背道而驰的,除非程序员允许这些操作。

    作为实现的 一部分,客户端根本就不需要知道在封装之后,数据属性是如何组织的。在Python中,所有的类属性都是公开的,但名字可能被“混淆”了,

    以阻止未经授权的访问,但仅此而已,再没有其他预防措施了。这就需要在设计时,对数据提供相应的接口,以免客户程序通过不规范的操作来存取封装的数据属性。

    注意:封装绝不是等于“把不想让别人看到、以后可能修改的东西用private隐藏起来”

  

  真正的封装是,经过深入的思考,做出良好的抽象,给出“完整且最小”的接口,并使得内部细节可以对外透明

 (注意:对外透明的意思是外部调用者可以顺利的得到自己想要的任何功能,完全意识不到内部细节的存在) 

  3)合成

      合成扩充了对类的 述,使得多个不同的类合成为一个大的类,来解决现实问题。合成 述了 一个异常复杂的系统,比如一个类由其它类组成,更小的组件也可能是其它的类,

    数据属性及行为, 所有这些合在一起,彼此是“有一个”的关系。

  4)派生/继承/继承结构

      派生描述了子类衍生出新的特性,新类保留已存类类型中所有需要的数据和行为,但允许修改或者其它的自定义操作,都不会修改原类的定义。
    继承描述了子类属性从祖先类继承这样一种方式
    继承结构表示多“代”派生,可以述成一个“族谱”,连续的子类,与祖先类都有关系。

  

  5)泛化/特化

      基于继承
    泛化表示所有子类与其父类及祖先类有一样的特点。
    特化描述所有子类的自定义,也就是,什么属性让它与其祖先类不同。

  6)多态与多态性

      多态指的是同一种事物的多种状态:水这种事物有多种不同的状态:冰,水蒸气

    多态性的概念指出了对象如何通过他们共同的属性和动作来操作及访问,而不需考虑他们具体的类。

    冰,水蒸气,都继承于水,它们都有一个同名的方法就是变成云,但是冰.变云(),与水蒸气.变云()是截然不同的过程,虽然调用的方法都一样

  7)自省/反射

      自省也称作反射,这个性质展示了某对象是如何在运行期取得自身信息的。如果传一个对象给你,你可以查出它有什么能力,这是一项强大的特性。

    如果Python不支持某种形式的自省功能,dir和type内建函数,将很难正常工作。还有那些特殊属性,像__dict__,__name__及__doc__

参考:http://www.cnblogs.com/linhaifeng/articles/6182264.html

猜你喜欢

转载自www.cnblogs.com/MR-allen/p/10498299.html