python3(二十三)classInstance

""" 类和实例和访问权限 """
__author__ = 'shaozhiqi'


# class后面紧接着是类名,即Student,类名通常是大写开头的单词,
# 紧接着是(object),表示该类是从哪个类继承下来的
class Student(object):
    pass


bart = Student()  # 变量bart指向的就是一个Student的实例
bart.name = 'Bart Simpson'
print(bart.name)  # Bart Simpson  --可以自由地给一个实例变量绑定属性,即使类里没有定义这个属性


# 通过定义一个特殊的__init__方法,在创建实例的时候,就把我们任务必须的属性绑上去,如下:
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))


# __init__方法的第一个参数永远是self,表示创建的实例本身,因此,在__init__方法内部,就可以把各种属性绑定到self,因为self就指向创建的实例本身。
# 有了__init__方法,在创建实例的时候,就不能传入空的参数了,必须传入与__init__方法匹配的参数,但self不需要传,Python解释器自己会把实例变量传进去:
bart = Student('Bart Simpson ', 30)
print('name: ', bart.name)  # name:  Bart Simpson  可以看出name是public的

# 调用实例方法
bart.print_score()  # Bart Simpson : 30


# ----------------------------限制访问----------------------
class Student2(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 set_name(self, name):
        self.__name = name


bart2 = Student2('Bart Simpson2 ', 30)
# print('name: ', bart2.__name)  # 访问异常 'Student2' object has no attribute '__name'
print('name: ', bart2.get_name())  # name:  Bart Simpson2
bart2.set_name('shao')
print('name: ', bart2.get_name())  # name:  shao

# 1.双下划线开头双下划线结尾
# 在Python中,变量名类似__xxx__的,也就是以双下划线开头,并且以双下划线结尾的,
# 是特殊变量,特殊变量是可以直接访问的,不是private变量,所以,不能用__name__、__score__这样的变量名。
# 2.单下划线开头的变量
# _name,这样的实例变量外部是可以访问的,但是,按照约定俗成的规定,当你看到这样的变量时,
# 意思就是,“虽然我可以被访问,但是,请把我视为私有变量,不要随意访问”。
# 3.只以双下划线开头
# 不能直接访问__name是因为Python解释器对外把__name变量改成了_Student__name,所以,
# 仍然可以通过_Student__name来访问__name
bart2.__name = 'New Name'  # 设置__name变量!
print(bart2.__name)  # New Name
# 面上看,外部代码“成功”地设置了__name变量,但实际上这个__name变量和class内部的__name变量不是一个变量!
# 内部的__name变量已经被Python解释器自动改成了_Student__name,而外部代码给bart新增了一个__name变量
# 下面调用可以验证上面的结论
print(bart2.get_name())  # shao

 

posted @ 2019-09-19 16:09  ~清风煮酒~  阅读(296)  评论(0编辑  收藏  举报