写点什么

趁着课余时间学点 Python(十二)面向对象的理解(结局)

用户头像
ベ布小禅
关注
发布于: 1 小时前
趁着课余时间学点Python(十二)面向对象的理解(结局)


@[toc]

前言

由于马上就要期末考试了,正在抓紧时间复习所以这一篇就拖了很久,抱歉啦~


今天会说说:


属性私有,方法私有,重写,魔术方法

1. 私有化

上篇说过封装,既将我们不想让别人看到代码的内容,但是又需要用到的内容,通过类内部调用来实现调用。


说到这里却不得不提一下上篇的:


class Person(object):    def __init__(self, name, age):        self.xxx = name        self.xxxx = age
复制代码


这里面 self 后面的名字,是可以自己随意命名的,上一篇和后面一样只是为了好记忆罢了


只要你记得住,便是颠倒也是无事

1.1 属性私有化

何为属性私有?


举个例子便是:你的私房钱,你的手机电脑里面的小秘密等等这些不想被别人知道的东西


那么上面就说了,封装的目的是什么,不就是隐藏那些不想让别人知道的代码吗


所以有个属性私有化,可以让你的类属性变成私有的,这可和上篇的封装不一样,封装了还能通过实例化对象调用;这个属性一旦变成私有的,你在类外部是无法调用的


那我想用了怎么办?在类内部调用嘛!


好,叭叭了这么多,想必你们也得烦了,上代码


使用格式:


class Xxx(object):    age = 20    _name = "Xxx"
复制代码


这种前面带着一个下划线的就是私有属性,无法通过类外部实例化对象的方法进行调用


具体应用:


"""定义一个挺人类含有姓名,年龄,体重,身高将体重设置私有化通过类内部调用使得能够在类外部看到你的体重"""class Person(object):    _weight = 70    def __init__(self, name, age, height):        self.name = name        self.age = age        self.height = height     def weightPrint(self):        print("我的体重是:", self._weight)
person = Person("布小禅", 20, 180)person.weightPrint()
复制代码


这个体重就无法通过person.weightperson._weight这样调用,因为这个属性是私有的

1.2 方法私有化

我觉得这个倒是不必多说,只需要在定义的类方法名字前面也加一个_就可以了


class Person(object):    def _love(self):        print("我暗恋Xxx")
复制代码


这个方法也是无法通过实例化对象来调用的,调用需要这样:


class Person(object):    def _love(self):        print("我暗恋Xxx")        def speakLove(self):        self._love()
复制代码

2. 重写

重写需要在继承的时候使用


儿子继承了父亲的东西后,但是不会完全和父亲一样,而是会有自己的东西,比如说话,玩耍等,这时候就需要使用重写,给父亲的东西多增加一些


格式:


super().父类方法名(self)
复制代码


像这样,我们继承 object 类,__init__是 object 类的方法,所以要重写


class Person(object):    def __init__(self):        super().__init__(self)        print("我是重写加的")
复制代码


就像这样


而一般来说,写__init__的时候,是需要先加重写方法,再做封装

3. 魔术方法

魔术方法也就是 object 类的各种方法,他们都是__xx__形式的,都具有一些特定的作用


比如__init__就是构造方法


而有些魔术方法我们平时构造类的时候会时常用的到,我就说说那些常用的

3.1 __init__方法

基本上这个是必须用的,也见过多次了,就不一一叙述了

3.2 __str__方法

这个魔术方法的作用和函数的返回值一样,不过却是返回字符串


使得在实例化对象后,可以使用 print()函数打印出 str 方法返回的值


就像这样:


class Person(object):    def __str__(self):        return "我是__str__方法的返回值,显示在打印实例化对象时"
p = Person()print(p)
复制代码


运行代码会显示:


我是__str__方法的返回值,显示在打印实例化对象时

3.3 __del__方法

一看 del 就是和删除有关的


也确实是,当这个类的实例化被系统内存销毁时毁掉用这个方法


说直白点就是当这个类的实例化对象没用了后,系统会删除这个实例化对象在系统占用的内存,而删除的时候,就会调用这个方法


class Person(object):    def __del__(self):        print("我没用了,我被删除了")        p = Person()
复制代码


运行显示:


我没用了,我被删除了

3.4 __new__方法

这个__new__方法在实例化对象的时候是比__init__方法还先执行的


而这个 new 方法和别的方法也不大一样,因为别的方法都必须有个默认的参数 self


而这个方法的必须有的参数是 cls


看代码理解:


class Person(object):    def __init__(self):        print("我是构造方法__init__")        def __new__(cls):        print("我是__new__方法")        p = Person()
复制代码


代码运行结果:


我是__new__方法


那么我们的 init 方法为什么无法被执行呢?


因为先调用的 new 方法,参数是当前类,需要返回值,返回重写方法


像这样:


class Person(object):    def __init__(self):        print("我是构造方法__init__")        def __new__(cls):        print("我是__new__方法")        return super().__new__(cls)    p = Person()
复制代码


这样运行的结果就是:


我是__new__方法我是构造方法__init__

3.5 __call__方法

让实例化对象类似于函数化,函数是不是都是:xx()的形式


而 call 方法也可以让实例化对象:xx()


只要写个类,我们实例化了对象,然后写个 call 方法,我们就可以实例化对象()


class Person(object):    def __call__(self):        print("执行了__call__方法")p = Person()print(p())
复制代码


运行结果:


执行了__call__方法 None


而为什么是 None 呢?


因为 call 方法里面没有返回值啊,自然就是空


你可以设置返回值


来让实例化对象()显示返回值


像这样:


class Person(object):    def __call__(self):        print("执行了__call__方法")        return "我是返回值"p = Person()print(p())
复制代码


运行结果:


执行了__call__方法我是返回值

结语

兴趣是最好的老师,坚持是不变的真理。学习不要急躁,一步一个脚印,踏踏实实的往前走。每天进步一点点,日积月累之下,你就会发现自己已经变得很厉害了。


我是布小禅,一枚自学萌新,跟着我每天进步一点点吧!


说了这么多暂时也就够了,那么就告辞吧



发布于: 1 小时前阅读数: 3
用户头像

ベ布小禅

关注

还未添加个人签名 2021.04.06 加入

平平无奇一萌新,默默无闻学IT,我是布小禅,一个网络专业却对编程及其感兴趣的小白! 目前在学python和Java,都很浅显,平时爱写点学习笔记。IT技术交流群:1039347613 也可以联系本人企鹅:2228660752 v:Smly0413

评论

发布
暂无评论
趁着课余时间学点Python(十二)面向对象的理解(结局)