0
template <class T, class FPTR = void (void *)> 
class CSmartPtr
{
public :
// -----------------------------------------------------------------------
//  Constructors and Destructor
// -----------------------------------------------------------------------
CSmartPtr()
{
    m_TData = NULL;
    m_deleter = NULL;
}

CSmartPtr(T* TData)
{
    m_TData = TData;
    m_deleter = NULL;
}

CSmartPtr(T* TData, FPTR *deleter)
{
    m_TData = TData;
    m_deleter = deleter;
}

~CSmartPtr()
{
    if (NULL == m_deleter)
    {
        delete m_TData;
    }
    else
    {
        m_deleter(m_TData);
    }
}

T *const operator-> () const
{
    return m_TData;
}

//-----------------------------------------------------------------------
// Getter methods
//-----------------------------------------------------------------------
T *const get() const
{
    return m_TData;
}

void reset(T* TData)
{
    if (NULL != m_TData)
    {
        if (NULL == m_deleter)
        {
            delete m_TData;
        }
        else
        {
            m_deleter(m_TData);
        }
    }

    m_TData = TData;
}

private :

// -----------------------------------------------------------------------
//  Private data members
//
//  fUnicodeForm
//      This is the Unicode XMLCh format of the string.
// -----------------------------------------------------------------------
T *m_TData;
FPTR *m_deleter;
};

int main( void )
{
CSmartPtr<BYTE> apbySrcBuff;      // This doesnt work.
    CSmartPtr<BYTE, (void) (void *)> apbySrcBuff;      // This works.
getchar();
return TRUE;
}

我完全是新手templates,而且我从几个小时开始就被上述问题困扰。试图自己解决它,但没有成功。

错误是Error 1 error C2064: term does not evaluate to a function taking 1 arguments 该行是 m_deleter(m_TData);

4

2 回答 2

0

我已经在 ideone对其进行了测试,并且运行良好(它以运行时错误终止,但那是你的 smart_ptr 实现,我没有调试过)。

我发现的唯一问题是第二个声明使用了额外的括号,(void)(void*)并且在这里编译失败(我对第一个声明没有任何问题)。

于 2013-08-23T12:28:35.410 回答
0

您需要在代码顶部添加以下内容:

#include <cstdio>

typedef char BYTE;
bool TRUE = true;

并在注释掉您相同的一个之后:

CSmartPtr apbySrcBuff;

行,它全部编译。

于 2013-08-23T11:25:02.287 回答