转自  http://www.cnblogs.com/BeginMan/p/3510786.html

本文旨在Python复习和总结:

1、如何创建类和实例?

# 创建类
class ClassName(object):
"""docstring for ClassName"""
def __init__(self, arg):
super(ClassName, self).__init__()
self.arg = arg
# 创建实例
instance = ClassName()

2、经典类与新式类的区别?

3、什么是方法?如何定义?如何使用?

方法是类的功能
定义在类中
通过实例调用

4、self代表什么?用在哪些地方?

每个类方法都有一个self参数,代表实例对象本身,当实例调用方法时,由解释器悄悄地传递给方法,不用手动self进来。
self在Python里不是关键字。self代表当前对象的地址。self能避免非限定调用造成的全局变量。
wangkangluo1的Python为什么要self中讲的很清楚:

创建了一个类MyClass,实例化MyClass得到了MyObject这个对象,然后调用这个对象的方法MyObject.method(arg1,arg2) ,这个过程中,Python会自动转为Myclass.mehod(MyObject,arg1,arg2)
这就是Python的self的原理了。即使你的类的方法不需要任何参数,但还是得给这个方法定义一个self参数。

5、类对象的两种操作?

定义完类之后就产生了类对象,类对象支持的两种操作:引用和实例
引用:通过类对象去调用类中的属性或方法;实例:通过类对象实例化一个类对象的实体。

6、什么是Python类属性和实例属性?

属性就是另一个对象的数据或函数元素!通过句点符号访问,如一些python类型如复数有数据属性,列表和字典拥有方法(函数属性)。还有可能是,访问一个属性时,这个属性又是对象,其又拥有自己的属性,这样就构成了属性链。如:

>>> import sys
>>> sys.stdout.write('beginman')
beginman
>>> myMoudel.myClass.__doc__

类属性与类相关,与实例无关,通常是类的数据属性,仅仅是类中定义的变量,通常称作静态变量或静态数据。在其他语言中相当于在变量前加上static

>>> class C(object):
foo = 100 # 定义类属性 >>> print C.foo # 访问类属性
100
>>> C.foo = C.foo+100 # 更新类属性
>>> C.foo
200

由上所知,类属性仅仅与类(类也是对象,python中称类对象)相关,与实例半毛钱关系都没有。

>>> class C(object):
foo = 100 # 定义类属性 >>> print C.foo # 访问类属性
100
>>> C.foo = C.foo+100 # 更新类属性
>>> C.foo
200
>>> c=C() # 实例化一个对象c
>>> c.foo
200
>>> c.foo = 1000 # 实例试图修改类属性
>>> c.foo # 实例想看是否修改成功,于是就c.foo竟输出1000,于是实例就满以为自己成功了
1000
>>> C.foo # 类对象鄙夷的看了实例一样,说:“你就是老子生出来的,老子的东西你也能碰??”
200
>>> del c.foo # 实例看完之后当场傻眼,心想mlgb,你牛B,我还是除掉自己负担沉重的改造吧
>>> c.foo # 实例除掉了自己负担沉重的改造后,老老实实地调用类对象给的sb玩意
200
>>> # 通过类对象与实例关于类属性争权大战后,我们知道了一点:
>>> #类属性仅仅与类(类也是对象,python中称类对象)相关,与实例半毛钱关系都没有。
>>> #如果类的实例没有同名变量也可以使用实例来访问。如果实例含有与类属性同名的属性,则用该实例访问属性时,访问的是实例中的属性。如果类的实例没有同名变量也可以使用实例来访问。如果实例含有与类属性同名的属性,则用该实例访问属性时,访问的是实例中的属性。
>>>

7、类方法?

>>> class C(object):
foo = 100
def met(self):
print 'i am method for class.' >>> C.met() # C心想方法也是我的一部分,那么方法也是类属性*(这点很正确),于是我调用你玩玩 Traceback (most recent call last):
File "<pyshell#31>", line 1, in <module>
C.met() # C心想方法也是我的一部分,那么方法也是类属性*(这点很正确),于是我调用你玩玩
TypeError: unbound method met() must be called with C instance as first argument (got nothing instead)
>>> # 出大事了,方法竟然不同意还反抗了
>>> # 心想这是为什么呢?突然想到了原来是那鸟人Python
>>> # 鸟人 Guido van Rossum 创造Python类给出的规定就是,你可以创类方法,但是不能调戏她。
>>> c=C() # 类心有不甘,于是创了实例小c来助纣为虐
>>> c.met() # 实例小c心想,mlgbd,上次想修改类属性就被你狠狠地鄙视了一番,现在又为难我,唉,命苦。无论如何试试吧
i am method for class.
>>> # 龌龊,类方法竟然听我实例的,于是实例就赶紧找Guido van Rossum问什么情况
>>> # Guido van Rossum就说”为了与OOP惯例保持一致,没有实例就不能调用方法,这种限制就是Python所描述的绑定概念,方法必须绑定在实例中才听话,不能把权利都交给了类,这是老子对你实例的恩惠啊。“
>>> # 实例听完泪牛满面,类对象发怒了,说:”今天,我就要把我身上的所有零件(属性)都掏出来看看,看都有谁不听话!“
>>> dir(C) # 于是类对象使用第一招 dir()内建
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'foo', 'met']
>>> print C.__dict__ # 第二招就是召遣他最听话的属性 __dict__ 来揪出
{'__module__': '__main__', 'met': <function met at 0x0000000002D33EB8>, '__dict__': <attribute '__dict__' of 'C' objects>, 'foo': 100, '__weakref__': <attribute '__weakref__' of 'C' objects>, '__doc__': None}
>>>

类对象出尽风头之后,该轮到实例了:

实例的创建:
C++等编程应用,实例对象是New出来的,Python牛b,就跟人家不一样,偏以函数调用的形式实例化。

class CC(object):
#我是Python类默许的,没重写__init__,所以也没有什么特殊操作
pass class C(object):
def __init__(self,name,phone,ID):
super(C,self).__init__()
self.name = name
self.phone = phone
self.id = ID
print 'Hi man 我重写了__init__,因为我需要更多的操作' cc = CC() # 创建CC实例
c = C('BeginMan','110','12306') # 创建C实例

重点:
当类被调用,实例化的第一步就是创建实例对象,然后Python检查是否实现了__init__()方法,默认情况下如果没有覆盖__init__就不会施加特别的操作。任何特别的操作都需要重写__init__
接着就是传递参数,这依赖于你自己定义的__init__,它里面有多少个参数,在实例化的过程中就要传多少个参数,不管是否覆盖了__init__(),实例对象都要作为第一个参数传递进去。

__init____new____call__的区别:

__new__更像真正的构造器,创建对象时调用,返回当前对象的一个实例。但是实际中用的很少。
__init__:初始化工作,创建对象时调用,对当前对象的实例进行初始化,无返回值。在Python中很常用的。
__call__:让类的实例的行为表现的像函数一样,你可以调用他们,将一个函数当做一个参数传到另外一个函数中等等。很少用。
优先级:__new__先与__init__

__del__析构器方法,见《py 核心》

实例属性:

可在创建实例后的任意时间创建,也可以在"运行时"创建.__init__()是创建这些属性的关键点。

>>> c.__dict__  # 此时实例c还没属性
{}
>>> c.__class__ # 实例化的类
<class '__main__.C'> >>> c.foo=1
>>> c.name='CS'
>>> c.__dict__
{'foo': 1, 'name': 'CS'}
>>> dir(c)
[***'foo', 'name'***,'__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__']

python面向对象与其他语言的异同点?

大同小异
Differences between “Java OOP” and “Pythonic OOP”?
真tm的拗口,谁英文好能翻译下。

什么是构造器,__init__表示什么? 有什么意义?

参考面向对象的编程init方法

OOP常用术语

这在软件工程经常见到的,由于Python OOP实际运用的并不是太多,所以对于OOP特征的体现就不那么明显,C++/Java/C# OOP思想体现倒是挺深的,不过本人太菜,难以熟谙OOP的精髓。
面向对象程序设计中的常用术语总结
其中对还包括自省

什么是Python自省(反射)?

python中oop的更多相关文章

  1. 第三十三篇 Python中关于OOP(面向对象)的常用术语

    面向对象的优点 从编程进化论可知,面向对象是一种更高等级的结构化编程方式,它的好处主要有两点: 1. 通过封装明确了内外,你做为类的缔造者,你就是女娲,女娲造物的逻辑别人无需知道,女娲想让你知道,你才 ...

  2. 四 python中关于OOP的常用术语

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

  3. Python中的属性管理

    Python管 理属性的方法一般有三种:操作符重载(即,__getattr__.__setattr__.__delattr__和 __getattribute__,有点类似于C++中的重载操作符).p ...

  4. 深刻理解Python中的元类metaclass(转)

    本文由 伯乐在线 - bigship 翻译 英文出处:stackoverflow 译文:http://blog.jobbole.com/21351/ 译注:这是一篇在Stack overflow上很热 ...

  5. 深刻理解Python中的元类(metaclass)

    译注:这是一篇在Stack overflow上很热的帖子.提问者自称已经掌握了有关Python OOP编程中的各种概念,但始终觉得元类(metaclass)难以理解.他知道这肯定和自省有关,但仍然觉得 ...

  6. Python面向对象OOP

    一 OOP     与C++和Java一样,Python同样具有OOP设计. 过程式:从前到后,一条一条,机器能接受的顺序性方式:方式大概为"首先你应该做什么,第二应该做什么,高级点的做点假 ...

  7. Python中metaclass解释

    Classes as objects 首先,在认识metaclass之前,你需要认识下python中的class.python中class的奇怪特性借鉴了smalltalk语言.大多数语言中,clas ...

  8. 可爱的 Python : Python中函数式编程,第二部分

    英文原文:Charming Python: Functional programming in Python, Part 2,翻译:开源中国 摘要:  本专栏继续让David对Python中的函数式编 ...

  9. 可爱的 Python : Python中函数式编程,第一部分

    英文原文:Charming Python: Functional programming in Python, Part 1 摘要:虽然人们总把Python当作过程化的,面向对象的语言,但是他实际上包 ...

随机推荐

  1. 画山 paint

    画山 paint 有一张大小为n*m的白纸,小R想在纸上画一片绵延的群山. 为了描述方便,我们将纸张表示在坐标系上,四个顶点的坐标分别为(0,0),(n,0),(0,m),(n,m). 小R有一只神奇 ...

  2. “今日头条杯”首届湖北省大学程序设计竞赛--F. Flower Road

    题目链接:点这 github链接:(包含数据和代码,题解):点这 链接:https://www.nowcoder.com/acm/contest/104/E来源:牛客网 题目描述 (受限于评测机,此题 ...

  3. CSS:CSS 简介

    ylbtech-CSS:CSS 简介 1.返回顶部 1. CSS 简介 你需要具备的知识 在继续学习之前,你需要对下面的知识有基本的了解: HTML / XHTML 如果你希望首先学习这些项目,请在  ...

  4. 由Resin引发的java.lang.IllegalArgumentException: object is not an instance of declaring class(反射中使用)思考

    文章目录 背景 原因 解决办法 背景 在java agent中抓取Resin的 某些方法,在invoke的时候出现错误 java.lang.IllegalArgumentException: obje ...

  5. Socket/TCP粘包、多包和少包, 断包

    转发: https://blog.csdn.net/pi9nc/article/details/17165171 为什么TCP 会粘包 前几天,调试mina的TCP通信, 第一个协议包解析正常,第二个 ...

  6. sed use case: Filter without editing

    if we want to filter with sed pattern and just print the filtered lines without any further editing ...

  7. 并发编程(五)——GIL全局解释器锁、死锁现象与递归锁、信号量、Event事件、线程queue

    GIL.死锁现象与递归锁.信号量.Event事件.线程queue 一.GIL全局解释器锁 1.什么是全局解释器锁 GIL本质就是一把互斥锁,相当于执行权限,每个进程内都会存在一把GIL,同一进程内的多 ...

  8. Linux下NODE配置NODE_PATH变量

    在当我们使用了npm install express -g安装之后的,会安装在全局目录下,但是如果直接用Node来启动程序的话,是无法发现这个包的,原因就在于NODE_PATH这个环境变量设置的不正确 ...

  9. Django项目从新建到运行

    返回主目录:Django框架 内容目录: 一.安装之前 二.Django安装 三.创建项目 四.配置 一.安装之前 安装django之前你需要注意的几个事项: 1.版本问题 建议使用1.11.11左右 ...

  10. PL/SQL Developer 查看查询的执行计划

    https://zhuanlan.zhihu.com/p/65771352 通过 PL/SQL Developer 查看查询的执行计划 1 什么是执行计划 执行计划是一条查询语句在 Oracle 中的 ...