比如,单例模式一个简单实现:
class CSingleton
{
public:
static CSingleton* GetInstance()
{
static CSingleton *pInstance = new CSingleton();
return pInstance;
}
void PrintText()
{
std::cout << "Hello World!" << std::endl;
}
};
其关键部分的反汇编代码:
;省略代码
test byte ptr ??_B?1??GetInstance@CSingleton@@SAPAV1@XZ@51, al ; `CSingleton::GetInstance(void)'::`2'::`local static guard'{2}'
jnz short loc_401077
or ??_B?1??GetInstance@CSingleton@@SAPAV1@XZ@51, eax ; `CSingleton::GetInstance(void)'::`2'::`local static guard'{2}'
;省略代码
loc_401077:
mov eax, ?pInstance@?1??GetInstance@CSingleton@@SAPAV2@XZ@4PAV2@A ; CSingleton * `CSingleton::GetInstance(void)'::`2'::pInstance
mov ecx, [esp+10h+var_C]
mov large fs:0, ecx
pop ecx
add esp, 0Ch
ret
如果线程1执行到第5行,同时线程2执行到第2行,线程2的判断就会生效,直接跳到第7行执行,这时函数的返回值就会是NULL。