Python中的类学习笔记
程序员文章站
2023-11-28 22:03:40
python使用中面向对象的语言,支持继承、多态;
定义一个person类:
复制代码 代码如下:
>>> class person:
... d...
python使用中面向对象的语言,支持继承、多态;
定义一个person类:
复制代码 代码如下:
>>> class person:
... def sayhello(self):
... print('hello')
...
>>> person.sayhello(none)
hello
>>> person().sayhello()
hello
可以修改person的类方法
复制代码 代码如下:
>>> def hack_sayhello(obj):
... print('...hello')
...
>>>
>>> person.sayhello = hack_sayhello
>>> person.sayhello(none)
...hello
>>> person().sayhello()
...hello
>>> sayhello = person().sayhello
>>> sayhello()
...hello
person().sayhello也是一个函数,可以赋值给变量,并可以直接调用;
复制代码 代码如下:
>>> person.sayhello is person().sayhello
false
>>> person.sayhello == person().sayhello
false
person.sayhello与person().sayhello并不是同一个对象,直觉上,person().sayhello关联(绑定)了一个person实例,而person.sayhello是一个类方法;
self参数事实上正是方法和函数的区别:方法将它们的第一个参数绑定到所属的实例上,因此这个参数可以不必提供;
复制代码 代码如下:
>>> class person:
... name = 'unkown'
... def sayhello(self):
... print('i\'m ' + name)
...
>>>
>>> person.sayhello(none)
traceback (most recent call last):
file "<stdin>", line 1, in <module>
file "<stdin>", line 4, in sayhello
nameerror: name 'name' is not defined
>>> p = person()
>>> p.name = 'wyj'
>>> p.sayhello()
traceback (most recent call last):
file "<stdin>", line 1, in <module>
file "<stdin>", line 4, in sayhello
nameerror: name 'name' is not defined
可见,python在解析变量时,默认从local scope/global scope中查找;
复制代码 代码如下:
>>> class person:
... name = 'unkown'
... def sayhello(self):
... print('i\'m ' + self.name)
...
>>>
>>> person.sayhello(none)
traceback (most recent call last):
file "<stdin>", line 1, in <module>
file "<stdin>", line 4, in sayhello
attributeerror: 'nonetype' object has no attribute 'name'
>>> p = person()
>>> p.name = 'wyj'
>>> p.sayhello()
i'm wyj
访问成员都要通过self,假如以包含name属性的对象调用person.sayhello(obj),是否可以呢?
复制代码 代码如下:
>>> class cat:
... name = 'huanhuan'
...
>>> person.sayhello(cat())
i'm huanhuan
可以,python并不限制必须用相同类的实例对象作为参数调用类方法(貌似python的类机制类似javascript);
访问控制
python并不直接支持私有方访问,而是要靠程序员自己把握。
不过,可以在属性名称前加上双下划线而给其私有访问能力(对外不可见);
复制代码 代码如下:
>>> class person:
... def __private_method(self):
... print('private')
... def test(self):
... self.__private_method()
...
>>> person().test()
private
>>> person().__private_method()
traceback (most recent call last):
file "<stdin>", line 1, in <module>
attributeerror: 'person' object has no attribute '__private_method'
实际上,以上下划线打头的方法都有一个_classname__methodname的方法
复制代码 代码如下:
>>> person._person__private_method
<function person.__private_method at 0x7fed431a2d90>
调用
复制代码 代码如下:
>>> person._person__private_method(none)
private
总之,python并不能阻止从类外进行方法调用;
类属性以及对象属性
首先,可以为类添加属性,新对象将得到属性的一份拷贝
复制代码 代码如下:
>>> person.age = 3
>>> person().age
3
>>> person.age = 4
>>> person().age
4
>>> p = person()
>>> person.age = 31
>>> p.age
31
对类属性的修改,反映到了先前生成的对象的属性上,这说明类属性和对象的属性共享一个值;
复制代码 代码如下:
>>> p.age = 34
>>> p.age
34
>>> person.age
31
>>> person.age = 99
>>> p.age
34
而一旦对对象的属性的修改,对象属性就拥有了自己的值,并不会反映到类属性上,而对类属性的修改,也不再反映到该对象的属性上;
这种行为与javascript类似
下一篇: PHP防止post重复提交数据的简单例子