cnblogs Post date: 2013-01-11 00:05

看这段代码:

    void set(int* a, int* b);

    void setA(int a)
    {
            set(&a, 0);
    }
    void setB(int b)
    {
            set(0, &b);
    }

    int g_a = 0, g_b = 0;
    void set(int* a, int* b)
    {
            if (a) g_a = *a;
            if (b) g_b = *b;
    }

看看这段代码,乍一看没什么问题

仔细琢磨,能发现这个setA和setB函数有个问题:

如果编译器默认调用约定是fastcall类型的寄存器调用(如现在的ARM、PPC),那么可能会将入参存放在寄存器中,而对入参取地址则就算对寄存器取地址,这个行为很可能出问题

-- 目前程序在PPC上是没问题的

-- 如果真的没问题就不会思考这件事了:在某些情况下会概率性地失效,详细原因有待挖掘