python笔记(八) - 类 part1
class myClass:
pass
python中最简单的类,pass表示什么也不做。现在在这个类里加一个方法:
class myClass:
def sayHello(self):
print 'hello'
c = myClass()
c.sayHello()
def sayHello(self):
print 'hello'
c = myClass()
c.sayHello()
唯一要注意的地方是sayHello方法带了一个参数self,这是个保留字,指向本身。但是在调用这个方法的时候不用显示加上这个参数,如果加上这个参数的话会报异常。
进一步的来补充这个类,让它能做更多的事情
class myClass:
def __init__(self,name):
self.name = name
def sayHello(self):
print 'hello %s'%self.name
c = myClass('dhuang')
c.sayHello()
def __init__(self,name):
self.name = name
def sayHello(self):
print 'hello %s'%self.name
c = myClass('dhuang')
c.sayHello()
我们给它加了一个方法,不过这个方法有点特别,起码从名字看来是这样的。
__init__方法从字面上是很好理解的,初始化。不错很接近,当创建一个类的新实例的时候,这个方法首先被执行,然后才是其他的。你可以理解它为构造函数,但是还是有很大我区别。最重要的一个区别是,当进入__init__方法的时候类实例已经存在了。
在__init__方法中定义了一个变量name,注意它前面的self,如果带有self的话在这个类的全局都可以使用,使用的方法当然是像这样self.name。如果没有带self的话,则认为它是当前代码块的变量,不具有类的全局访问权限
但是有种特殊情况,看下面的代码
class myClass:
count = 0
def __init__(self,name):
myClass.count+=1
self.name = name
def __del__(self):
myClass.count-=1
def sayHello(self):
print 'hello %s'%self.name
c = myClass('dhuang1')
c.sayHello()
print myClass.count
print c.count
d = myClass('dhuang2')
d.sayHello()
print myClass.count
print d.count
c.__del__()
print myClass.count
print d.count
count = 0
def __init__(self,name):
myClass.count+=1
self.name = name
def __del__(self):
myClass.count-=1
def sayHello(self):
print 'hello %s'%self.name
c = myClass('dhuang1')
c.sayHello()
print myClass.count
print c.count
d = myClass('dhuang2')
d.sayHello()
print myClass.count
print d.count
c.__del__()
print myClass.count
print d.count
变量count的作用域为整个类,你可以理解它为全局变更。因为调用它的方式也有点特别(类调用),当然对象的方式调用也是没有问题的。
在这个类里面还有__del__的方法,它也是内置的方法,和__init__的作用刚好相反,当对象销毁的时候调用它做一些清理工作。