Python深入学习之特殊方法与多范式


Posted in Python onAugust 31, 2014

Python一切皆对象,但同时,Python还是一个多范式语言(multi-paradigm),你不仅可以使用面向对象的方式来编写程序,还可以用面向过程的方式来编写相同功能的程序(还有函数式、声明式等,我们暂不深入)。Python的多范式依赖于Python对象中的特殊方法(special method)。

特殊方法名的前后各有两个下划线。特殊方法又被成为魔法方法(magic method),定义了许多Python语法和表达方式,正如我们在下面的例子中将要看到的。当对象中定义了特殊方法的时候,Python也会对它们有“特殊优待”。比如定义了__init__()方法的类,会在创建对象的时候自动执行__init__()方法中的操作。

(可以通过dir()来查看对象所拥有的特殊方法,比如dir(1))

运算符

Python的运算符是通过调用对象的特殊方法实现的。比如:

'abc' + 'xyz'               # 连接字符串

实际执行了如下操作:
'abc'.__add__('xyz')

所以,在Python中,两个对象是否能进行加法运算,首先就要看相应的对象是否有__add__()方法。一旦相应的对象有__add__()方法,即使这个对象从数学上不可加,我们都可以用加法的形式,来表达obj.__add__()所定义的操作。在Python中,运算符起到简化书写的功能,但它依靠特殊方法实现。

Python不强制用户使用面向对象的编程方法。用户可以选择自己喜欢的使用方式(比如选择使用+符号,还是使用更加面向对象的__add__()方法)。特殊方法写起来总是要更费事一点。

尝试下面的操作,看看效果,再想想它的对应运算符

(1.8).__mul__(2.0)
True.__or__(False)

内置函数

与运算符类似,许多内置函数也都是调用对象的特殊方法。比如

len([1,2,3])      # 返回表中元素的总数

实际上做的是
[1,2,3].__len__()

相对与__len__(),内置函数len()也起到了简化书写的作用。

尝试下面的操作,想一下它的对应内置函数

(-1).__abs__()
(2.3).__int__()

表(list)元素引用

下面是我们常见的表元素引用方式

li = [1, 2, 3, 4, 5, 6]

print(li[3])

上面的程序运行到li[3]的时候,Python发现并理解[]符号,然后调用__getitem__()方法。
li = [1, 2, 3, 4, 5, 6]

print(li.__getitem__(3))

尝试看下面的操作,想想它的对应
li.__setitem__(3, 0)
{'a':1, 'b':2}.__delitem__('a')

函数

我们已经说过,在Python中,函数也是一种对象。实际上,任何一个有__call__()特殊方法的对象都被当作是函数。比如下面的例子:

class SampleMore(object):

    def __call__(self, a):

        return a + 5
add = SampleMore()     # A function object

print(add(2))          # Call function    

map(add, [2, 4, 5])    # Pass around function object

add为SampleMore类的一个对象,当被调用时,add执行加5的操作。add还可以作为函数对象,被传递给map()函数。

当然,我们还可以使用更“优美”的方式,想想是什么。

总结

对于内置的对象来说(比如整数、表、字符串等),它们所需要的特殊方法都已经在Python中准备好了。而用户自己定义的对象也可以通过增加特殊方法,来实现自定义的语法。特殊方法比较靠近Python的底层,许多Python功能的实现都要依赖于特殊方法。我们将在以后看到更多的例子。

Python的许多语法都是基于其面向对象模型的封装。对象模型是Python的骨架,是功能完备、火力强大的大黄蜂。但是Python也提供更加简洁的语法,让你使用不同的编程形态,从而在必要时隐藏一些面向对象的接口。正如我们看到的Camaro跑车,将自己威风的火药库收起来,提供方便人类使用的车门和座椅。

Python 相关文章推荐
跟老齐学Python之集合的关系
Sep 24 Python
使用Python编写一个在Linux下实现截图分享的脚本的教程
Apr 24 Python
Python批量重命名同一文件夹下文件的方法
May 25 Python
Python正则抓取新闻标题和链接的方法示例
Apr 24 Python
python 垃圾收集机制的实例详解
Aug 20 Python
python+selenium实现163邮箱自动登陆的方法
Dec 31 Python
基于循环神经网络(RNN)实现影评情感分类
Mar 26 Python
对python3 urllib包与http包的使用详解
May 10 Python
Python批量删除只保留最近几天table的代码实例
Apr 01 Python
Python转换时间的图文方法
Jul 01 Python
python字符串替换re.sub()方法解析
Sep 18 Python
python pip如何手动安装二进制包
Sep 30 Python
python中的reduce内建函数使用方法指南
Aug 31 #Python
Python中使用ConfigParser解析ini配置文件实例
Aug 30 #Python
python进阶教程之动态类型详解
Aug 30 #Python
python进阶教程之异常处理
Aug 30 #Python
python进阶教程之函数对象(函数也是对象)
Aug 30 #Python
python进阶教程之循环对象
Aug 30 #Python
python进阶教程之循环相关函数range、enumerate、zip
Aug 30 #Python
You might like
使用JSON实现数据的跨域传输的php代码
2011/12/20 PHP
php输出文字乱码的解决方法
2019/10/04 PHP
Jquery升级新版本后选择器的语法问题
2010/06/02 Javascript
js操作textarea方法集合封装(兼容IE,firefox)
2011/02/22 Javascript
在javascript中关于节点内容加强
2013/04/11 Javascript
浅析JavaScript中的delete运算符
2013/11/30 Javascript
Seajs的学习笔记
2014/03/04 Javascript
node.js Web应用框架Express入门指南
2014/05/28 Javascript
jQuery实现Tab菜单滚动切换的方法
2015/09/21 Javascript
AngularJS 实现购物车全选反选功能
2017/10/24 Javascript
微信小程序页面缩放式侧滑效果的实现代码
2018/11/15 Javascript
Angular7创建项目、组件、服务以及服务的使用
2019/02/19 Javascript
Vue匿名插槽与作用域插槽的合并和覆盖行为
2019/04/22 Javascript
layui监听select变化,以及设置radio选中的方法
2019/09/24 Javascript
js实现坦克移动小游戏
2019/10/28 Javascript
vscode中Vue别名路径提示的实现
2020/07/31 Javascript
JavaScript常用8种数组去重代码实例
2020/09/09 Javascript
[05:22]DOTA2 2015国际邀请赛中国区预选赛首日TOP10
2015/05/26 DOTA
Python 判断是否为质数或素数的实例
2017/10/30 Python
pytorch 数据集图片显示方法
2018/07/26 Python
Python 单元测试(unittest)的使用小结
2018/11/14 Python
django自带调试服务器的使用详解
2019/08/29 Python
巴西葡萄酒销售网站:Wine.com.br
2017/11/07 全球购物
BSTN意大利:德国街头和运动文化高品质商店
2020/12/22 全球购物
EJB发布WEB服务一般步骤
2012/10/31 面试题
幼师自荐信范文
2013/10/06 职场文书
软件工程专业推荐信
2013/10/28 职场文书
三爱活动实施方案
2014/03/19 职场文书
员工年终自我评价
2014/09/14 职场文书
学生保证书格式
2015/02/27 职场文书
2015年秋季小学开学典礼主持词
2015/07/16 职场文书
Nginx + consul + upsync 完成动态负载均衡的方法详解
2021/03/31 Servers
JS数组方法some、every和find的使用详情
2021/10/05 Javascript
mysql幻读详解实例以及解决办法
2022/06/16 MySQL
Ubuntu安装Mysql+启用远程连接的完整过程
2022/06/21 Servers
Flink 侧流输出源码示例解析
2022/09/23 Servers