将int转换为long时会发生什么?
例如:
a = sys.maxint-1
a = a+2
在a = a 2的陈述中发生了什么?
Python解释器如何处理溢出?
最佳答案 让
read the source(我的机器上有python2.7.3):
这是添加的地方(据我所知):
static PyObject *
int_add(PyIntObject *v, PyIntObject *w)
{
register long a, b, x;
CONVERT_TO_LONG(v, a);
CONVERT_TO_LONG(w, b);
/* casts in the line below avoid undefined behaviour on overflow */
x = (long)((unsigned long)a + b);
if ((x^a) >= 0 || (x^b) >= 0)
return PyInt_FromLong(x);
return PyLong_Type.tp_as_number->nb_add((PyObject *)v, (PyObject *)w);
}
到目前为止,还不错 – 我们从CONVERT_TO_LONG宏中的python整数类型中获取C long类型.然后他们做了一个补充.注意他们如何通过强制转换各种long来获取一些有趣的技巧来检测溢出.*如果没有检测到溢出,它们将C long转换回python对象并返回它.如果有溢出,你可以看到他们再次尝试添加 – 这次,使用python long类型(PyLong_Type).
如果你看一下int_sub,你会发现它几乎是一回事(检测下溢的位技巧略有不同). int_mul似乎有点复杂,并带有一个很好的大块评论.实际上,代码中充满了关于它们如何处理不同情况下的溢出/下溢的注释.这是非常有用的信息.
>我现在有点太累了解决它,但如果你这样做,可以随意发表评论(或者只是编辑).