数据封装

    面向对象编程的一个重要特点就是数据封装。在上面的 Student 类中,每个实例就拥有各自的 name score 这些数据。我们可以通过函数来访问这些数据,比如打印一个学生的成绩:

    >>> def print_score(std):

    … print('%s: %s' % (std.name, std.score))



    >>> print_score(bart)

    Bart Simpson: 59

    但是,既然 Student 实例本身就拥有这些数据,要访问这些数据,就没有必要从外面的函数去访问,可以直接在 Student 类的内部定义访问数据的函数,这样,就把“数据”给封装起来了。这些封装数据的函数是和 Student 类本身是关联起来的,我们称之为类的方法:

    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))

    要定义一个方法,除了第一个参数是 self 外,其他和普通函数一样。要调用一个方法,只需要在实例变量上直接调用,除了 self 不用传递,其他参数正常传入:

    >>> bart.print_score()

    Bart Simpson: 59

    这样一来,我们从外部看 Student 类,就只需要知道,创建实例需要给出 name score ,而如何打印,都是在 Student 类的内部定义的,这些数据和逻辑被“封装”起来了,调用很容易,但却不用知道内部实现的细节。

    封装的另一个好处是可以给 Student 类增加新的方法,比如 get_grade

    class Student(object):





    def get_grade(self):

    if self.score >= 90:

    return 'A'

    elif self.score >= 60:

    return 'B'

    else:

    return 'C'

    同样的, get_grade 方法可以直接在实例变量上调用,不需要知道内部实现细节:

    >>> bart.get_grade()

    'C'