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