python 内建比较函数详解
http://blog.sina.com.cn/s/blog_5357c0af01011392.html
我們經(jīng)常需要比較兩個對象,使用自定義的函數(shù)是個方法,但不直觀
故而我們常常使用比較運算符來直接比較對象,此時我們需要對比較運算符進行自定義(重載)。
如果不重載,那么,對于自定義的對象將會比較對象的地址。
python中,我們可以通過對內(nèi)建的比較函數(shù)進行自定義,來實現(xiàn)運算符重載。
我們常用的比較運算符有
大于 > 對應(yīng)的內(nèi)建比較函數(shù)為 __gt__()
大于等于 >= 對應(yīng)的內(nèi)建比較函數(shù)為 __ge__()
等于 == 對應(yīng)的內(nèi)建比較函數(shù)為 __eq__()
小于 < 對應(yīng)的內(nèi)建比較函數(shù)為 __lt__()
小于等于 <= 對應(yīng)的內(nèi)建比較函數(shù)為 __le__()
以下是個范例:
class p(object):
????def __init__(self,x,y):
????????print 'init one p instance'
????????self.x=x
????????self.y=y
????def __cmp__(self,other):
????????return 1
????def __eq__(self,other):
????????return 'eq'
????def __lt__(self,other):
????????return 'lt'
????def __gt__(self,other):
????????return 'gt'
a=p(1,2)
b=p(3,4)
print 'a==b:',a==b
print 'a<b:',a<b
print 'a>b:',a>b
print cmp(a,b)
不過,其中有些需要說明的地方,按理說,我們使用對應(yīng)的比較運算符就應(yīng)該只調(diào)用對應(yīng)的函數(shù),但是,當我們只自定義了部分比較運算符時,實際上可能出現(xiàn)偏差:
當只定義了eq,使用=,只會調(diào)用相應(yīng)eq,<= >= 不會調(diào)用eq
當只定義了lt,使用<,>都會調(diào)用lt,其他正常
當只定義了le,使用<=,>=都會調(diào)用le,其他正常
當只定義了gt,效果同lt,當只定義了ge,效果同le
如果如果同時定義了lt,gt,則使用<,>時各自調(diào)用,其他正常,同理適用 le,ge
為什么會這樣?我不知道,但顯然這讓我們得到一個結(jié)論:相對的比較運算符必須對稱存在,就是如果你自定義了lt你就必須自定義gt,如果自定義了le,就必須自定義ge,這就是答案!
還有一個特別的比較函數(shù),他沒有對應(yīng)的運算符,這就是 __cmp__(),我們可以直接使用cmp(x,y)來使用此內(nèi)置函數(shù)。此函數(shù)的作用是
如果 x<y 則 返回 -1
如果 x>y 則 返回 1
如果 x==y 則 返回0
那么,我們要問了,x,y是自定義對象時,如何比較呢?
如果我們沒有自定義這個函數(shù)和其他比較函數(shù)的話,默認比較對象x,y的地址
如果我們自定義了比較函數(shù)的話,將返回0
如果我們自定義了__cmp__()比較函數(shù)的話,則得到函數(shù)返回值
但是對于
class tt(object):
def __init__(self,a,b):
self.a = a
self.b = b
這樣的類,就不用自定義__cmp__函數(shù),解析器自己會正確解析
總結(jié)
以上是生活随笔為你收集整理的python 内建比较函数详解的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python线程指南
- 下一篇: Python函数式编程指南