我不认为我的问题与这个问题重复。
我尝试做的事情:
template<const char* szFunctionName>
class CReentranceLock
{
public:
CReentranceLock(){}
~CReentranceLock(){}
bool isLocked(){return s_bLock;}
void setLocked(bool b)
{
const bool Result=(bool)InterlockedCompareExchange(
(unsigned long *)&s_bLock, b, !b);
}
private:
static bool s_bLock;
};
template<const char* szFunctionName>
bool CReentranceLock<const char*szFunctionName>::s_bLock=false;
// error C2146: syntax error : missing ',' before identifier 'szFunctionName'
暗示所有 CReentranceLock 实例都有自己的静态,依赖于作为模板参数传递的函数名的 const char 地址。
可以这样使用:
void CMyObject::InAnyFunction()
{
const char* szFunctionName = __FUNCTION__;
CReentranceLock<szFunctionName> lock; // Edit: <- this doesn't work
if(lock.isLocked()) return;
lock.setLocked(true);
/// business code
lock.setLocked(false);
}
好吧,这只是理论……不幸的是,这在我尝试初始化静态的那一行在 Visual 2010 下无法编译。
error C2146: syntax error : missing ',' before identifier 'szFunctionName'
我在做什么或想错了什么?
PS:我并没有处理重入闻起来像一个糟糕的设计(在 MFC 中)的事实,我知道,我迷失在其中 ;-)
编辑:虽然下面的答案很好,并且定义编译......我在 CMyObject::InAnyFunction() 中使用 const char * 作为编译时可用的模板参数似乎是错误的。:-(