面向对象 - 封装/property - 总结
面向对象 - 封装:
封装:在类定义阶段,以__开头的属性名发生了变形 eg: __x --> _A__x / __foo --> _A__foo
1.特点:
1.在类外部无法直接访问 __x 是 _A__x
2.在类内部可以直接使用 self.__foo() == self._A__foo()
3.子类无法覆盖父类以__开头的属性 因为根本不是一个名字 __x _A__x
2.总结:
这种变形需要注意的问题:
1.这种机制也并没有真正意义上限制我们从外部直接访问属性,知道了类名和属性名就可以拼出名字:_类名__属性,然后就可以访问了,
如a._A__N eg:print(A._A__x) 但一般不这样做!
2.变形的过程只在类的定义时发生一次,在定义后的赋值操作,不会变形 eg: b.__age=18 {'_B__name': 'alice', '__age': 18}
3.在继承中,父类如果不想让子类覆盖自己的方法,可以将方法定义为私有的 eg: def __foo(self): #_A__foo
3.意义:
1.封装数据属性的目的:(封装不是单纯意义上的隐藏)
明确的区分内外,控制外部对隐藏属性的操作行为 对接口 设定规则
2.封装方法属性的目的:
隔离复杂度 a=ATM() a.withdraw() 对接口 设定规则
4.扩展性:
def tell_area(self) 对使用者来说不用改变方式 开发者在类里面扩展
面向对象的三大特征:继承 多态 封装
面向对象的优点:可扩展性高
class A:
__x=1
def __init__(self,name):
self.name=name def __foo(self):
print('run foo') def bar(self):
self.__foo()
print('run bar') a=A('alice')
# print(a.__dict__)
# print(a.name)
# a.bar()
# # a.foo()
# a._A__foo()
# # print(a.__x)
# print(a._A__x)
# print(A.__dict__) # a.bar()
# a.__foo() # a.__x=1
# print(a.__dict__)
# print(a.__x)
# print(A.__dict__) # A.__x=2
# print(A.__x)
# print(A.__dict__) class Foo:
def __func(self):
print('from foo') class Bar(Foo):
def __init__(self,name):
self.__name=name def __func(self):
print('from bar') # b=Bar()
# # b.func()
# print(Foo.__dict__)
# print(Bar.__dict__) b=Bar('alice')
# print(b.__dict__)
# print(b.name)
# print(b._Bar__name) class A:
def __foo(self): #_A__foo
print('A.foo') def bar(self):
print('A.bar')
self.__foo() #self._A__foo() # 只调自己类的方法 定义时就已经确定好的! class B(A):
def __foo(self): # _B_fooo
print('B.foo') # b=B()
# b.bar() # print(A.__dict__)
# print(B.__dict__) class People:
def __init__(self,name,age):
self.__name=name
self.__age=age def tell_info(self): #对接口 设定规则
print('name:<%s> age:<%s>'%(self.__name,self.__age)) def set_info(self,name,age):
if not isinstance(name,str):
print('名字必须是字符串类型')
return
if not isinstance(age,int):
print('年龄必须是数字类型')
return
self.__name=name
self.__age=age p1=People('alice',12)
# print(p1.name,p1.age)
# print(p1.__dict__)
# p1.tell_info()
# p1.set_info('alex',18)
# p1.tell_info() class ATM:
def __card(self):
print('插卡') def __auth(self):
print('用户认证') def __input(self):
print('输入取款金额') def __print_bill(self):
print('打印账单') def __take_money(self):
print('取款') def withdraw(self):
self.__card()
self.__auth()
self.__input()
self.__print_bill()
self.__take_money() # a=ATM()
# a.withdraw() class Room:
def __init__(self,name,owner,weight,length,height):
self.name=name
self.owner=owner
self.__weight=weight
self.__length=length
self.__height=height def tell_area(self):
return self.__weight * self.__length * self.__height r=Room('客厅','alice',100,100,100)
# print(r.tell_area())
封装
面向对象 - property:
property:
1.@property 将函数属性 伪装成 数据属性
2.必须要有返回值 return ''
3.@property 查看 必须要有返回值 print(p.name) name 是函数属性 不是数据属性 伪装成 数据属性
@name.setter 修改 p.name='alex'
@name.deleter 删除 del p.name
总结:通过计算得来的方法 可以通过@property 伪装成数据属性
class People:
def __init__(self,name,weight,height):
self.name=name
self.weight=weight
self.height=height @property
def bmi(self):
return self.weight / (self.height ** 2) p = People('alice',60,1.65)
# print(p.bmi())
# print(p.bmi)
# p.bmi=12 class People:
def __init__(self,name):
self.__name=name @property
def name(self):
return self.__name @name.setter
def name(self,val):
if not isinstance(val,str):
print('名字必须是str')
return
self.__name=val @name.deleter
def name(self):
print('不允许删除') p=People('alice')
print(p.name)
p.name='alex'
print(p.name)
del p.name
property
面向对象 - 封装/property - 总结的更多相关文章
- Python 面向对象 组合-多态与多态性-封装-property
面向对象-组合 1.什么是组合 组合指的是某一个对象拥有一个属性,该属性的值是另外一个类的对象 class Foo: xxx = 111 class Bar: yyy = 222 obj = Foo( ...
- 从普通函数到对象方法 ------Windows窗口过程的面向对象封装
原文地址:http://blog.csdn.net/linzhengqun/article/details/1451088 从普通函数到对象方法 ------Windows窗口过程的面向对象封装 开始 ...
- Python之面向对象封装
Python之面向对象封装 封装不是单纯意义的隐藏 什么是封装: 将数据放在一个设定好的盒子里,并标出数据可以实现的功能,将功能按钮外露,而隐藏其功能的工作原理,就是封装. 要怎么封装: 你余额宝有多 ...
- python面向对象(封装、多态、反射)
目录 面向对象之封装 @property 面向对象之多态 面向对象之反射 面向对象之封装 含义 将类中的某些名字按照特殊的书写方式"隐藏"起来,不让外界直接调用,目的是为了不然外界 ...
- Java面向对象㈠ -- 封装
Java的面向对象有三大特征:封装.继承.多态.这里主要对封装进行讲解. 封装可以理解为隐藏一个类的成员变量和成员函数,只对外提供需要提供的成员函数. Java的封装主要通过访问权限控制符:priva ...
- Atitit usbQb212 oo 面向对象封装的标准化与规范解决方案java c# php js
Atitit usbQb212 oo 面向对象封装的标准化与规范解决方案java c# php js 1.1. 封装性是面象对象编程中的三大特性之一 三个基本的特性:封装.继承与多态1 1.2. 魔 ...
- Atitit 面向对象 封装的实现原理
Atitit 面向对象 封装的实现原理 1.1. 动态对象的模拟使用map+函数接口可以实现1 1.2. 在用结构体 + 函数指针 模拟 对象 1 1.3. This指针..1 1.4. " ...
- java基础1.0::Java面向对象、面向对象封装、抽象类、接口、static、final
一.前言 一直以来都是拿来主义,向大神学习,从网上找资料,现在就把自己在工作中和学习中的所理解的知识点写出来,好记星不如烂笔头,一来可以作为笔记自己温习,二来也可以给走在求学之路的同学们一点参考意见, ...
- OC面向对象—封装
OC面向对象—封装 一.面向对象和封装 面向对象的三大特性:封装(成员变量).继承和多态 在OC语言中,使用@interface和@implementation来处理类. @interface就好像暴 ...
随机推荐
- debian下运行netstat失败
如果提示:bash: netstat: command not found 说明没有安装netstat工具,而该工具在 net-tools 工具包内. apt-get install net-tool ...
- atitit.http get post的原理以及框架实现java php
atitit.http get post的原理以及框架实现java php 1. 相关的设置 1 1.1. urlencode 1 1.2. 输出流的编码 1 1.3. 图片,文件的post 1 2. ...
- RS232接口
想用下板子,却发现板子和USB转串口线都是母口,无耐只能自己用线将对应的管脚连起来. 结果测试的时候发现,板子能发不能收.将板子串口的23连起来,回环正常.电脑USB转串口线上的23连起来也回环正常. ...
- oracle 查询前30条数据
select * from (select a.*,rownum as rn from tetm_ad_type a) b where b.rn<30 --表名不能用as 字段取别名,直 ...
- 小马哥课堂-统计学-t分布(2)
t分布,随着自由度的增加,而逐渐接近于正态分布 #!/usr/bin/env python3 #-*- coding:utf-8 -*- ############################### ...
- Extjs的完成按钮和位置
this.toolbar.add('->') ---重点是这个箭头,他是控制位置的 this.CompleteDataAction = new Ext.Action({ text : '完成', ...
- Oracle 错误 maximum number of processes(150) exceeded 解决办法
网上很多同行应该都遇到过这个问题,百度一搜 千篇一律的处理办法,就是加大进程数. 但是我这边情况不一样,因为我的Oracle 11g是早上刚装的,跟本没人用,我用PLSQL链接照样说不能链接. 我就在 ...
- 在oschina添加了x3dom的索引
http://www.x3dom.org/ http://www.oschina.net/p/x3dom x3dom的思路非常优秀并且可行,借助于WebGL的春风,将X3D带到了死而复生的境地.
- 使用AccessibilityService实现微信自己主动抢红包
近期要实现微信自己主动抢红包的功能.使用AccessibilityService来开发,这里主要写一下逻辑以及注意点. 注意点 1.搜索keyword 我们实现某个功能比方点击等须要找到相应的对象然后 ...
- Cocos3.0 的android返回键功能实现
比如:Game.h Game.cpp 头文件Game.h中定义: void onKeyReleased(EventKeyboard::KeyCode keyCode,Event * pEvent) ...