首页 > 代码库 > 多态和封装
多态和封装
多态
>>> "This is a book".count("s")2>>> [1,2,4,3,5,3].count(3)2
count()
的作用是数一数某个元素在对象中出现的次数
>>> f = lambda x,y:x+y>>> f(2,3)5>>> f("qiw","sir")‘qiwsir‘>>> f(["python","java"],["c++","lisp"])[‘python‘, ‘java‘, ‘c++‘, ‘lisp‘]
lambda函数中,我们没有限制参数的类型,也一定不能限制,因为如果限制了,就不是pythonic了。在使用的时候,可以给参数任意类型,都能到的不报错的结果。当然,这样做之所以合法,更多的是来自于+
的功能强悍。
repr()函数,针对输入的任何对象返回一个字符串。
>>> repr[1,2,3]‘[1,2,3]‘>>> repr(1)‘1‘>>> repr({"lang":"python"})"{‘lang‘:‘python‘}"
#!/usr/bin/env python# coding=utf-8"the code is from: http://zetcode.com/lang/python/oop/"__metaclass__ = typeclass Animal: def __init__(self, name=""): self.name = name def talk(self): passclass Cat(Animal): def talk(self): print "Meow!"class Dog(Animal): def talk(self): print "Woof!"a = Animal()a.talk()c = Cat("Missy")c.talk()d = Dog("Rocky")d.talk()
代码中有Cat和Dog两个类,都继承了类Animal,它们都有talk()
方法,输入不同的动物名称,会得出相应的结果。
多态问题,最后还要告诫,类型检查是毁掉多态的利器,比如type、isinstance以及isubclass函数,所以,一定要慎用这些类型检查函数。
封装和私有化
python中私有化的方法也比较简单,就是在准备私有化的属性(包括方法、数据)名字前面加双下划线。
#!/usr/bin/env python# coding=utf-8__metaclass__ = typeclass ProtectMe: def __init__(self): self.me = "qiwsir" self.__name = "kivi" def __python(self): print "I love Python." def code(self): print "Which language do you like?" self.__python()if __name__ == "__main__": p = ProtectMe() print p.me print p.__name
用上面的方法,的确做到了封装。但是,我如果要调用那些私有属性,怎么办?
可以使用property
函数。
#!/usr/bin/env python# coding=utf-8__metaclass__ = typeclass ProtectMe: def __init__(self): self.me = "qiwsir" self.__name = "kivi" @property def name(self): return self.__nameif __name__ == "__main__": p = ProtectMe() print p.name
用了@property
之后,在调用那个方法的时候,用的是p.name
的形式,就好像在调用一个属性一样,跟前面p.me
的格式相同。
多态和封装
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。