多态,__new__魔术方法,单态模式---day22

网友投稿 588 2022-11-26

多态,__new__魔术方法,单态模式---day22

多态,__new__魔术方法,单态模式---day22

1.多态

# ### 多态:不同的子类对象,调用相同的父类方法,产生了不同的执行效果'''关键字:继承 改写'''class Soldier(): #攻击 def attack(): pass #撤退 def back(): pass#陆军class Army(Soldier): def attack(self): print("[陆军]上来拼刺刀,你捅我我捅你,一刀999") def back(self): print("[陆军]撤退就跑") #海军class AirForce(Soldier): def attack(self): print("[空军]拿起二营长的意大利炮对敌方开展猛烈攻击") def back(self): print("[空军]弃机跳伞,落地成盒") #实例化陆军,产生陆军士兵obj_army = Army()#实例化海军,产生海军士兵obj_navy = Navy()#实例化空军,产生空军士兵obj_airforce = AirForce()#各部分注意,等待将军的命令lst = [obj_army,obj_navy,obj_airforce]'''1.全体出击2.全体撤退3.空军上,其他人撤4.按q键退出'''sign = Truewhile sign: num = input("将军请下令:") for i in lst: if num == "1": i.attack() elif num == "2": i.back() elif num == '3': if isinstance(i,AirForce): i.attack() else: i.back() elif num.upper() == 'Q': print("将军,您辛苦了~") sign = False break else: print("风太大,我听不见!") break

2. __new__魔术方法

# ### __new__ 魔术方法''' 触发时机:实例化类生成对象的时候触发(触发时机在__init__之前) 功能:控制对象的创建过程 参数:至少一个cls接受当前的类,其他根据情况决定 返回值:通常返回对象或None'''#(1)基本语法class MyClass(): a = 1other obj = MyClass()print(other obj)class MyClass1(object): def __new__(cls): print(cls) #(1) 借助父类object 类.方法() # obj = object.__new__(cls) # 返回本类自己的对象 # return obj #(2) 返回其他类的对象 # return other obj #(3)不返回任何对象 return Noneobj = MyClass1()print(obj)#print(obj.a)#(2) new 方法触发时机要快于init'''__new__ 用来创建对象__init__ 用来初始化对象(前提得有对象)先创建对象,再去初始化对象,所以new快于init'''class Boat(): def __init__(self): print(2) def __new__(cls): print(1) return object.__new__(cls)obj = Boat()#(3) new方法的参数要和init方法参数一一对应#一个参数class Boat(): def __new__(cls,name): return object.__new__(cls) def __init__(self,name): self.name = name obj1 = Boat('泰坦尼克号')print(obj1.name)#多个参数class Boat(): def __new__(cls,*args,**kwargs): return object.__new__(cls) def __init__(self,name,a,b,c,d,e): self.name = nameobj = Boat("泰坦尼克号",2,3,4,5,6)print(obj.name)#(4)注意点'''如果返回的不是本类的对象,不会触发__init__构造方法'''print("================")class MyClass(): a = 1other_obj = MyClass()class Boat(): def __new__(cls): return other_obj def __init__(self): print("构造方法被触发")obj = Boat() #不会打印 "构造方法被触发"

3.单态模式

# ### 单态(例)模式:无论实例化多少次,都有且只有一个对象'''目的意义:为了节省内存空间,仅仅是为了调用类中的成员不需要额外给该对象添加任何成员,这个场景,使用单态比如:操作数据库的增删改查这样的类,是不需要的'''#(1) 基本语法class Singleton(): __obj = None #定义一个私有变量 def __new__(cls): #创建一个new方法 if cls.__obj is None: #判断这个对象是否为None cls.__obj = obj.__new__(cls) #为None 就创建一个对象 return cls.__obj #返回对象'''<__main__.Singleton object at 0x000001FB3F207278>有这个对象直接返回,没这个对象,就给你创建,保证只有一个第一次实例化时,if cls.__obj is None 条件为真,创建一个对象放到cls._obj,最后返回第二次实例化时,if cls.__obj is None 条件为假 , 直接返回第三次实例化时,if cls.__obj is None 条件为假 , 直接返回第四次实例化时,if cls.__obj is None 条件为假 , 直接返回'''obj1 = Singleton()print(obj1)obj2 = Singleton()print(obj2)obj3 = Singleton()print(obj3)obj4 = Singleton()print(obj4)#(2) 单态模式 + 构造方法class Singleton(): __obj = None def __new__(cls,*args,**kwargs): if cls.__obj is None: cls.__obj = object.__new__(cls) return cls.__obj def __init__(self,name): self.name = nameobj1 = Singleton('王振')obj2 = Singleton('刘伟')print(obj1.name)print(obj2.name)#解析:'''obj1 = Singleton('王振') self.name = "王振"obj2 = Singleton('刘伟') self.name = '刘伟'obj1 和 obj2 都是同时指向同一个对象,因为对象只创建了一个对象.name 是获取最后那个指向的name即为刘伟,调了两次,即都打印一样的值'''

总结:今天主要讲了继承的多态,__new__魔术方法,已经单态模式

多态就是不同的子类对象,调用相同的父类方法,产生了不同的执行效果

魔术方法__new__ 触发时机,在实例化生成对象的时候触发(在__init__初始化之前)

主要功能控制对象的创建过程,参数至少一个cls接收当前类,返回值,通过返回对象或None

new方法的参数要和init方法参数一一对应,注意点,如果返回的不是本类对象,就不会触发__init__构造方法

单态模式就是无论实例化多少次,都有且只有一个对象

目的是为了节省内存空间,用在仅仅是为了调用类中的成员不需要额外给该对象添加任何成员这种场景,如操作数据库的增删改查。

语法首先定义一个类,类里面定义一个私有属性并赋值为None,在创建一个new方法,传入一个cls,写个if判断,判断这个私有

变量是否为None,为None就执行if语句下的代码块,用obj.__new__(cls)创建一个对象,最后return这个对象,调用处,无论实例化多少个对象,只创建一个对象,此时都指向同一个对象

-------------------------------------------

个性签名:代码过万,键盘敲烂!!!

如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring定时任务无故停止又不报错的解决
下一篇:cmake安装及报错解决办法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~