编译期断言

书中列出三种编译期断言的实现方式,一一列出:
CompileTimeAssertion.h
//第一个版本使用不能建立空数组的性质
#define STATIC_CHECK1(expr) \
{\
    char unnamed[(expr) ? 1 : 0];\
}
 
 
//第二个版本使用模板的非类形参,使用为定义类是违法的
template<boolstruct CompileTimeError;//声明一个模板
template<> struct CompileTimeError<true>{};//仅仅对模板参数为true的特化实现
#define STATIC_CHECK2(expr) \
    (CompileTimeError<expr>())
 
 
//第三个版本,可以定制消息,但是这个消息必须是合法的c++标识符
template<boolstruct CompileTimeCheck
{
    CompileTimeCheck(...){}//加上后面的{}还可以通过链接,但是仅仅是针对编译,声明就够了
};
template<> struct CompileTimeCheck<false>{};
#define STATIC_CHECK3(expr, msg) \
{\
    struct ERROR_##msg{} unnameError;\
    CompileTimeCheck<expr> unnameCheck(unnameError);\
}
CompileTimeAssertion.cpp

#include <iostream>
#include "CompileTimeAssertion.h"
int main()
{
    /*****************版本1****************/
    {
        STATIC_CHECK1(true);
        //.\CompileTimeAssertion.cpp(5) : error C2466: 不能分配常量大小为 0 的数组
        
//.\CompileTimeAssertion.cpp(5) : error C2133: “unnamed”: 未知的大小
        
//STATIC_CHECK(false);
    }
    /*****************版本2****************/
    {
        STATIC_CHECK2(true);
        //error C2514: “CompileTimeError<__formal>”: 类没有构造函数
        
//STATIC_CHECK2(false);
    }
    /*****************版本3****************/
    {
        STATIC_CHECK3(1 < 3, CompareTwoNumber);
        // error C2440: “初始化”: 无法从“main::ERROR_CompareTwoNumber”转换为“CompileTimeCheck<false>”
        
//无构造函数可以接受源类型,或构造函数重载决策不明确
        
//STATIC_CHECK3(3 < 1, CompareTwoNumber);
    }

原文地址:https://www.cnblogs.com/hbt19860104/p/2668188.html