Python OOP(1)

  • 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
  • 类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。
  • 数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据。
  • 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override),也称为方法的重写。
  • 实例变量:定义在方法中的变量,只作用于当前实例的类。
  • 继承:即一个派生类(derived class)继承基类(base class)的字段和方法。继承也允许把一个派生类的对象作为一个基类对象对待。例如,有这样一个设计:一个Dog类型的对象派生自Animal类,这是模拟"是一个(is-a)"关系(例图,Dog是一个Animal)。
  • 实例化:创建一个类的实例,类的具体对象。
  • 方法:类中定义的函数。
  • 对象:通过类定义的数据结构实例。对象包括两个数据成员(类变量和实例变量)和方法。

 

创建类

class ClassName:
   '类的帮助信息'   #类文档字符串
   class_suite  #类体

 

#!python2
#-*- coding:utf-8 -*-

class Employee:
    #类说明,可以通过className.__doc__ 查看
    "员工类" 
    #类变量
    empCount=0
    
    #构造函数或初始化函数,当创建这个类的instance的时候就会调用
    #所有类的方法,第一个函数必须是self
    def __init__(self,name,salary):
        self.name=name
        self.salary=salary
        Employee.empCount+=1
        
    def displayCount(self):
        print "Total Employee %d " % Employee.empCount
        
        
    def displayEmployee(self):
        print "Name: %s, Salay: %s " % (self.name,self.salary)
        

#创建类 Employee的第一个实例对象
emp1=Employee("Martin","20000")
#创建类 Employee的第二个实例对象
emp2=Employee("Sui",10000)


emp1.empCount
emp1.displayCount()
emp1.displayEmployee()

emp2.empCount
emp2.displayCount()
emp2.displayEmployee()

Employee.empCount

#增加修改和删除属性
emp1.age=20
print emp1.age
emp1.age=22
print emp1.age
del emp1.age

#函数方式访问属性
#getattr(obj, name[, default]) : 访问对象的属性。
#hasattr(obj,name) : 检查是否存在一个属性。
#setattr(obj,name,value) : 设置一个属性。如果属性不存在,会创建一个新属性。
#delattr(obj, name) : 删除属性。


hasattr(emp1,"age")
getattr(emp1,"age")
setattr(emp2,"sex","M")
getattr(emp2,"sex")
delattr(emp2,"sex")
hasattr(emp2,"sex")
  
#内置类属性
# __dict__ : 类的属性(包含一个字典,由类的数据属性组成)
# __doc__ :类的文档字符串
# __name__: 类名
# __module__: 类定义所在的模块(类的全名是'__main__.className',如果类位于一个导入模块mymod中,那么className.__module__ 等于 mymod)
# __bases__ : 类的所有父类构成元素(包含了一个由所有父类组成的元组)

print Employee.__doc__
print Employee.__dict__
print Employee.__name__
print Employee.__module__
print Employee.__bases__

 

类的继承

面向对象的编程带来的主要好处之一是代码的重用,实现这种重用的方法之一是通过继承机制。继承完全可以理解成类之间的类型和子类型关系。

需要注意的地方:继承语法 class 派生类名(基类名)://... 基类名写在括号里,基本类是在类定义的时候,在元组之中指明的。

在python中继承中的一些特点:

  • 1:在继承中基类的构造(__init__()方法)不会被自动调用,它需要在其派生类的构造中亲自专门调用。
  • 2:在调用基类的方法时,需要加上基类的类名前缀,且需要带上self参数变量。区别于在类中调用普通函数时并不需要带上self参数
  • 3:Python总是首先查找对应类型的方法,如果它不能在派生类中找到对应的方法,它才开始到基类中逐个查找。(先在本类中查找调用的方法,找不到才去基类中找,简单说就是按照“由下到上,由左至右”的顺序搜索该对象上的所有类)。

如果在继承元组中列了一个以上的类,那么它就被称作"多重继承" 

class SubClassName (ParentClass1[, ParentClass2, ...]):
   'Optional class documentation string'
   class_suite

 

#!python2
#-*- coding:utf-8 -*-

#定义父类
class Parent:
    
    parentAttt=1
    
    def __init__(self):
        print "父类构造函数"
        
    def parentMethon(self):
        print "call parent methon"
        
    def setAttr(self,attr):
        Parent.attr=attr
        
    def getAttr(self):
        print "父类属性: ",Parent.attr
        
        
class Child(Parent):
    
    def __init__(self):
        print "子类构造函数"
        
    def childMethod(self):
        print "call children method"
        
#实例化子类       
c=Child()
#调用呢子类方法
c.childMethod()
#调用父类方法
c.parentMethon()
#再次调用父类方法
c.setAttr("test")
c.getAttr()


#issubclass(B,A) B是A类的子类, 返回True。否则返回False
#判断是否是derive class
issubclass(Child,Parent)


#isinstance(obj, Class) 布尔函数如果obj是Class类的实例对象或者是一个Class子类的实例对象则返回true
#判断是对象,实例

isinstance(c,Parent)

    

 

继承多个类

 

class A:        # 定义类 A
.....

class B:         # 定义类 B
.....

class C(A, B):   # 继承类 A 和 B
.....

 

方法重写

如果你的父类方法的功能不能满足你的需求,你可以在子类重写你父类的方法:

 

#!python2
#-*-coding:utf-8-*-

class Parent:
    def myMethod(self):
        print "call parent Method"
        
        
class Child(Parent):
    def myMethod(self):
        print "call rewrite child method"
        
c=Child()
c.myMethod()

call rewrite child method

p=Parent()
p.myMethod()

call parent Method

 

基础重载

__init__ ( self [,args...] )
构造函数
简单的调用方法: obj = className(args)

__del__( self )
析构方法, 删除一个对象
简单的调用方法 : dell obj

__repr__( self )
转化为供解释器读取的形式
简单的调用方法 : repr(obj)

__str__( self )
用于将值转化为适于人阅读的形式
简单的调用方法 : str(obj)

__cmp__ ( self, x )
对象比较
简单的调用方法 : cmp(obj, x)

 

运算符重载

 

#!python2
#-*-coding:utf-8-*-

class Vector:
    
    def __init__(self,a,b):
        self.a=a
        self.b=b
        
    def __str__(self):
        return "Vector(%d,%d)" % (self.a,self.b)
    
    def __add__(self,others):
        return Vector(self.a+others.a,self.b+others.b)
        
        
v1=Vector(10,20)
v2=Vector(1,2)
print v1+v2

Vector(11,22)

 

类属性与方法
类的私有属性
__private_attrs:两个下划线开头,声明该属性为私有,不能在类的外部被使用或直接访问。在类内部的方法中使用时 self.__private_attrs。
类的方法
在类地内部,使用def关键字可以为类定义一个方法,与一般函数定义不同,类方法必须包含参数self,且为第一个参数
类的私有方法
__private_method:两个下划线开头,声明该方法为私有方法,不能在类地外部调用。在类的内部调用 self.__private_methods

 

#!python2
#-*- coding:utf-8 -*-


class JustCounter:
    __privateid=0
    publicid=0
    
    def counter(self):
        self.__privateid+=1
        self.publicid+=1
        print self.__privateid
        self.__privatecounter()
        
    def __privatecounter(self):
        self.__privateid+=1
        print "call privatecounter"
        
    
c=JustCounter()
c.counter()
c.publicid
1
#实例不能访问私有变量
c.__privateid
#Python不允许实例化的类访问私有数据,但你可以使用 
#object._className__attrName 
#object._className__method()
#访问属性或者方法

c._JustCounter__privateid

2

c._JustCounter__privatecounter()

call privatecounter

 

posted on 2017-01-24 16:51  大大的橙子  阅读(315)  评论(0编辑  收藏  举报

导航