什么是 XCode 8 个环境变量到 运行 英特尔线程构建块
What are XCode 8 Environment Variables to run Intel Threading Building Blocks
我安装了英特尔线程构建模块。我无法为 XCode(lib 和包含路径)设置环境变量。
首先,我想编写一个简单的 parallel_for 程序,我什至无法在我的程序中添加命名空间 tbb
。
有人可以帮忙吗?
enter image description here
这很简单:安装它的最佳方法:
brew install tbb
需要 Homebrew,强烈建议 Mac 想要使用各种开源工具的用户。
调整3个项目设置
之后执行brew info tbb
查看安装目录,在我的例子中
/usr/local/Cellar/tbb/2017_U7
结果是
/usr/local/Cellar/tbb/2017_U7/include/
/usr/local/Cellar/tbb/2017_U7/lib/
对于各自的项目设置,Header Search Paths
和Library Search Paths
。
在 Other Linker Flags
中输入 -ltbb
就可以了。
测试代码示例
我已使用 Xcode 8.3
中的上述设置验证了此示例
#include "tbb/parallel_for.h"
#include "tbb/task_scheduler_init.h"
#include <iostream>
#include <vector>
struct mytask {
mytask(size_t n)
:_n(n)
{}
void operator()() {
for (int i=0;i<1000000;++i) {} // Deliberately run slow
std::cerr << "[" << _n << "]";
}
size_t _n;
};
int main(int,char**) {
//tbb::task_scheduler_init init; // Automatic number of threads
tbb::task_scheduler_init init(tbb::task_scheduler_init::default_num_threads()); // Explicit number of threads
std::vector<mytask> tasks;
for (int i=0;i<1000;++i)
tasks.push_back(mytask(i));
tbb::parallel_for(
tbb::blocked_range<size_t>(0,tasks.size()),
[&tasks](const tbb::blocked_range<size_t>& r) {
for (size_t i=r.begin();i<r.end();++i) tasks[i]();
}
);
std::cerr << std::endl;
return 0;
}
我安装了英特尔线程构建模块。我无法为 XCode(lib 和包含路径)设置环境变量。
首先,我想编写一个简单的 parallel_for 程序,我什至无法在我的程序中添加命名空间 tbb
。
有人可以帮忙吗?
enter image description here
这很简单:安装它的最佳方法:
brew install tbb
需要 Homebrew,强烈建议 Mac 想要使用各种开源工具的用户。
调整3个项目设置
之后执行brew info tbb
查看安装目录,在我的例子中
/usr/local/Cellar/tbb/2017_U7
结果是
/usr/local/Cellar/tbb/2017_U7/include/
/usr/local/Cellar/tbb/2017_U7/lib/
对于各自的项目设置,Header Search Paths
和Library Search Paths
。
在 Other Linker Flags
中输入 -ltbb
就可以了。
测试代码示例
我已使用 Xcode 8.3
中的上述设置验证了此示例#include "tbb/parallel_for.h"
#include "tbb/task_scheduler_init.h"
#include <iostream>
#include <vector>
struct mytask {
mytask(size_t n)
:_n(n)
{}
void operator()() {
for (int i=0;i<1000000;++i) {} // Deliberately run slow
std::cerr << "[" << _n << "]";
}
size_t _n;
};
int main(int,char**) {
//tbb::task_scheduler_init init; // Automatic number of threads
tbb::task_scheduler_init init(tbb::task_scheduler_init::default_num_threads()); // Explicit number of threads
std::vector<mytask> tasks;
for (int i=0;i<1000;++i)
tasks.push_back(mytask(i));
tbb::parallel_for(
tbb::blocked_range<size_t>(0,tasks.size()),
[&tasks](const tbb::blocked_range<size_t>& r) {
for (size_t i=r.begin();i<r.end();++i) tasks[i]();
}
);
std::cerr << std::endl;
return 0;
}