【《人工智能实践教程》测评】Python 高级编程
# 【《人工智能实践教程》测评】Python 高级编程### 类属性与实例属性
类属性就是类对象所拥有的属性,它被所有类对象的实例对象所共有,在内存中只存在一个副本。
在前面的例子中我们接触到的就是实例属性(对象属性),它不被所有类对象的实例对象所共有,在内存中的副本个数取决于对象个数。
类方法是类对象所拥有的方法,需要用修饰器一般以 @classmethod 来标识其为类方法,
1. 对于类方法,第一个参数必须是类对象,作为第一个参数
(cls是形参, 可以修改为其它变量名,但最好用'cls'了)
2. 能够通过实例对象和类对象去访问。
静态方法需要用修饰器一般以 @staticmethod 来标识其为静态方法,
1. 静态方法不需要多定义参数
2. 能够通过实例对象和类对象去访问。
### property类属性
1. Python内置的@property装饰器就是负责把一个方法变成属性调用的;
2. @property本身又创建了另一个装饰器@state.setter,负责把一个 setter 方法变成属性赋值,于是,我们就拥有一个可控的属性操作.
3. @property广泛应用在类的定义中,可以让调用者写出简短的代码,同时保证对参数进行必要的检查,这样,程序运行时就减少了出错的可能性。
### 单例模式
对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任务;一个系统只能有一个窗口管理器或文件系统;一个系统只能有一个计时工具或ID(序号)生成器。如在Windows中就只能打开一个任务管理器。如果不使用机制对窗口对象进行唯一化,将弹出多个窗口,如果这些窗口显示的内容完全一致,则是重复对象,浪费内存资源;如果这些窗口显示的内容不一致,则意味着在某一瞬间系统有多个状态,与实际不符,也会给用户带来误解,不知道哪一个才是真实的状态。因此有时确保系统中某个对象的唯一性即一个类只能有一个实例非常重要。
```python
# https://www.cnblogs.com/wozijisun/p/16635365.html
def singleton(cls):
_instance_dict = {}# 采用字典,可以装饰多个类,控制多个类实现单例模式
def inner(*args, **kwargs):
if cls not in _instance_dict:
_instance_dict = cls(*args, **kwargs)
return _instance_dict.get(cls)
return inner
@singleton
class Teacher:
def __init__(self, name, age):
self.name = name
self.age = age
@singleton
class Student:
def __init__(self, name, age):
self.name = name
self.age = age
def get(self):
t1 = Teacher("aa",52)
return t1
# def __new__(cls, *args, **kwargs): # 将方法3的这部分代码搬到了函数装饰器中
# if not cls._instance:
# cls._instance = super().__new__(cls)
# return cls._instan
stu1 = Student('bb', 18)
stu2 = Student('jack', 18)
stu3 = Student('aaa', 19)
print(stu1 is stu3)
print(stu1.__dict__, stu3.__dict__)
t1 = Student('bb', 18).get()
t2 = Student('bb', 18).get()
print(t1 is t2)
```
装饰器(**decorator**)可以动态地修改一个类或函数的功能。这里,我们也可以使用装饰器来装饰某个类,使其只能生成一个实例,代码如下:
页:
[1]