Python语言底层是用c语言写的,所以也叫做cpython,和java c++不同的是,它是动态解释性语言,运行时边解释边运行,而java和C++是静态语言,他们在运行前就全部编译成二进制可执行文件,且进行了简单的语法检查,所以,如果有语法错误,编译都过不去。
Python中变量的定义是不声明类型的,且一切变量均是对象,比如int类型其实也是一个int类,而java它们定义的时候已经告诉编译器变量的类型。
python 有一个众所周知得缺点,运行慢!
Python运行慢,为什么还要用它,因为容易上手,灵活简单,节省开发时间。且是开源的,跨平台,可移植等优点,另外还有丰富的第三方类库。
Python慢的原因:Gil 全局解释器锁和动态语言:边运行边编译。
其中GIL,就是python没办法实现真正得并发。比如多核cpu,python是没办法同一时间实现多个线程同时执行,因为有这个GIL解释器锁得存在,为什么要有这个解释器锁呢,原因就是当初python的变量都是引用的方式进行使用的,如果在同一时刻有两个线程同时去操作一个共享资源,这个变量的引用计数值初始是0,假如没有GIL的话,就是说可以同时进行,那么这两个线程同时都引用成功,此时更新引用数都是1,这个时候,如果第一个线程释放了这个变量的使用,那么变量的引用值就变成了0,python内部的垃圾回收机制会去把这个变量回收了,实际上还是有线程2在使用,那么这个时候线程2就会出错。所以为了解决这种数据安全的问题,python解释器就在解释器上上了一把大锁,不让同一时刻有两个进程同时执行。
所以对于多核的计算机,像Java c++都是可以实现真正的并发,但是python无法做到。所以就会慢。
虽然python没有真正的并发,但是还是有伪并发的,因为计算机的计算速度及其快,1秒相当于实际的2的9次方秒,所以假设有多个任务的情况下,python是可以通过轮询的办法实现并发,比如在1秒的时间内,有3个任务,开始的0.00001秒执行下A任务,接下来的0.00001秒执行B任务,接下来的0.00001秒执行C任务。重复这样,那么在一秒内就能够把这三个任务执行完,让用户感觉好像是同时执行了一样。实际上cpu的执行还是串行的。