BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Boost 1.61发布,带来了新的CPU/CPU计算、插件管理和其他程序库

| 作者 Sergio De Simone 关注 17 他的粉丝 ,译者 金灵杰 关注 5 他的粉丝 发布于 2016年6月15日. 估计阅读时间: 5 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。

在1.60版本发布的5个月后,Boost发布了1.61版本,增加了一些新程序库,同时更新了许多程序库。

Boost 1.61包括4个新程序库:

  • Compute,使用OpenCL为多核CPU和GPU运算平台提供C++接口。OpenCL是一个开放标准,它允许创建运行在异构运算设备(如CPU和GPU)上的应用程序。该程序库提供管理OpenCL对象的类,例如设备(device)、内核(kernel)和命令队列(command_queues),同时也提供了允许开发者处理计算设备、与计算设备传输数据、迭代和转换计算设备的函数。这使得我们可以将数据传输到默认计算设备上,对数据进行转换,最后复制回宿主机:
std::vector host_vector(10000);
// 定义宿主机内容向量
// 获取默认设备,并且设置上下文
compute::device device = compute::system::default_device();
compute::context context(device);
compute::command_queue queue(context, device);
// 在设备上创建向量
compute::vector device_vector(host_vector.size(), context);
// 将数据从宿主机传输到设备上
compute::copy(
    host_vector.begin(), host_vector.end(), device_vector.begin(), queue
);
// 就地计算每个元素的平方根
compute::transform(
    device_vector.begin(),
    device_vector.end(),
    device_vector.begin(),
    compute::sqrt(),
    queue
);
// 将数据复制回宿主机
compute::copy(
    device_vector.begin(), device_vector.end(), host_vector.begin(), queue
);
  • DLL,一个旨在开发跨平台、可移植插件的程序库。DLL允许开发者加载其他程序库、导入本地函数和变量、查询程序库的段和符号表等。DLL插件可以通过extern “C”和BOOST_SYMBOL_EXPORT定义。客户端应用程序可以通过执行DLL插件的import函数加载动态链接库:
// 持有指向插件变量指针的变量
boost::shared_ptr plugin;
plugin = dll::import(
    full_path_to_library,
    name_of_symbol_to_import,
    dll::load_mode::append_decorations
);

DLL也支持动态链接库的引用计数,以更好的控制已加载插件的生命周期、在插件卸载时执行回调函数和其他一些功能。

  • Hana,一个元编程库,它能够提供操作异构序列的高级算法。对比现有元编程库,例如Boost.MPLBoost.Fusion,Hana统一了类型和值的操作。Hana提供了一系列容器类型,例如元组(tuple)、含无效值容器(optional)、映射(map)等,还有操作这些容器的算法集合,例如折叠(fold)、压缩(zip)、扁平化(flatten)等。
  • Metaparse,一个用于生成解析器的程序库,它能够在编译时解析文本或代码,并且可以返回一个类型、一个常量和一个运行时调用的C++函数等。Metaparse特别倾向用于创建一种嵌入式领域特定语言。Metaparse允许使用类似EBNF范式的语法定义上下文无关语法。它和另一个著名的元编程库Boost.Spirit的主要区别是后者产生运行时解析器,而Metaparse产生编译时解析器。

前文提到过,Boost 1.61也更新了许多现有程序库,包括Multiprecision(多倍精度数值库)、Optional(含无效值容器库)、Geometry(几何库)、Fusion(容器库)等等。

查看英文原文:Boost 1.61 Brings New Libraries for CPU/CPU Computation, Plugin Management, and More


感谢张龙对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ@丁晓昀),微信(微信号:InfoQChina)关注我们。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT