列举Python中吸引人的一些特性

这里我不讨论 python 的一些有用的库或者框架,只从语言本身,最小支持的情况下谈论这门语言本身。语言的发展都是越来越接近Lisp,这也是Lisp这门语言伟大的原因。

下面我罗列一下我学习 python 的原因:
多编程范式

python是一门多范式的编程语言,所谓的过程式,面向对象和函数式的结合。

大部分人接触编程语言都是从过程式开始的,原因是因为过程式的程序方式与计算机运行方式是统一的,指令序列与运行过程是统一的。如典型的C,我也是从C开始学习的,过程式的程序语言设计编写程序较为简单,但是符合人机交互思考方式。

python虽然是一门面向对象语言,就连“ ”(空格)也可以看做是一个对象,但是python胜任过程式是没有问题的。

如不需要使用类的静态方法:

 def a_plus_b(a,b):
   return a+b

1. Duck typing

Python在设计的时候将其当做一门面向对象的方式编写,且不说面向对象给软件设计带来的一些革命等,在python这样的动态语言中面向对象有一个亮点就是Duck typing(鸭子类型)。

关于鸭子类型,就是说,如果我认为一个抽象的东西会游泳会“嘎嘎”叫,我就可以把它当做鸭子。

 def use_duck( Duck ):
   Duck.swim()
   Duck.gaga()
 class Duck:
   def swim(self):
     ...
   def gaga(self):
     ...

如果这样使用:
 little_duck = Duck()
 use_duck( little_duck )

关于Duck类,你可以给他取任何的名字,或者继承它取另一个名字,只需要实现 swim() gaga() 你就可以把它当做鸭子。

关于鸭子类型,很多人不理解为什么不需要提供一个接口来规定鸭子的行为,我既不支持也不反对,我的观点是这样的:

  • 对于参数的检查,不符合动态语言的特性
  • 提供了接口规范,那就不是鸭子类型了,直接叫多态得了

2. Python支持的函数式编程

首先是lambda 演算。

函数式编程的定义是将函数看做是变量一样的待遇,变量在程序中最简单的有什么待遇呢?

  • 可以赋值
  • 可以作为参数
  • 可以改变值(Erlang例外)
  • 且不说生命周期了和作用域了

λ演算背后蕴含着计算机可计算性的深厚知识,lambda也是图灵模型,是停机问题的一个否定答案,不仅仅是一个匿名函数那样简单。

关于 lambda 演算,看看这个程序做了什么:

 map(lambda n:2*n,[1,2,3,4,5])

lambda n:2*n 本身作为一个匿名函数
    lambda 本身作为一个参数传入 map()函数,这也就是说我的高阶函数,可以将函数变身看成是一个变量作为参数传递,这也是它作为函数受到的高等待遇

关于赋值和改变值,两种方式:

f = fun() 不改变函数状态,只改变名称,但是说明函数是可以赋值的
    可以使用闭包作为改变函数的状态方式,或者使用装饰器来完成函数状态改变

函数式编程的使用也可以提高程序的可读性和减少代码,而且能够清晰的表达函数的功能,如MapReduce就是来自函数式编程的思想:

 Map(func,List)

作用是将func 作用于List中的每一个元素。

以刚才的例子举例:

 map(lambda n:2*n,[1,2,3,4,5])

此函数返回

 [2,4,6,8,10]

重要的是在于知道这样的方式带给我们的清晰的设计方式。

当然函数式编程不是那么几句话就说完的,理解函数式编程的核心是理解 λ演算。
一些有意思的特性

1. 惰性计算:

看看完成一个斐波那契数列 python 可以怎么做:

 >>> def fib():
   a , b = 0 ,1
   while 1:
     yield b
     a , b = b ,a+b

 >>> f = fib()

实际上由yield 生成了一个可迭代对象,每次调用f.next()就可以产生一个斐波那契值,而函数的内部状态是由迭代对象存储的。至于返回一个可迭代对象,如果需要确定迭代到多少位,可以使用 itertools.islice。

2. 协程

协程也是一个基于yield的概念,主要的模式是微线程的协作式工作模式:

 def coroutine(func):
   def ret():
     f = func()
     f.next()
     return f
   return ret

 @coroutine
 def consumer():
   print "Wait to getting a task"
   while 1:
     n = (yield)
     print "Got %s",n

 import time
 def producer():
   c = consumer()
   while 1:
     time.sleep(1)
     print "Send a task to consumer"
     c.send("task")

 if __name__ == "__main__":
 producer()

协程带来的好处是可以直接调度你的线程,这也是它为什么叫做协程而不是线程的原因,线程属于抢占式并发,协程属于协作式并发。
动态语言带来的好处

从程序设计带来的快感(我相信只有热爱这方面的人才有的感觉)来说,动态语言,比如python,节约了更多的时间可以用来陪女朋友或者老婆,或者老公。

当然,作为互联网时代快速开发来说,赶鸭子上线,也是《黑客与画家》上面介绍的,快速开发很重要,当然需要符合这方面的需求。

动态语言的CPU密集型运算必然比不过C/C++。

总之:人生苦短,我用python。

(0)

相关推荐

  • Python中的zip函数使用示例

    zip函数接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表.具体意思不好用文字来表述,直接看示例: 1.示例1: 复制代码 代码如下: x = [1, 2, 3] y = [4, 5, 6] z = [7, 8, 9] xyz = zip(x, y, z) print xyz 运行的结果是: [(1, 4, 7), (2, 5, 8), (3, 6, 9)] 从这个结果可以看出zip函数的基本运作方式. 2.示例2: 复制代码 代码如下: x = [1, 2, 3] y = [

  • Python写的服务监控程序实例

    前言: Redhat下安装Python2.7 rhel6.4自带的是2.6, 发现有的机器是python2.4. 到python网站下载源代码,解压到Redhat上,然后运行下面的命令: 复制代码 代码如下: # ./configure --prefix=/usr/local/python27 # make # make install 这样安装之后默认不会启用Python2.7,需要使用/usr/local/python27/bin/python2.7调用新版本的python. 而下面的安装方

  • 用python 制作图片转pdf工具

    最近因为想要看漫画,无奈下载的漫画是jpg的格式,网上的转换器还没一个好用的,于是乎就打算用python自己DIY一下: 这里主要用了reportlab.开始打算随便写几行,结果为若干坑纠结了挺久,于是乎就想想干脆把代码写好点吧. 实现了以下的几项功能: 将当前文件夹下的图片保存到一个pdf中,支持选择pdf大小等 如果有需要可以遍历它下面的所有文件夹 简单的来说完全满足我将漫画转成pdf格式的需求了. 碰到了一些问题,这里记录下: 一.中文路径: 这个实在是略蛋疼,总之就是尽量都decode一

  • 列举Python中吸引人的一些特性

    这里我不讨论 python 的一些有用的库或者框架,只从语言本身,最小支持的情况下谈论这门语言本身.语言的发展都是越来越接近Lisp,这也是Lisp这门语言伟大的原因. 下面我罗列一下我学习 python 的原因: 多编程范式 python是一门多范式的编程语言,所谓的过程式,面向对象和函数式的结合. 大部分人接触编程语言都是从过程式开始的,原因是因为过程式的程序方式与计算机运行方式是统一的,指令序列与运行过程是统一的.如典型的C,我也是从C开始学习的,过程式的程序语言设计编写程序较为简单,但是

  • 举例介绍Python中的25个隐藏特性

    注:这里忽略了生成器,装饰器,交换变量等熟知技巧 1. 函数参数unpack 老生常谈的了: def foo(x, y): print x, y alist = [1, 2] adict = {'x': 1, 'y': 2} foo(*alist) # 1, 2 foo(**adict) # 1, 2 2. 链式比较操作符 >>> x = 3 >>> 1 < x < 5 True >>> 4 > x >=3 True 3. 注意

  • 详解Python中元组的三个不常用特性

    目录 1. 引言 2. 举个栗子 3. 创建包含单一元素的元组 4. 使用下划线和*来unpack元组 5. 使用命名元组 6. 总结 1. 引言 元组是Python中一种重要的内置数据类型.与列表一样,我们经常使用元组将多个对象保存为相应的数据容器.然而,与列表不同的是元组的不变性——一个不可改变的数据序列. 2. 举个栗子 下面的代码片段向我们展示了元组的一些常见用法. response = (404, "Can't access website") response_code =

  • 复习Python中的字符串知识点

    字符串 在 Python 中创建字符串对象非常容易.只要将所需的文本放入一对引号中,就完成了一个新字符串的创建(参见清单 1).如果稍加思考的话,您可能会感到有些困惑.毕竟,有两类可以使用的引号:单引号 (') 和双引号 (").幸运的是,Python 再一次使这种问题迎刃而解.您可以使用任意一类引号来表示 Python 中的字符串,只要引号一致就行.如果字符串是以单引号开始,那么必须以单引号结束,反之亦然.如果不遵循这一规则,则会出现 SyntaxError 异常. 清单 1. 在 Pytho

  • 一起来看看五条Python中的隐含特性

    目录 1. 引言 2. 函数属性 3. For-else循环 4. int型分隔符 5. eval() and exec() 6. 省略号 6.1 占位符 6.2 numpy数组中用于切片 7.总结 1. 引言 最近闲暇之余,我会去阅读一些Python文档,有时候会注意到一些有趣的Python特性,这些特性不禁让人惊呼:“哇,Python原来还可以这么写”. 闲话少说,我们直接开始吧. :) 2. 函数属性 和设置类和对象的属性类似,我们在Python中也可以为函数设置属性.样例代码如下: de

  • 详解Python中的动态属性和特性

    导语:本文章记录了本人在学习Python基础之元编程篇的重点知识及个人心得,打算入门Python的朋友们可以来一起学习并交流. 一.利用动态属性处理JSON数据源 属性:在Python中,数据的属性和处理数据的方法统称属性. 元编程:用元类进行编程,元类→类→对象,元类比类更抽象,生成类的类. 1.使用动态属性访问JSON类数据 第一版:利用json.load(fp)审查数据 from urllib.request import urlopen import warnings import os

  • python中的property及属性与特性之间的优先权

    目录 前言 属性(attribute) 属性的定义 属性的用法 特性(property) 特性的定义 特性的用法 特性的使用场景 属性和特性之间的差别和联系 属性和特性之间的优先权 前言 这几天看<流畅的python>这本书了,在一个示例中又看到了property作为装饰器在使用,因为很久没有用这个东西了,对它的一些特性和使用方法等都不是很熟悉,所以又专门在搜了几篇博客和在官方文档中学习了它的相关用法.再者又刚好学到了python中的属性(attribute),所以刚好这两者可以两相对比,也许

  • Python 中如何使用 virtualenv 管理虚拟环境

    1. 什么是虚拟环境? 虚拟环境的意义,就如同 虚拟机 一样,它可以实现不同环境中Python依赖包相互独立,互不干扰. 举个例子吧. 假设我们的电脑里有两个项目,他们都用到同一个第三方包,本来一切都顺利.但是由于某种原因,项目B由于某些原因要使用这个第三方包的一些新特性(新版本才有),而如果就这样贸然升级了,对项目A的影响我们无法评估,这个时候我们就特别需要有一种解决方案可以让项目A和B,处于两个不同的Python环境中.互不影响. 为了方便大家对虚拟环境有个认识,我列举了下其优点: 使不同应

  • 详解Python中迭代器和生成器的原理与使用

    目录 1.可迭代对象.迭代器 1.1概念简介 1.2可迭代对象 1.3迭代器 1.4区分可迭代对象和迭代器 1.5可迭代对象和迭代器的关系 1.6可迭代对象和迭代器的工作机制 1.7自己动手创建可迭代对象和迭代器 1.8迭代器的优势 1.9迭代器的缺点和误区 1.10python自带的迭代器工具itertools 2.生成器 2.1生成器的创建方法 2.2生成器方法 2.3生成器的优势 2.4生成器应用场景 3.生成器节省内存.迭代器不节省内存 3.1可迭代对象 3.2迭代器 3.3生成器 3.

  • Python中的枚举函数enumerate()的具体用法

    相比于range,list等简易单词,enumerate仅凭外形都不太让人愿意用.事实上,enumerate还是很好用的. enumerate()是python的内置函数.适用于python2.x和python3.x enumerate在字典上是枚举.列举的意思 enumerate参数为可遍历/可迭代的对象(如列表.字符串) enumerate多用于在for循环中得到计数,利用它可以同时获得索引和值,即需要index和value值的时候可以使用enumerate enumerate()返回的是一

随机推荐