💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
## 私有权限 ### 面向对象三大特性:封装、继承、多态 #### 封装的意义: 1. 将属性和方法放到一起做为一个整体,然后通过实例化对象来处理; 2. 隐藏内部实现细节,只需要和对象及其属性和方法交互就可以了; 3. 对类的属性和方法增加 访问权限控制。 #### 私有权限:在属性名和方法名 前面 加上两个下划线 \_\_ > 1. 类的私有属性 和 私有方法,都不能通过对象直接访问,但是可以在本类内部访问; > 2. 类的私有属性 和 私有方法,都不会被子类继承,子类也无法访问; > 3. 私有属性 和 私有方法 往往用来处理类的内部事情,不通过对象处理,起到安全作用。 ~~~ class Master(object): def __init__(self): self.kongfu = "古法烤冷面配方" def make_cake(self): print("[古法] 按照 <{}> 制作了一份烤冷面...".format(self.kongfu)) # 父类是 Master类 class School(Master): def __init__(self): self.kongfu = "现代烤冷面配方" def make_cake(self): print("[现代] 按照 <{}> 制作了一份烤冷面...".format(self.kongfu)) super().__init__() # 执行父类的构造方法 super().make_cake() # 执行父类的实例方法 class Prentice(School, Master): def __init__(self): self.kongfu = "夏氏烤冷面配方" # 私有属性,可以在类内部通过self调用,但不能通过对象访问 self.__money = 10000 # 私有方法,可以在类内部通过self调用,但不能通过对象访问 def __print_info(self): print(self.kongfu) print(self.__money) def make_cake(self): self.__init__() print("[夏氏] 按照 <{}> 制作了一份烤冷面...".format(self.kongfu)) def make_old_cake(self): Master.__init__(self) Master.make_cake(self) def make_new_cake(self): School.__init__(self) School.make_cake(self) class PrenticePrentice(Prentice): pass laoxia = Prentice() # 对象不能访问私有权限的属性和方法 # print(laoxia.__money) # laoxia.__print_info() pp = PrenticePrentice() # 子类不能继承父类私有权限的属性和方法 print(pp.__money) pp.__print_info() ~~~ #### 总结 * Python中没有像C++中 public 和 private 这些关键字来区别公有属性和私有属性。 * Python是以属性命名方式来区分,如果在属性和方法名前面加了2个下划线'\_\_',则表明该属性和方法是私有权限,否则为公有权限。