boost::asio 库版本,C/C++代码编译兼容性

1、boost::asio::spawn 开启有栈(stackful)协同程序,版本改进及限制

      >= boost_1_80 版本应采用以下方式。

                auto f = 
                    [self, this](const boost::asio::yield_context& y) noexcept {
                        bool success_ = do_handshake(y);
                        if (!success_) {
                            close();
                        }
                        else {
                            clear_timeout();
                        }
                    };

                // https://original.boost.org/doc/libs/1_80_0/doc/html/boost_asio/overview/composition/spawn.html
                // https://original.boost.org/doc/libs/1_79_0/doc/html/boost_asio/overview/composition/spawn.html
#if BOOST_VERSION >= 108000
                boost::asio::spawn(*context_, 
                    f, 
                    boost::asio::detached);
#else
                boost::asio::spawn(*context_, f);
#endif

     <= boost_1_85 版本可以采用缺省 “boost::asio::spawn(*context_, f);” 方式,而之上版本,代码不在兼容此方式。

     之上版本,人们必须显示得提供:boost::asio::detached,它是一个用于辅助 boost::asio 内部泛型模板元编程,在编译器期确定调用行为得。

2、boost::uuids::uuid 

            boost::uuids::uuid uuid;
#if BOOST_VERSION >= 108600
            *(Int128*)&uuid = ppp::net::Ipep::HostToNetworkOrder(guid);
#else
            *(Int128*)uuid.data = ppp::net::Ipep::HostToNetworkOrder(guid);
#endif

   <= boost_1_85 版本,可以直接设置 data 字段,它是一个占16个字节的数组,而在 boost_1_86 及以上版本,它是一个单独定义的数据结构,而不在是一个数组。

3、boost::asio >= 1_86_0 及以上版本,所有的 async_xxx、如:async_read、async_write 函数的事件回调函数,都不可以在返回值,否则编译警告。

     大家惯性,喜欢在 async_read 的回调函数之中,返回 BOOL/INT的值,仍旧是可行的,只是会存在大量的库编译警告。

     所以,这要求大家必须修改自己的代码,才可以消除编译警告,当然,强制屏蔽编译的警告输出也是可行的,但这可能带来不可预测的风险。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值