Python重载问题


函数重载


python 不提供函数重载。 函数重载主要是为了解决两个问题。1、可变参数类型;2、可变参数个数。另外,一个基本的设计原则是,仅仅当两个函数除了参数类型和参数个数不同以外,其功能是完全相同的,此时才使用函数重载,如果两个函数的功能其实不同,那么不应当使用重载,而应当使用一个名字不同的函数。
那么对于情况1,函数功能相同,但是参数类型不同,python 如何处理?答案是根本不需要处理,因为 python 可以接受任何类型的参数,如果函数的功能相同,那么不同的参数类型在 python 中很可能是相同的代码,没有必要做成两个不同函数。
那么对于情况 2 ,函数功能相同,但参数个数不同,python通过缺省参数来实现。对那些缺少的参数设定为缺省参数即可解决问题。因为你假设函数功能相同,那么那些缺少的参数终归是需要用的。
举例说明,函数定义:
def f(str,times):
    print str*times
上面函数是指对字符串str打印times次,可能你很多情况只需对str打印,此时每次都对times赋值1就显得很繁琐,我们希望没有指定times的值就只打印一次。 在C++中你可以用函数重载这样实现:
void f(string str)
{
    cout << str << endl;
}
void f(string str,int times)
{
    int i=0;
    for (i =0;i
打印一次就调用f(str),打印多次就调用f(str,times)

用python实现:
def f(str,times=1):
    print str*times
打印一次就调用f(str),打印多次就调用f(str,times),调用方法一样。
从形式上先,与C++相比,代码省了很多,但功能是一样的。times=1表示参数没有指定时,默认情况下的值为1。

运算符重载


在 Python中,运算符重载的方式更为简单-每一个类都默认内置了所有可能的运算符方法,只要重写这个方法,就可以实现针对该运算符的重载。 例如以下是重载加法操作:
class Info(object):
    def __init__(self):
        self.a = 11
        self.b = 22
    def __add__(self,x):
        return self.a * self.b


a = Info()
b = Info()
print a + b

评论关闭