函数
1.判断所有指针中是否有空指针的函数
有的时候我们需要判断大量指针中是否有空指针,此模板函数只要参数中有一个空指针就会返回true
template<typename T1, typename ...Tn>
bool havNullPtr(T1* p1, Tn *...pn)
{
return p1 == NULL || ((pn == NULL) || ...);
};
2.为一个IUnknow类型的派生类型增加和减少引用
在COM模型编程中经常使用IUnknow类型,下面两个函数可以安全的增加引用和减少引用
template< typename T, typename ty = typename std::enable_if<std::is_convertible<T*, IUnknown*>::value>::type>
static ULONG Release(T*& pIUnknown)
{
ULONG result = -1;
if (nullptr == pIUnknown)
{
return result;
}
else
{
result = pIUnknown->Release();
pIUnknown = nullptr;
return result;
}
}
template< typename T, typename ty = typename std::enable_if<std::is_convertible<T*, IUnknown*>::value>::type>
static ULONG AddRef(T*& pIUnknown)
{
ULONG result = -1;
if (nullptr == pIUnknown)
{
return result;
}
else
{
result = pIUnknown->AddRef();
return result;
}
}
3.释放所有指针内存并且置空
template<typename T1, typename ...Tn>
void DeletAll(T1*& p1, Tn *&...pn)
{
delete p1;
p1 = nullptr;
((delete pn), ...);
(( pn = nullptr), ...);
};
类
1. 带有错误码的返回值模板
我们总是希望能够知道函数是否正确执行,通常要返回错误码的函数使用指针或者引用作为参数以返回值,这样不够优雅,而且返回值往往只在出现错误时关注,大部分时间并不关注错误码 1.此模板包含返回值和返回结果代码HRESULT,并提供自动类型转换为返回值,自动类型转换使用完美转发,仅能被自动转换一次,之后的读取是不确定的 2.警告:此模板的构造函数也会使输入的值失效,如果不希望失效可以传入拷贝,尽量在return语句使用此类型
template<typename T>
class ResultVal
{
public:
void operator=( ResultVal<T>& other)
{
this->m_Hresult = other.m_Hresult;
this->m_Val = std::move(other.m_Val);
}
ResultVal(ResultVal<T>& other)
{
this->m_Hresult = other.m_Hresult;
this->m_Val = std::move(other.m_Val);
}
operator T()
{
return std::move(m_Val);
}
ResultVal(T& Val, HRESULT hr = S_OK)
{
m_Val = std::move(Val);
m_Hresult = hr;
}
ResultVal(T&& Val, HRESULT hr = S_OK)
{
m_Val = std::move(Val);
m_Hresult = hr;
}
ResultVal(const T& Val, HRESULT hr = S_OK)
{
m_Val = Val;
m_Hresult = hr;
}
HRESULT m_Hresult;
T m_Val;
};
宏
1.如果成立便返回
虽然非常不推荐使用宏,但是函数中if后接return实在太影响体验了 如下宏在x成立时函数返回y或使void返回值的函数结束(不会写重载的宏)
#define IfTrueReturnVal(x, y) { if(x) return (y);};
#define IfTrueReturn(x) { if(x) return;};
最后的
小伙伴需要什么语法糖可以在评论提,尽力完成
|