Python解释器如何将int转换为long?

将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似乎有点复杂,并带有一个很好的大块评论.实际上,代码中充满了关于它们如何处理不同情况下的溢出/下溢的注释.这是非常有用的信息.

>我现在有点太累了解决它,但如果你这样做,可以随意发表评论(或者只是编辑).

点赞