Python 高手编程系列六百三十六 :命名和使用

常量用来定义程序所依赖的一组值,例如默认配置文件名。
好的做法是将所有常量集中放在包中的一个文件内。举个例子,Django 采用的就是这
种方法。一个名为 settings.py 的模块提供所有常量,如下所示:

config.py

SQL_USER = ‘tarek’
SQL_PASSWORD = ‘secret’
SQL_URI = ‘postgres://%s:%s@localhost/db’ % (
SQL_USER, SQL_PASSWORD
)
MAX_THREADS = 4
另一种方法是使用可以被 ConfigParser 模块或类似 ZConfig(Zope 中用于描述其
配置文件的解析器)之类的高级工具解析的配置文件。但有些人认为,对于 Python 这种文
件能够像文本文件一样轻松编辑和修改的语言来说,使用另一种文件格式可能是过分之举。
对于表现得像标记的选项,通常的做法是将它们和布尔运算结合起来,就像 doctest
和 re 模块所做的那样。doctest 中的模式很简单,如下所示:
OPTIONS = {}
def register_option(name):
return OPTIONS.setdefault(name, 1 << len(OPTIONS))
def has_option(options, name):
return bool(options & name)

现在定义选项

BLUE = register_option(‘BLUE’)
RED = register_option(‘RED’)
WHITE = register_option(‘WHITE’)
你将会得到下列结果:

我们来尝试一下

SET = BLUE | RED
has_ option(SET, BLUE)
True
has
_option(SET, WHITE)
False
在创建这样一组新的常量时,应避免对它们使用共同的前缀,除非模块中有多组常量。
模块名称本身就是一个共同的前缀。另一种解决方法是使用内置 enum 模块的 Enum 类,
并且依赖于 set 集合类型而不是二进制运算符。不幸的是,Enum 类在面向旧 Python 版本
的代码中应用有限,因为 enum 模块由 Python 3.4 版提供。
公有和私有变量
对于可变的且可以通过导入自由访问的全局变量,如果它们需要被保护,那么应该使
用带一个下划线的小写字母。但这种变量不经常使用,因为如果它们需要被保护,模块通
常会提供 getter 和 setter 来处理。在这种情况下,一个前缀下划线可以将变量标记为包的私
有元素,如下所示:
_observers = []
def add_observer(observer):
_observers.append(observer)
def get_observers():
““确保_observers 不能被修改。””"
return tuple(_observers)
位于函数和方法中的变量遵循相同的规则,并且永远不会被标记为私有,因为它们对上下文来说是局部变量。
对于类或实例变量而言,只在将变量作为公有签名的一部分不会带来任何有用信息或
者冗余的情况下,才必须使用私有标记符(前缀下划线)。
换句话说,如果变量在方法内部使用,用来提供公有功能,并且只具有这个功能,那
么最好将其设为私有。
例如,支持 property 的属性是很好的私有成员,如下所示:
class Citizen(object):
def init(self):
self._message = ‘Rosebud…’
def _get_message(self):
return self._message
kane = property(_get_message)
另一个例子是用来记录内部状态的变量。这个值对其他代码没有用处,但却参与了类
的行为,如下所示:
class UnforgivingElephant(object):
def init(self, name):
self.name = name
self._people_to_stomp_on = []
def get_slapped_by(self, name):
self._people_to_stomp_on.append(name)
print(‘Ouch!’)
def revenge(self):
print(‘10 years later…’)
for person in self.people_to_stomp_on:
print(‘%s stomps on %s’ % (self.name, person))
下面是在交互式会话中的运行结果:
joe = UnforgivingElephant(‘Joe’)
joe.get
slapped by(‘Tarek’)
Ouch!
joe.get
slapped _by(‘Bill’)
Ouch!
joe.revenge()
10 years later…
Joe stomps on Tarek
Joe stomps on Bill

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值