摘要:正常的函数和变量名为此类型,可以被直接引用。不应该被直接引用,只有内部可以访问,外部不能访问。不能随意修改对象内部的状态,这样通过访问限制的保护,代码更加健壮。不能直接访问是因为解释器对外把变量改成了,所以仍然可以通过来访问变量。
在一个模块中,我们可能会定义很多函数和变量。但有的函数和变量我们希望能给别人使用,有的函数和变量我们希望仅仅在模块内部使用,so?
我们可以通过定义该函数、变量是公开的还是私有的来达到该目的。
在Python中,是通过下划线“_”前缀来实现的。
public:公开的。正常的函数和变量名为此类型,可以被直接引用。比如变量abc、PI等;
特殊变量:格式为__xxx__ ,以__开头、以__结尾。可以直接被引用,但是有特殊用途。比如 __author__ 、__name__就是特殊变量。一般自己定义的变量不要用这种变量名。
private:私有的、非公开的,格式类似于_xxx_ 和__xxx,例如__num。
不应该被直接引用,只有内部可以访问,外部不能访问。
不能随意修改对象内部的状态,这样通过访问限制的保护,代码更加健壮。
在Class类内部,可以有属性和方法。而外部代码可以通过直接调用实例变量的方法来操作数据,隐藏了内部复杂逻辑。但是,外部代码还是可以自由地修改一个实例的属性。例如:
>>>b.score 99 >>>b.score = 59 >>>b.score 59
如果要让内部属性不被外部访问,可以把属性的名称前加上两个下划线“__”,变成私有变量,如下:
class Student(object): def __init__(self, name, score): self.__name = name self.__score = score def print_score(self): print("%s: %s" % (self.__name, self.__score))
尝试在外部对属性进行访问,发现会报错,因为私有变量,不能被外部访问。
>>> bart = Student("Bart Simpson", 98) >>> bart.__name # 私有变量:不能被外部访问 Traceback (most recent call last): File "", line 1, in AttributeError: "Student" object has no attribute "__name"
但是,如果外部代码要获取name和score怎么办?
给Student类增加获取属性的方法:get_name()和get_score(),如下:
class Student(object): ... def get_name(self): return self.__name def get_score(self): return self.__score
如果外部代码修改score怎么办?可以再给Student类增加设置方法:set_score():
... def set_score(self, score): # 避免传入无效参数 if 0 <= score <= 100: self.__score = score else: raise ValueError("bad score")
那作为双下划线开头的私有实例变量是不是一定不能从外部访问呢?其实也不是。
不能直接访问__name是因为Python解释器对外把__name变量改成了_Student__name,所以仍然可以通过_Student__name来访问__name变量。
>>> bart = Student("Bart Simpson", 98) >>> bart.get_name() "Bart Simpson" >>> bart.__name = "New Name" # 给bart新增的__name变量 >>> bart.__name # !与class内部的__name变量不是一个变量! "New Name" >>> bart.get_name() # get_name()内部返回self.__name (_Student__name) "Bart Simpson"
表面上看,外部代码“成功”地设置了__name变量,但实际上这个__name变量和class内部的__name变量不是一个变量!内部的__name变量已经被Python解释器自动改成了_Student__name,而外部代码给bart新增了一个__name变量。
所以python并没有一种方法可以完全限制访问private的函数或变量,所以不是“不能被直接引用”,从编程的习惯上不应该引用private函数或变量。那他们的用处呢?
例如:
def _private_1 (name): return "hello,%s " % name def _private_2 (name): return "hi , %s " % name def greeting(name): if len(name) > 3: return _private_1 (name) else: return _private_2 (name)
在模块里公开greeting()函数,而把内部逻辑用private函数隐藏起来了。这样,调用greeting()函数不用关心内部的私有函数的细节。
这是一种非常有用的代码封装和抽象的方法,即:外部不需要引用的函数全部定义成private,只有外部需要引用的函数才定义为public。
class Student(object): def __init__(self, name, score): self.__name = name self.__score = score def print_score(self): print("%s: %s" % (self.__name, self.__score)) def get_name(self): return self.__name def get_score(self): return self.__score def set_score(self, score): # 避免传入无效参数 if 0 <= score <= 100: self.__score = score else: raise ValueError("bad score") def _private_1 (name): return "hello,%s " % name def _private_2 (name): return "hi , %s " % name def greeting(name): if len(name) > 3: return _private_1 (name) else: return _private_2 (name)
❤ thanks for watching, keep on updating...
点个赞再走吧
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/44810.html
摘要:继承继承,就是子类继承父亲的特征和行为,使得子类具有父类的成员变量和方法。此时,被继承的类称为父类或基类,而继承的类称为子类或派生类。,如果存在继承关系的时候,和就不一样了基类中的成员可以在派生类中使用,但是基类中的成员不能再派生类中使用。 ...
摘要:比如我们可以设置这就代表我们设置的规则对百度爬虫是有效的。上一篇文章网络爬虫实战使用解析链接下一篇文章网络爬虫实战基本使用 上一篇文章:Python3网络爬虫实战---22、使用Urllib:解析链接下一篇文章:Python3网络爬虫实战---24、requests:基本使用 利用 Urllib 的 robotparser 模块我们可以实现网站 Robots 协议的分析,本节我们来简...
摘要:并发线程测试循环新建线程类,并在线程体内塞入单个的测试用例,以及全局的计数类。为了让性能测试更充分,我编写了不同的计算过程,并使用随机函数随机获取并塞入线程执行。 ...
摘要:函数和可用于检查条件并在条件不满足时抛出异常。函数只能用于测试内部错误,并检查非变量。函数和状态变量仅在当前定义它们的合约中使用,并且不能被派生合约使用。派生合约可以访问所有非私有成员,包括内部函数和状态变量,但无法通过来外部访问。 Solidity是以太坊的主要编程语言,它是一种静态类型的 JavaScript-esque 语言,是面向合约的、为实现智能合约而创建的高级编程语言,设计...
摘要:我们使用测试同学的网站时,就会出现网站无法访问,等错误。所以我们需要加上访问时间限制,防止一个多次访问请求,导致整个网站崩溃。 我们使用Jmeter测试同学的网站时...
阅读 2771·2023-04-25 23:08
阅读 1561·2021-11-23 09:51
阅读 1539·2021-10-27 14:18
阅读 3099·2019-08-29 13:25
阅读 2799·2019-08-29 13:14
阅读 2856·2019-08-26 18:36
阅读 2180·2019-08-26 12:11
阅读 781·2019-08-26 11:29