python私有属性和property装饰器_Python的私有变量与装饰器@property的用法

Python的私有变量是在变量前面加上双横杠(例如:__test)来标识,

Python私有变量只能在类内部使用,不被外部调用,且当变量被标记为私有后,调用时需再变量的前端插入类名,在类名前添加一个下划线,即“_ClassName__变量名”形式。

Python私有变量或方法在自身类中不能直接调用,需通过在类中定义接口,实现私有变量的引用、读取和修改。

class Person(object):

def __init__(self, name, age):

self.__name=name

self.__age=age

def get_age_fun(self):returnself.__age

def set_age_fun(self, value):if not isinstance(value, int):

raise ValueError('年龄必须是数字!')if value < 0 or value > 100:

raise ValueError('年龄必须是0-100')

self.__age=value

def print_info(self):

print('%s: %s' %(self.__name, self.__age))

p= Person('balala',20)

p.__age= 17print(p.__age) #17print(p.get_age_fun()) #20 表面上看,上面代码“成功”地设置了__age变量 17,但实际上这个__age变量和class内部的__age变量不是一个变量!

# 内部的__age变量已经被Python解释器自动改成了_Person_age,而外部代码给p新增了一个__age变量。 所以调用 get_age_fun输出的是初始值

p.set_age_fun(35)

print(p.get_age_fun()) #35print(p.print_info()) # balala:35

稍微调整下:

(注意只改变了一个变量名: 原来的私有属性 __age 单下划线为: _age,也可以定义为:age.

解释:以一个下划线开头的实例变量名,比如_age,这样的实例变量外部是可以访问的,但是,按照约定俗成的规定,当看到这样的变量时,意思是,"虽然可以被访问,但是,请视为私有变量,不要随意访问。")

class Person(object):

def __init__(self, name, age):

self.__name=name

self._age=age

def get_age_fun(self):returnself._age

def set_age_fun(self, value):if not isinstance(value, int):

raise ValueError('年龄必须是数字!')if value < 0 or value > 100:

raise ValueError('年龄必须是0-100')

self._age=value

def print_info(self):

print('%s: %s' %(self.__name, self._age))

p= Person('balala',20)

p._age= 17print(p._age) #17print(p.get_age_fun()) # 这里是17 不再是20,因为此时_age是全局变量,外部直接影响到类内部的更新值

p.set_age_fun(35)

print(p.get_age_fun()) #35print(p.print_info()) # balala:35

看的出私有和全局的设置

但是,上面的调用方法是不是略显复杂,没有直接用属性这么直接简单。

有没有可以用类似属性这样简单的方式来访问类的变量呢?必须的,对于类的方法

我们先来看一个稍微改造的例子:(稍后我们再使用Python内置的@property装饰器就是负责把一个方法变成属性调用.)

我们进入正题:看看@property的妙用之处:

class Person(object):

def __init__(self, name, age):

self.__name=name

self.__age=age

@property

def get_age_fun(self):returnself.__age

@get_age_fun.setter # get_age_fun是上面声明的方法

def set_age_fun(self, value):if not isinstance(value, int):

raise ValueError('年龄必须是数字!')if value < 0 or value > 100:

raise ValueError('年龄必须是0-100')

self.__age=value

def print_info(self):

print('%s: %s' %(self.__name, self.__age))

p= Person('balala',20)

p.__age= 17print(p.__age) #17print(p.get_age_fun) #20注意这里不带()

#p.set_age_fun(35) 注意不能这样调用赋值了

p.set_age_fun= 35# 这里set_age_fun 就是 声明的函数不带()

print(p.get_age_fun) #35print(p.print_info()) # balala:35

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值