学习总结2019.4.18

__init__方法

# 强调:
#   1、该方法内可以有任意的python代码
#   2、一定不能有返回值
class People:
    country=‘China‘
    x=1
?
    def __init__(obj, name, age, sex): #obj=obj1,x=‘egon‘,y=18,z=‘male‘
        # if type(name) is not str:
        #     raise TypeError(‘名字必须是字符串类型‘)
        obj.name = name
        obj.age = age
        obj.sex = sex
?
?
    def run(self):
        print(‘----->‘, self)
?
?
# obj1=People(‘egon‘,18,‘male‘)
obj1=People(3537,18,‘male‘)
?
# print(obj1.run)
# obj1.run() #People.run(obj1)
# print(People.run)
?
‘‘‘
# __init__方法会在实例化对象时被调用
# 1.会为实例化的对象形成空的名称空间
# 2.就是一个方法,可以被传参,在 类名(实参) 这种方式下调用并传参 __init__(self, 形参)
# 3.第一个self就是要产生的当前对象
# 重点:在方法内部,形参拿到了实参值,利用self.属性名 = 形参 = 实参值,对对象的名称空间添加属性
‘‘‘

对象方法

class A:
    # 对象方法
    def test(self, num):
        pass
a = A()
?
# 调用方法
# 二级优化
a.test(10)
# 一级优化
A.test(a, 10)
# 实现原理
A.__dict__[‘test‘](a, 10)
?
‘‘‘
类中定义的函数(没有被任何装饰器装饰的)是类的函数属性,类可以使用,但必须遵循函数的参数规则,有几个参数需要传几个参数
?
类中定义的函数(没有被任何装饰器装饰的),其实主要是给对象使用的,而且是绑定到对象的,虽然所有对象指向的都是相同的功能,但是绑定到不同的对象就是不同的绑定方法
?
强调:绑定到对象的方法的特殊之处在于,绑定给谁就由谁来调用,谁来调用,就会将‘谁’本身当做第一个参数传给方法,即自动传值(方法__init__也是一样的道理)
?
注意:绑定到对象的方法的这种自动传值的特征,决定了在类中定义的函数都要默认写一个参数self,self可以是任意名字,但是约定俗成地写出self。
?
‘‘‘

类方法:类中@classmethod修饰的方法

class Tool:
    @classmethod
    def add(cls, n1, n2):  # 统一类与对象都可以调用类方法,一定有默认传入第一个参数
        return n1 + n2

# 建议
Tool.add(10, 20)  # 默认第一个传入自身 - Tool
?
# 不建议
tool = Tool()
tool.add(100, 200)   # 默认第一个传入自身所属类 - tool.__class__

属性与方法总结
class OldBoy:
    # 属于类的属性
    name = ‘老男孩‘
?
    # 属于对象的属性
    def __init__(self, name):
        self.name = name
?
    # 属于类的方法
    # 需求:获取机构的名字
    @classmethod
    def get_class_name(cls):
        return cls.name
?
    # 属于对象的方法
    # 需求:获取校区的名字
    def get_school_name(self):
        return self.name
?
# 先创建校区
shanghai = OldBoy(‘上海校区‘)
shenzhen = OldBoy(‘深圳校区‘)
?
# 类方法的使用
# 建议使用类调用
print(OldBoy.get_class_name())
# 类方法拿对象调用并没有多少新增的意义,不建议拿对象调用
print(shanghai.get_class_name())
print(shenzhen.get_class_name())
?
# 对象方法的使用
# 类调用对象方法,必须把要操作的对象手动传入,不建议使用
print(OldBoy.get_school_name(shanghai))
print(OldBoy.get_school_name(shenzhen))
# 对象调用对象方法,默认将自身传入,建议使用
print(shanghai.get_school_name())
print(shenzhen.get_school_name())

封装

  • 隐藏:在python中用双下划线开头的方式将属性隐藏起来(设置成私有的)
#其实这仅仅这是一种变形操作且仅仅只在类定义阶段发生变形
#类中所有双下划线开头的名称如__x都会在类定义时自动变形成:_类名__x的形式:
?
class A:
    __N=0 #类的数据属性就应该是共享的,但是语法上是可以把类的数据属性设置成私有的如__N,会变形为_A__N
    def __init__(self):
        self.__X=10 #变形为self._A__X
    def __foo(self): #变形为_A__foo
        print(‘from A‘)
    def bar(self):
        self.__foo() #只有在类内部才可以通过__foo的形式访问到.
?
#A._A__N是可以访问到的,
#这种,在外部是无法通过__x这个名字访问到。
?
‘‘‘
这种变形需要注意的问题是:
?
1.这种机制也并没有真正意义上限制我们从外部直接访问属性,知道了类名和属性名就可以拼出名字:_类名__属性,然后就可以访问了,如a._A__N,即这种操作并不是严格意义上的限制外部访问,仅仅只是一种语法意义上的变形,主要用来限制外部的直接访问。
?
2.变形的过程只在类的定义时发生一次,在定义后的赋值操作,不会变形
?
3.在继承中,父类如果不想让子类覆盖自己的方法,可以将方法定义为私有的
‘‘‘
  • 封装
‘‘‘
1:封装数据:将数据隐藏起来这不是目的。隐藏起来然后对外提供操作该数据的接口,然后我们可以在接口附加上对该数据操作的限制,以此完成对数据属性操作的严格控制。
?
2:封装方法:目的是隔离复杂度;外界不能直接访问,让内部的属性与方法具有安全保障
‘‘‘
?
class A:
    # 类的属性:__开头的属性,在外界不能通过 cord | __cord 直接访问:对外隐藏了
    __cord = ‘01012300‘
?
    # 类的方法:__开头的方法,在外界不能通过 get_money | __get_money 直接访问:对外隐藏了
    @classmethod
    def __get_money(cls):
        print(‘输入密码,取出100w零花钱‘)

    # 对象的方法:一般的实现需求都是,这些方法只在内部使用
    def __test(self):
        pass

    # 对象的属性:封装目的
    # 1.对象的属性值一般都来源于外界,外界是有权力再次访问的
    # 2.封装的目的不是让外界无法访问,而且不让其直接访问,可以在完成安全处理后再访问
    # 3.如何做到外界还是通过变量名来对属性进行取值赋值,但是是走的方法间接拿到的值
    #       -- __money被封装,外界还是可以通过 对象.money 取值赋值
    def __init__(self, money)
        self.__money = money

    # 取值
    @property  # 在外界可以 对象.money 进行取值
    def money(self):
        # print(‘走方法拿到的money‘)
        return self.__money
?
    # 赋值
    @money.setter  # 在外界可以 对象.money = 新值 进行赋值
    def money(self, money):
        self.__money = money
?
    # 删除
    @money.deleter
    def money(self):
        del self.__money

原文地址:https://www.cnblogs.com/penghengshan/p/10754262.html

时间: 2024-10-08 19:28:14

学习总结2019.4.18的相关文章

《深入Java虚拟机学习笔记》- 第18章 finally子句

本章主要介绍字节码实现的finally子句.包括相关指令以及这些指令的使用方式.此外,本章还介绍了Java源代码中finally子句所展示的一些令人惊讶的特性,并从字节码角度对这些特征进行了解释. 1.微型子例程 字节码中的finally子句表现的很像"微型子例程".Java虚拟机在每个try语句块和与其相关的catch子句的结尾处都会"调用"finally子句的子例程.finally子句结束后(这里的结束指的是finally子句中最后一条语句正常执行完毕,不包括抛

2019.3.18考试&2019.3.19考试

2019.3.18 C O D E T1 树上直接贪心,环上for一遍贪心 T2 正反都做一遍DP T3 观察到顺序不影响答案,分块打标记 2019.3.19 肥肠爆芡,因为沙茶博主昨天在学校的煞笔食堂吃坏了肚子,所以这场考试咕咕了 我佛了 一定补这两场.jpg 原文地址:https://www.cnblogs.com/ydnhaha/p/10558495.html

2019.06.18学习python循环总结

常用循环: 1.for ... in 2.if ... else range(start, end, scan)函数: 参数含义: start:计数从start开始.默认是从0开始.例如range(5)等价于range(0, 5); end:技术到end结束,但不包括end.例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5 scan:每次跳跃的间距,默认为1.例如:range(0, 5) 等价于 range(0, 5, 1) 例子(分页): --------for  in -

Pyton学习路线2019升级版(课程大纲+视频教程+网盘资源下载)

2019最新Pyton全栈+人工智能学习路线升级版 全面涵盖前端.后端.爬虫.数据挖掘.人工智能等课程(课程大纲+视频教程+网盘资源下载)! 学习路线四大亮点: 1.人工智能三大主流框架全覆盖 2.贯通前端后端实用技术 3.强化人工智能项目实战能力 4.高度还原企业级数据挖掘分析场景 Python前景分析: Python以其简洁优美.功能强大.高效率的先天优势成为企业新宠 ,此外,国内计算机教育也越来越重视Python在编程中的地位. 1.教育大省北京和山东确定将Python编程基础纳入信息技术

【C语言解惑课堂】解惑内容合集(2019.8.18更新)

我的知识星球:"C语言解惑课堂"截止到2019年8月18日的所有解惑内容如下.要查看详细解析的C语言难点或者需要提问的同学,微信扫扫文末的星球二维码加入吧! 一.基础难点剖析 [第1篇][C语言基础][unsigned short类型用于循环的一个难点] [第2篇][C语言基础][unsigned int溢出] [第3篇][C语言基础][int类型溢出] [第4篇][C语言基础][字符与字符串的区别] [第5篇][C语言基础][&&运算符两边的数值] [第33篇][C语

学习动态性能表(18)--v$system_event

学习动态性能表 第18篇--V$SYSTEM_EVENT  2007.6.13 本视图概括了实例各项事件的等待信息.v$session_wait显示了系统的当前等待项,v$system_event则提供了自实例启动后各个等待事件的概括.常用于获取系统等待信息的历史影象.而通过两个snapshot获取等待项增量,则可以确定这段时间内系统的等待项. V$SYSTEM_EVENT中的常用列 EVENT:等待事件名称 TOTAL_WAITS:此项事件总等待次数 TIME_WAITED:此项事件的总等待时

Linux 学习记录 2019年5月5日

2.1 shell内核:include <stdio.h> shell是应用程序控制硬件终端的一个统称.bash 1:广泛 2:好用 tab键补齐 .既然Linux系统中已经有了Bash这么好用的"翻译官",那么接下来就有必要好好学习下怎么跟它沟通了. 常见执行Linux命令的格式是这样的:命令名称 [命令参数] [命令对象]注意,命令名称.命令参数.命令对象之间请用空格键分隔. 命令:要做的事情参数:对命令的修饰 让命令更加适用于当前的工作场景对象:被动方,承受者 命令对

Python 学习日志9月18日

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Helvetica Neue"; color: #000000 } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "PingFang SC"; color: #000000 } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "Hel

《白帽子讲WEB安全》学习笔记之第18章 安全运营

第18章 安全运营 18.1 把安全运营起来 战略: q  寻找漏洞并修补--漏洞修补 q  防御快速响应--安全监控 q  规范开发流程--入侵检测 18.2 漏洞修补流程 流程: q  建立类似Bug Tracker的漏洞跟踪机制,并为漏洞的紧急程序选择优先级 q  建立漏洞分析机制,并与程序员一起制定修补方案,同时review补丁的代码实现 q  对曾经出现的漏洞进行归档,并定期统计漏洞的修补情况 Bug Tracker 这是一个用于软件开发和测试阶段的缺陷跟踪.过失跟踪和问题跟踪工具.你