前言
跟着廖雪峰老师自己动手敲一敲,把忘了的、漏了的重学一下。别去看什么几小时学完***的视频课,自己动动手比什么都快。
一、类和实例
- 类是创建实例的模板,而实例则是一个一个具体的对象,各个实例拥有的数据都互相独立,互不影响。
- 方法就是与实例绑定的函数,和普通函数不同,方法可以直接访问实例的数据。
- 通过在实例上调用方法,我们就直接操作了对象内部的数据,但无需知道方法内部的实现细节。
- 和静态语言不同,Python允许对实例变量绑定任何数据,也就是说,对于两个实例变量,虽然它们都是同一个类的不同实例,但拥有的变量名称都可能不同。
class Student(object):#类是创建实例的模板
def __init__(self, name, score):#方法函数:属性强制绑定,实例变量self 指代创建的实例本身(无需传入)
self.name = name
self.score = score
def print_score(self): #只需要在实例变量上直接调用
print('%s: %s' % (self.name, self.score))
def get_grade(self):
if self.score >= 90:
return 'A'
elif self.score >= 60:
return 'B'
else:
return 'C'
lisa = Student('Lisa', 99)
bart = Student('Bart', 59)
lisa.print_score()
bart.print_score()
print(lisa.name, lisa.get_grade())#可以直接在实例变量上调用,不需要知道内部实现细节
print(bart.name, bart.get_grade())
bart.age = 88#Python允许对实例变量绑定任何数据
print(bart.age )
运行结果:
Lisa: 99
Bart: 59
Lisa A
Bart C
88
二、访问限制
1.正确做法
代码如下(示例):
class Student(object):
def __init__(self, name, score, age):
self.name = name
self.score = score
self.__age = age#变量前加双下划线访问限制,只有内部可以访问,外部不能访问,代码更加健壮
#可以对参数做检查,避免传入无效的参数(大费周章的原因)
def get_age(self):
return self.__age#如果外部想访问被限制的实例变量,增加此函数
def set_age(self, age):
self.__age = age#如果外部想修改被限制的实例变量,增加此函数
bart = Student('Bart Simpson', 59,17)
bart.score = 99#外部代码可以自由地修改一个实例的属性
print(bart.score,bart.get_age())
bart.age=bart.set_age(18)#但若是有访问限制,只能调用修改函数
print(bart.get_age())#然后再通过get函数获取改变后的值
运行结果:
99 17
18
2.一些补充
-
以单下划线开头的变量名
这样的实例变量外部是可以访问的,但是,按照约定俗成的规定,当你看到这样的变量时,意思就是,“虽然我可以被访问,但是,请把我视为私有变量,不要随意访问”。 -
以双下划线开头,并且以双下划线结尾的变量名
是特殊变量,特殊变量是可以直接访问的,不是private变量,不要随便定义成这样的形式。 -
不要试图用在外部以改变后的类型:
_Classname__variablename
访问以双下划线开头的变量(虽然能过编译但会出问题)
- 不能在外部对私有变量不通过set函数直接改值,因为变量被限制访问后其名称已经改变,在外部操作并不能影响私有变量,反而是增加了一个新的变量。有点绕口,举个栗子:
class Student(object):
def __init__(self, name, score, age):
self.name = name
self.score = score
self.__age = age
def get_age(self):
return self.__age
bart = Student('Bart Simpson', 59,17)
bart.__age=20
print(bart.__age,bart.get_age())
运行结果:
20 17
懂了吧!
三、小练习
class Student(object):
def __init__(self, name, gender):
self.name = name
self.__gender = gender
def get_gender(self):
return self.__gender
def set_gender(self,gender):
self.__gender=gender
bart = Student('Bart', 'male')
if bart.get_gender() != 'male':
print('测试失败!')
else:
bart.set_gender('female')
if bart.get_gender() != 'female':
print('测试失败!')
else:
print('测试成功!')
运行结果:
测试成功!