boost诊断工具BOOST_ASSERT、BOOST_VERIFY、BOOST_STATIC_ASSERT

本文详细介绍了Boost.Assert宏的功能和使用方式,包括BOOST_ASSERT和BOOST_VERIFY宏的区别,以及如何使用BOOST_STATIC_ASSERT进行编译期断言检查。

boost.assert提供的主要工具是BOOST_ASSERT宏,类似于C语言的assert,提供运行时的断言,但功能有所增强;
默认情况下,BOOST_ASSERT宏等同于assert宏: # define BOOST_ASSERT(expr) assert(expr);
BOOST_ASSERT宏仅会在Debug模式下起作用,在Release模式下不会被编译,不会影响运行效率;
BOOST_ASSERT宏是标准断言宏assert的增强版本,使用更加灵活;
定义BOOST_DISABLE_ASSERTS宏可禁止BOOST_ASSERT作用,但assert宏不会受影响;
定义BOOST_ENABLE_ASSERT_HANDLER宏将导致BOOST_ASSERT的行为发生改变;

BOOST_VERIFY宏是assert库提供的另一种工具,断言表达式一定会被求值,其余与BOOST_ASSERT行为相同。

assert与BOOST_ASSERT是运行时断言,但有时候运行时已经很晚了,程序已经发生了无可挽回的错误;
static_assert库能够把断言诊断的时刻由运行时提前到编译期,增加程序的健壮性;
BOOST_STATIC_ASSERT是一个编译期断言,使用typedef和模板元技术实现;
BOOST_STATIC_ASSERT可以出现在程序的任何位置:命名空间中、类中、函数中.

 C++ Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
 
/*
    boost.assert提供的主要工具是BOOST_ASSERT宏,类似于C语言的assert,提供运行时的断言,但功能有所增强;
    默认情况下,BOOST_ASSERT宏等同于assert宏: # define BOOST_ASSERT(expr) assert(expr);
    BOOST_ASSERT宏仅会在Debug模式下起作用,在Release模式下不会被编译,不会影响运行效率;
    BOOST_ASSERT宏是标准断言宏assert的增强版本,使用更加灵活;
    定义BOOST_DISABLE_ASSERTS宏可禁止BOOST_ASSERT作用,但assert宏不会受影响;
    定义BOOST_ENABLE_ASSERT_HANDLER宏将导致BOOST_ASSERT的行为发生改变;
    
    BOOST_VERIFY宏是assert库提供的另一种工具,断言表达式一定会被求值,其余与BOOST_ASSERT行为相同。

    assert与BOOST_ASSERT是运行时断言,但有时候运行时已经很晚了,程序已经发生了无可挽回的错误;
    static_assert库能够把断言诊断的时刻由运行时提前到编译期,增加程序的健壮性;
    BOOST_STATIC_ASSERT是一个编译期断言,使用typedef和模板元技术实现;
    BOOST_STATIC_ASSERT可以出现在程序的任何位置:命名空间中、类中、函数中.
*/



/************************************************************************/
/* C++ stl Library                                                        */
/************************************************************************/
#include  <iostream>
#include  <string>

/************************************************************************/
/* C++ boost Library                                                   */
/************************************************************************/
#define  BOOST_DISABLE_ASSERTS                //禁用BOOST_ASSERT
#define  BOOST_ENABLE_ASSERT_HANDLER          //为BOOST_ASSERT添加handler
#include  <boost/assert.hpp>
#include  <boost/format.hpp>
#include  <boost/static_assert.hpp>
#include  <cassert>
using   namespace  std;

namespace  boost
{
    
void  assertion_failed( char   const  * expr,  char   const  * function,  char   const  * file,  long  line)
    {
        boost::format fmt(
"Assertion Failed!\nExpression: %s\nFunction: %s\nFile: %s\nLine: %ld\n\n" );
        fmt % expr% function% file% line;
        cout << fmt;
    }
}

template < typename  T>
void  print(T &tok)
{
    
for (BOOST_AUTO(pos, tok.begin()); pos != tok.end(); pos++)
    {
        cout << 
"["  << *pos <<  "]"  ;
    }
    cout << endl;
}

double  func( int  x)
{
    BOOST_ASSERT(x != 
0  &&  "divided by zero!" );
    
return   1 . 0 /x;
}

int  main( void )
{
    BOOST_ASSERT(
16  == 0x10);
    
//assert(16 == 0x11);
     //BOOST_ASSERT(string().size() == 1);
     //func(0);

    
int  nLen =  0 ;
    string str(
"Michael Joessy!" );
    BOOST_VERIFY(nLen = str.length());
    cout << 
"length of str is "  << nLen << endl;

    BOOST_STATIC_ASSERT(
2  ==  sizeof ( short ));
    
//BOOST_STATIC_ASSERT(3 == sizeof(short));

    cin.get();
    
return   0 ;
}

 

转载于:https://www.cnblogs.com/MakeView660/p/7126916.html

在 C 语言和 C++ 中,`_Static_assert` 和 `static_assert` 都用于实现静态断言(即在编译阶段进行条件检查),但它们在语法、使用方式以及标准支持上存在一些差异。 ### 语法和关键字形式 - 在 C 语言中,从 C11 标准开始引入了 `_Static_assert` 关键字,用于进行静态断言。其语法形式为: ```c _Static_assert(constant-expression, string-literal); ``` 这里 `constant-expression` 是一个常量表达式,如果其值为假(0),则触发编译错误;`string-literal` 是一个字符串字面量,用于提供错误信息[^2]。 - 在 C++ 中,从 C++11 标准开始引入了 `static_assert` 关键字。其语法形式为: ```cpp static_assert(constant-expression, string-literal); ``` 从 C++17 开始,`static_assert` 的语法允许省略错误消息参数,即可以仅提供条件表达式而不提供消息: ```cpp static_assert(constant-expression); ``` 这种形式在 C 语言的 `_Static_assert` 中并不存在[^3]。 ### 标准支持 - `_Static_assert` 是 C11 标准中定义的特性,因此它仅适用于 C 语言环境。在 C 语言中,静态断言只能在编译时检查常量表达式是否为真,并且必须提供错误消息字符串[^2]。 - `static_assert` 是 C++11 标准中引入的特性,并在 C++17 中得到了扩展。它不仅支持在编译时检查常量表达式,还支持更灵活的语法形式(如省略错误消息)[^3]。 ### 使用场景 - 在 C 语言中,`_Static_assert` 常用于检查类型大小、常量值等编译期间可确定的条件。例如,验证 `CHAR_BIT` 是否为 8: ```c #include <limits.h> _Static_assert(CHAR_BIT == 8, "Char size must be 8 bits."); ``` 这有助于确保代码在特定平台上的正确性[^2]。 - 在 C++ 中,`static_assert` 除了可以用于类似的用途外,还广泛应用于模板元编程中。它可以用于验证模板参数是否满足特定条件,从而在编译时捕获潜在的错误。例如: ```cpp template <class T> struct Check { static_assert(sizeof(int) <= sizeof(T), "T is not big enough!"); }; ``` 这种用法在 C++ 模板编程中非常常见,因为它能够在编译时进行更复杂的类型检查[^4]。 ### 错误信息处理 - 在 C 语言中,`_Static_assert` 必须提供一个字符串字面量作为错误信息,否则会导致编译错误。这意味着开发者必须明确提供错误信息,以帮助调试。 - 在 C++ 中,`static_assert` 从 C++17 开始允许省略错误信息参数。这种灵活性使得开发者可以在某些情况下简化代码,尤其是在调试或快速原型开发时。 ### 示例对比 - **C 语言中的 `_Static_assert`**: ```c #include <stdio.h> #include <limits.h> _Static_assert(CHAR_BIT == 8, "Char size must be 8 bits."); int main() { printf("CHAR_BIT is %d\n", CHAR_BIT); return 0; } ``` 如果 `CHAR_BIT` 不等于 8,则编译时会触发错误,并显示指定的错误信息。 - **C++ 中的 `static_assert`**: ```cpp #include <iostream> template <class T> struct Check { static_assert(sizeof(int) <= sizeof(T), "T is not big enough!"); }; int main() { Check<int> c1; // 编译通过 Check<char> c2; // 编译失败,因为 sizeof(int) > sizeof(char) return 0; } ``` 在这个例子中,`static_assert` 会在编译时检查模板参数 `T` 的大小是否足够大,否则触发编译错误。 ### 总结 - `_Static_assert` 和 `static_assert` 都是用于编译时断言的工具,但它们分别属于 C 和 C++ 的标准。 - `_Static_assert` 在 C 语言中必须提供错误消息,而 `static_assert` 在 C++17 中可以省略。 - `static_assert` 在 C++ 中的应用更为广泛,特别是在模板元编程中,能够提供更强的类型检查能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值