boost::assert学习笔记

本文介绍了Boost库中的断言宏BOOST_ASSERT及其使用方法。在默认情况下,该宏等同于标准C++库中的assert宏,但在定义了BOOST_ENABLE_ASSERT_HANDLER之后,其行为会发生变化,在debug和release模式下都会进行检查,并调用boost::assertion_failed函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

P213

要点

头文件

 #include <boost/assert.hpp>  


  1. 默认情况下BOOST_ASSERT宏等同于assert宏,断言表达式为真,即:
    #define BOOST_ASSERT(expr) assert(expr)。如果参数expr表达式值为true,那么断言成立,程序会继续向下执行,否则断言会引发一个异常。
  2. BOOST_ASSERT宏仅会在debug模式下生效。

  3. 扩展用法 P215

如果在头文件<boost/assert.hpp>之前定义了宏BOOST_ENABLE_ASSERT_HANDLE,这将导致BOOST_ASSERT的行为发生改变:
它将不再等同于assert宏,断言的表达式在debug、release模式下都会被求值。如果断言失败,会发生一个断言失败的函数调用boost::assertion_failed()。

  • BOOST_VERIFY P216
  • static_assert->BOOST_STATIC_ASSERT
    下面的代码定义了一个简单的模板函数my_min,出于某种目的,它仅支持short或者char的类型:
  • #include <boost/static_assert.hpp>
    template<typename T>
    T my_min(T a,T b)
    {
        BOOST_STATIC_ASSERT(sizeof(T) < sizeof(int)); //静态断言
        return a<b?a:b;
    }
    
    int main()
    {
        cout << my_min((short)1,(short)3); //OK
        cout << my_min(1L,3L); //编译期错误
    }   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值