随笔 - 105  文章 - 0  评论 - 0  阅读 - 40744

面向对象基础

1、在实例化过程时,会把对象即变量名也隐式到传到类开辟的空间,这就是为什么__init__里需要self参数。

2、非构造函数(__init__)即方法不会复制到内存空间去,方法调用时相对于:Role.buy_gun(r1)同等于r1.buy_gun(),由于要知道实例,所以类里的每个方法都需要有个self参数

3、实例变量:在构造函数中定义的变量

      类变量:在所有函数外的变量。例:如类有变量n,有两个实例obj1、obj2,则obj1.n的更改不会改变obj2.n的,也不会改变类变量n。因为obj1会新建一个变量n,与类中的变量完全没关系。 节省开销

4、找属性变量时先从实例找,再从类中找(即静态属性),静态属性如果obj1改变了,obj2也会改变。实例化后可添加新属性,如obj.new_pro = val,但此类中的其它对象则没此属性。也可删除属性,del obj.pro。

5、析构函数:def __def__(self) 用于在对象被销毁时自动执行收尾工作,不能添加参数。

6、私有属性、私有方法:名称前加两条下划线__。只能在对象内部调用。

 

一、继承

1、子类继承父类类名写法:class Sub_class_name(father_class_name)

2、在子类中重写父类的方法:在子类用与父类一样的函数名即可重写

3、在子类函数中使用父类方法:(1)、father_class_name.fun(<父类参数>)

(2)super(sub_class_name,self).__init__(<父类参数,除self>)

4、py2 经典类是采用深度优先继承,新式类是受用广度优先继承

      py3 经典类和新式类都是广度优先继承。

5、可通过组合继承?

 

二、多态

原则:一个接口,多种实现,则接口重用。例子:

def main():
class Animal(object):
def __init__(self, name):
self.name = name

@staticmethod
def talk(obj):
obj.talk()

class Dog(Animal):
def talk(self):
print('Woo Woo!')

class Cat(Animal):
def talk(self):
print('Meow!')

d = Dog('test1')
c = Cat('test2')

Animal.talk(c)
Animal.talk(d)


if __name__ == '__main__':
main()
posted on   Treelight  阅读(114)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示