python 面向对象相对别的语言来说缺少两个功能:
1、python不具备重载,重载是指在同一个类中,使得方法有相同的名称,但是有不同的参数列表,但由于python函数具有强大的参数处理功能,因此这不是一个问题。
2、python不存在强制数据隐私的机制,不过若想创建属性(实例变量或方法)时在属性名前以两个下划线引导,python就会阻止无心的访问,因此可以认为是私有的。

如果一个方法是预定义的特殊方法,则应该在方法名前后加上双下划线,例如__sub__()和__add__()。

一、自定义类

1、方法一

class className:
    suite

2、方法二

class className(base_class):
    suite

二、属性与方法

import math

class Point(object):
    def __init__(self,x,y):
        self.x = x
        self.y = y
    def __eq__(self,other):
        return self.x == other.x and self.x == other.y
    def distance_from_origin(self):
        return math.hypot(self.x,self.y)
    def __str__(self):
        return '({0.x},{0.y})'.format(self)

a = Point(1,2)
b = Point(2,2)
b.distance_from_origin()
Point.distance_from_origin(b)
a == b
str(a)

可预定义的比较方法如下:

python 类中方法重载 python类的重载_python

默认情况下,自定义类的所有实例都是可哈希运算的,因此,可对其调用hash(),也可以将其作为字典的键,或存储在集合中。但是如果重新实现了__eq__(),实例就不再是可哈希运算的了。

为了避免不适当的比较,可以使用如下三种方法:

  • 使用断言
assert isintance(object,Class),'object is not in the Class'
  • 产生TypeError异常
if not isinstance(object,Class):
    raise TypeError('object is not in the Class')
  • 返回NotImplemented
if not isinstance(object,Class):
    return NotImplement-ented

如果返回了NotImplemented,Python就会尝试调用other.__eq__(self)来查看object是否支持与Class类的比较,如果也没有类似的方法,Python将放弃搜索,并产生TypeError异常。
内置的isinstance()函数以一个对象与一个类为参数,如果该对象属于该类(或类元组中的某个类),或属于给定类的基类,就返回True

使用super()

使用super()函数可以使用基类的方法

def __init__(self,x,y,radius):
    super().__init__(x,y)
    self.radius = radius

在使用super()时,可以不用写self参数。

使用特性进行属性存取控制

一些方法返回一个单独的值,从用户的角度讲,可以将方法可以当做数据属性使用。以下是一个实例

class Circle(object):
    def __init__(self,radius):
        self.radius = radius
    def area(self):
        return self.radius * 2
    area = property(area)

c = Circle(4)
c.area

或可写为

class Circle(object):
    def __init__(self,radius):
        self.radius = radius
    @property
    def area(self):
        return self.radius * 2


c = Circle(4)
c.area

提供了一种验证数据有效性的方法

class Circle(object):
    def __init__(self,x,y,radius):
        self.radius = radius
        self.x = x
        self.y = y
    def area(self):
        return self.radius * 2
    area = property(area)

    @property
    def radius(self):
        return self.__radius
    @radius.setter
    def radius(self,radius):
        assert radius > 0,"radius must be nonzero and non-negative"
        self.__radius = radius

c = Circle(1,-2,4)
c.area