1
neoblackcap 2018-05-31 15:36:05 +08:00 1
颗粒度不一样,因为如果去掉 GIL 相当于现在的 Python 里面的每一个操作都是不安全的,哪怕你是一个简单的加法运算,因为加法运行也可能变动引用计数。天知道这里面有多少依赖 CPython 实现的。
还有就是 GvR 要求去掉 GIL 不能减慢单线程性能,要兼容性就必须上细颗粒锁,锁多了性能肯定会下降,这才是为什么 CPython 的 GIL 不好去掉的缘故 |
2
sy52676 OP @neoblackcap 好像明白一些,但是你讲的好高深。。。
|
4
HelloAmadeus 2018-05-31 22:51:32 +08:00 via Android
简单说吧,引用计数不去掉,估计 gil 锁就去不掉
|
5
qoras 2018-05-31 23:51:07 +08:00
保证使用基础结构时不用加锁, 如 dict
|
6
neoblackcap 2018-06-01 00:10:29 +08:00
@qoras 不可能,因为 CPython 里面所有的对象都对应底层 C 语言级别 PyObject 结构体,每个对象都有一个引用计数,不用 GIL 没法保证引用计数的变动线程安全。
如果改动的话,Java 就是一个很好的例子,大锁改成细颗粒锁,外加 concurrent 包,同时啊,引用计数应该改成 tracing GC。引用计数在现在的技术下不比 tracing gc 优秀 |
7
xxxy 2018-06-01 12:00:48 +08:00
|