上学笔记,类民用成员和保卫安全成员

2019-10-22 19:18 来源:未知

python中的protected和private

python中用

_var ;变量名前贰个下划线来定义,此变量为保卫安全成员protected,唯有类及其子类能够访谈。此变量不能通过from XXX import xxx 导入

__var;变量名前三个下划线来定义,此变量为私有private,只同意类自个儿访问,连子类都不可能访谈。

 

class perent_class(object):
    def __init__(self,name,protected,private):
        self.name = name
        self._protected = protected
        self.__private = private

 

Linux and python学习调换1,2群已满.

Linux and python学习调换3群新开,款待到场,一同学习.qq 3群:563227894

不前行,不倒退,结束的图景是未有的.

手拉手前进,与君共勉,

 

四周四次课(七月7日)

风流倜傥、 类的重写

1.1 重写经常方法

class A:
    def hello(self):
        print('Hello,i am A.')
class B(A):
    pass
a = A()
b = B()
a.hello()
b.hello()

结果:

Hello,i am A.
Hello,i am A.

解释:

B类未有概念自身的hello方法,故当hello被调用时,原始新闻就被打字与印刷出来了。

B类也能够重写那几个hello方法

class A:
    def hello(self):
        print('Hello,i am A.')
class B(A):
    def hello(self):  
        print('Hello,i am B.')
a = A()
b = B()
a.hello()
b.hello()

结果:

Hello,i am A.
Hello,i am B.

1.2 重写特殊的构造方法

1、调用未绑定的基类构造方法

class Bird:
    def __init__(self):
        self.hungry = True
    def eat(self):
        if self.hungry:
            print('Aaaah...')
            self.hungry = False
        else:
            print('No,thanks!')
class SongBird(Bird):
    def __init__(self):
            Bird.__init__(self)
            self.sound = 'Squawk!'
    def sing(self):
        print(self.sound)
b = SongBird()
b.sing()
b.eat()
b.eat()

结果:

Squawk!
Aaaah...
No,thanks!

2、使用super函数

class Bird():
    def __init__(self):
        self.hungry = True
    def eat(self):
        if self.hungry:
            print('Aaaah...')
            self.hungry = False
        else:
            print('No,thanks!')
class SongBird(Bird):
    def __init__(self):
        super(SongBird,self).__init__()
        self.sound = 'Squawk!'
    def sing(self):
        print(self.sound)
b = SongBird()
b.sing()
b.eat()
b.eat()

结果:

Squawk!
Aaaah...
No,thanks!

解释:

Python 第22中学定义类要求写上object,不然报错。

二、类的村办变量

在Python中得以因此在品质变量名前增多双下划线定义属性为私有品质

奇异变量命名

1、 _xx 以单下划线最早的代表的是protected类型的变量。即爱慕品种只可以同意其本身与子类举办访谈。若里面变量标示,如: 当使用“from M import”时,不会将以三个下划线发轫的靶子引入 。

2、 __xx 双下划线的代表的是个体类型的变量。只好同意这一个类本人进行探问了,连子类也不得以用来命名一个类属性(类变量),调用时名字被退换(在类FooBar内部,__boo变成_FooBar__boo,如self._FooBar__boo)

3、 __xx__概念的是极度情势。客商调控的命名空间内的变量或是属性,如init , __import__唯恐file 。只有当文书档案有认证时使用,不要自个儿定义那类变量。 (正是说那个是python内部定义的变量名)

在此边强调说一下私有变量,python默许的成员函数和分子变量都以当众的,未有像其余类似语言的public,private等要害字修饰.但是足以在变量前面加上八个下划线"_",那样的话函数或变量就改成私有的.那是python的私有变量轧压(那么些翻译好拗口),丹麦语是(private name mangling.) **场地正是当变量被标志为私有后,在变量的前端插入类名,再类名前增加四个下划线"_",即形成了_ClassName__变量名.**

Python内置类属性

__dict__ : 类的本性(富含叁个字典,由类的数量属性组成)

__doc__ :类的文书档案字符串

__module__: 类定义所在的模块(类的全名是'__main__.className',即便类位居叁个导入模块mymod中,那么className.__module__ 等于 mymod)

__bases__ : 类的兼具父类构成要素(包含了多少个由具备父类组成的元组)

例子1:

class A(object):
    def __init__(self):
        self.__data = []  # 翻译成 self._A__data=[]

    def add(self, item):
        self.__data.append(item)  # 翻译成 self._A__data.append(item)

    def printData(self):
        print self.__data  # 翻译成 self._A__data


a = A()
a.add('hello')
a.add('python')
a.printData()
# print a.__data  #外界不能访问私有变量 AttributeError: 'A' object has no attribute '__data'
print a._A__data  # 通过这种方式,在外面也能够访问“私有”变量;这一点在调试中是比较有用的!

结果:

['hello', 'python']
['hello', 'python']

例子2:

class A():
    def __init__(self):
        self.__name = 'python'  # 私有变量,翻译成 self._A__name='python'

    def __say(self):  # 私有方法,翻译成 def _A__say(self)
        print self.__name  # 翻译成 self._A__name


a = A()
# print a.__name #访问私有属性,报错!AttributeError: A instance has no attribute '__name'
print a.__dict__  # 查询出实例a的属性的集合
print a._A__name  # 这样,就可以访问私有变量了
# a.__say()#调用私有方法,报错。AttributeError: A instance has no attribute '__say'
print dir(a)  # 获取实例的所有属性和方法
a._A__say()  # 这样,就可以调用私有方法了

结果:

{'_A__name': 'python'}
python
['_A__name', '_A__say', '__doc__', '__init__', '__module__']
python
TAG标签:
版权声明:本文由金沙澳门唯一官网发布于编程教学,转载请注明出处:上学笔记,类民用成员和保卫安全成员