下载最新的TBB的库,我的是tbb30_20100822oss_src;
tar zxvf tbb30_20100822oss_src
进入解压缩目录下,执行make。
cd build
chmod +x *.sh
sh generate_tbbvars.sh
sh tbbvars.sh
cd linux_intel64_gcc_cc4.1.2_libc2.5_kernel2.6.18_release
cp *.so /usr/lib
cp *.so.2 /usr/lib
/sbin/ldconfig
回到解压缩目录下
cd include
cp *.* /usr/local/include
cd ../examples/pipeline/square
make
如果是下面的提示,则表示编译成功
g++ -O2 -DNDEBUG -o square square.cpp -ltbb
./square input.txt output.txt
serial run time = 0.32484
parallel run time = 0.167507
从它的例子我们看到执行时间并行的比串行的要缩短一半时间;但这个库
只是个C++库。tbb的特点:
提供C++模版库,用户不必关注线程,而专注任务本身。
抽象层仅需很少的接口代码,性能上毫不逊色。
灵活地适合不同的多核平台。
线程库的接口适合于跨平台的移植(Linux, Windows, Mac)
支持的C++编译器 – Microsoft, GNU and Intel