本文主要是介绍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 >= 108000boost::asio::spawn(*context_, f, boost::asio::detached);
#elseboost::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的值,仍旧是可行的,只是会存在大量的库编译警告。
所以,这要求大家必须修改自己的代码,才可以消除编译警告,当然,强制屏蔽编译的警告输出也是可行的,但这可能带来不可预测的风险。
这篇关于boost::asio 库版本,C/C++代码编译兼容性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!