本节内容:

  • 面向对象高级语法部分

    • 静态方法、类方法、属性方法
    • 类的特殊方法
    • 反射
  • 异常处理
  • Socket开发基础

静态方法

它与类唯一的关联就是需要通过类名来调用这个方法

#静态方法实际跟类没关系,不存在self变量了。
#只是名义上贵归类管理,实际上在静态方法里,访问不了类或实例中的任何属性

1. 调用时主动传递实例本身给eat方法,即d.eat(d)

2. 在eat方法中去掉self参数,但这也意味着,在eat中不能通过self.调用实例中的其它变量了

#!/usr/bin/env python
#-*- coding:utf-8 -*-
# Author:DCC class Dog(object):
def __init__(self,name):
self.name = name
def eat(self,food):
print("%s is eatting %s" % (self.name,food))
d = Dog("dog1")
d.eat("包子") #静态方法
class Cat(object):
def __init__(self,name):
self.name = name
@staticmethod #静态方法实际跟类没关系,不存在self变量了。
#只是名义上贵归类管理,实际上在静态方法里,访问不了类或实例中的任何属性
def eat(self,food):
print("%s is eatting %s" % (self,food))
d = Cat("dog1")
d.eat("cat1","baozi")

类方法

类方法通过@classmethod装饰器实现,类方法和普通方法的区别是, 类方法只能访问类变量,不能访问实例变量

#!/usr/bin/env python
#-*- coding:utf-8 -*-
# Author:DCC class Dog(object):
name = "nn"
def __init__(self,name):
self.name = name
@classmethod
def eat(self,food):
print("%s is eatting %s" % (self.name,food))
d = Dog("dog1")
d.eat("包子") #静态发放中,类方法只能访问类变量,不能访问实例变量
#运行结果
nn is eatting 包子

属性方法

属性方法的作用就是通过@property把一个方法变成一个静态属性

#!/usr/bin/env python
#-*- coding:utf-8 -*-
# Author:DCC class Dog(object):
name = "nn"
def __init__(self,name):
self.name = name
@property
def eat(self):
print("%s is eatting " % (self.name))
# @eat.setter
# def eat(self,food1):
# print("set to food:", food1) d = Dog("dog1")
d.eat #属性方法:把一个方法,变成一个静态属性,不能传参数,可以特殊赋值

类的特殊成员方法

__doc__ #输出:类的描述信息

class Foo:
""" 描述类信息,这是用于看片的神奇 """
def func(self):
pass
print(Foo.__doc__)

__module__ 和  __class__ 

__module__ 表示当前操作的对象在那个模块

__class__     表示当前操作的对象的类是什么

class C:

    def __init__(self):
self.name = 'wupeiqi'
from lib.aa import C

obj = C()
print obj.__module__ # 输出 lib.aa,即:输出模块
print obj.__class__ # 输出 lib.aa.C,即:输出类
05-11 15:09