[size=small]首先下载:

http://www.threadingbuildingblocks.org/uploads/77/111/2.1/tbb21_20080605oss_win.zip

当前是2.1版本

解压到c盘,打开vs2005,设置vc++的项目目录

include:

C:\tbb21oss_win\include

执行文件:

C:\tbb21oss_win\ia32\vc8\bin

库文件:

C:\tbb21oss_win\ia32\vc8\lib

最后设置 我的电脑--环境变量设置

添加下面到path部分的最前面,记得加上一个“;”:C:\tbb21oss_win\ia32\vc8\bin

然后添加一个变量:

TBB21_INSTALL_DIR 为C:\tbb21oss_win

开启vs2005的命令行工具,进入到C:\tbb21oss_win\ia32\vc8\bin路径,执行tbbvars.bat文件

可以开始第一个程序了,记得带上tbb.lib对应的是release编译模式

/* 
    Copyright 2005-2008 Intel Corporation.  All Rights Reserved.

This file is part of Threading Building Blocks.

Threading Building Blocks is free software; you can redistribute it 
    and/or modify it under the terms of the GNU General Public License 
    version 2 as published by the Free Software Foundation.

Threading Building Blocks is distributed in the hope that it will be 
    useful, but WITHOUT ANY WARRANTY; without even the implied warranty 
    of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
    GNU General Public License for more details.

You should have received a copy of the GNU General Public License 
    along with Threading Building Blocks; if not, write to the Free Software 
    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

As a special exception, you may use this file as part of a free software 
    library without restriction.  Specifically, if other files instantiate 
    templates or use macros or inline functions from this file, or you compile 
    this file and link it with other files to produce an executable, this 
    file does not by itself cause the resulting executable to be covered by 
    the GNU General Public License.  This exception does not however 
    invalidate any other reasons why the executable file might be covered by 
    the GNU General Public License. 
*/

// 
// Example program that reads a file of text and changes the first letter 
// of each word to upper case. 
//  
#include "tbb/pipeline.h" 
#include "tbb/tick_count.h" 
#include "tbb/task_scheduler_init.h" 
#include <cstring> 
#include <cstdlib> 
#include <cstdio> 
#include <cctype>

using namespace std;

//! Buffer that holds block of characters and last character of previous buffer. 
class MyBuffer { 
    static const size_t buffer_size = 10000; 
    char* my_end; 
    //! storage[0] holds the last character of the previous buffer. 
    char storage[1+buffer_size]; 
public: 
    //! Pointer to first character in the buffer 
    char* begin() {return storage+1;} 
    const char* begin() const {return storage+1;} 
    //! Pointer to one past last character in the buffer 
    char* end() const {return my_end;} 
    //! Set end of buffer. 
    void set_end( char* new_ptr ) {my_end=new_ptr;} 
    //! Number of bytes a buffer can hold 
    size_t max_size() const {return buffer_size;} 
    //! Number of bytes appended to buffer. 
    size_t size() const {return my_end-begin();} 
};

class MyInputFilter: public tbb::filter { 
public: 
    static const size_t n_buffer = 8; 
    MyInputFilter( FILE* input_file_ ); 
private: 
    FILE* input_file; 
    size_t next_buffer; 
    char last_char_of_previous_buffer; 
    MyBuffer buffer[n_buffer]; 
    /*override*/ void* operator()(void*); 
};

MyInputFilter::MyInputFilter( FILE* input_file_ ) :  
    filter(/*is_serial=*/true), 
    next_buffer(0), 
    input_file(input_file_), 
    last_char_of_previous_buffer(' ') 
{  
}

void* MyInputFilter::operator()(void*) { 
    MyBuffer& b = buffer[next_buffer]; 
    next_buffer = (next_buffer+1) % n_buffer; 
    size_t n = fread( b.begin(), 1, b.max_size(), input_file ); 
    if( !n ) { 
        // end of file 
        return NULL; 
    } else { 
        b.begin()[-1] = last_char_of_previous_buffer; 
        last_char_of_previous_buffer = b.begin()[n-1]; 
        b.set_end( b.begin()+n ); 
        return &b; 
    } 
}

//! Filter that changes the first letter of each word from lower case to upper case. 
class MyTransformFilter: public tbb::filter { 
public: 
    MyTransformFilter(); 
    /*override*/void* operator()( void* item ); 
};

MyTransformFilter::MyTransformFilter() :  
    tbb::filter(/*ordered=*/false)  
{}

/*override*/void* MyTransformFilter::operator()( void* item ) { 
    MyBuffer& b = *static_cast<MyBuffer*>(item); 
    int prev_char_is_space = b.begin()[-1]==' '; 
    for( char* s=b.begin(); s!=b.end(); ++s ) { 
        if( prev_char_is_space && islower((unsigned char)*s) ) 
            *s = toupper(*s); 
        prev_char_is_space = isspace((unsigned char)*s); 
    } 
    return &b;   

          
//! Filter that writes each buffer to a file. 
class MyOutputFilter: public tbb::filter { 
    FILE* my_output_file; 
public: 
    MyOutputFilter( FILE* output_file ); 
    /*override*/void* operator()( void* item ); 
};

MyOutputFilter::MyOutputFilter( FILE* output_file ) :  
    tbb::filter(/*is_serial=*/true), 
    my_output_file(output_file) 

}

void* MyOutputFilter::operator()( void* item ) { 
    MyBuffer& b = *static_cast<MyBuffer*>(item); 
    fwrite( b.begin(), 1, b.size(), my_output_file ); 
    return NULL; 
}

static int NThread = tbb::task_scheduler_init::automatic; 
static const char* InputFileName = "input.txt"; 
static const char* OutputFileName = "output.txt"; 
static bool is_number_of_threads_set = false;

void Usage() 

    fprintf( stderr, "Usage:\ttext_filter [input-file [output-file [nthread]]]\n"); 
}

int ParseCommandLine(  int argc, char* argv[] ) { 
    // Parse command line 
    if( argc> 4 ){ 
        Usage(); 
        return 0; 
    } 
    if( argc>=2 ) InputFileName = argv[1]; 
    if( argc>=3 ) OutputFileName = argv[2]; 
    if( argc>=4 ) { 
        NThread = strtol(argv[3],0,0); 
        if( NThread<1 ) { 
            fprintf(stderr,"nthread set to %d, but must be at least 1\n",NThread); 
            return 0; 
        } 
        is_number_of_threads_set = true; //Number of threads is set explicitly 
    } 
    return 1; 
}

int run_pipeline( int nthreads ) 

    FILE* input_file = fopen(InputFileName,"r"); 
    if( !input_file ) { 
        perror( InputFileName ); 
        Usage(); 
        return 0; 
    } 
    FILE* output_file = fopen(OutputFileName,"w"); 
    if( !output_file ) { 
        perror( OutputFileName ); 
        return 0; 
    }

// Create the pipeline 
    tbb::pipeline pipeline;

// Create file-reading writing stage and add it to the pipeline 
    MyInputFilter input_filter( input_file ); 
    pipeline.add_filter( input_filter );

// Create capitalization stage and add it to the pipeline 
    MyTransformFilter transform_filter;  
    pipeline.add_filter( transform_filter );

// Create file-writing stage and add it to the pipeline 
    MyOutputFilter output_filter( output_file ); 
    pipeline.add_filter( output_filter );

// Run the pipeline 
    tbb::tick_count t0 = tbb::tick_count::now(); 
    pipeline.run( MyInputFilter::n_buffer ); 
    tbb::tick_count t1 = tbb::tick_count::now();

// Remove filters from pipeline before they are implicitly destroyed. 
    pipeline.clear();

fclose( output_file ); 
    fclose( input_file );

if (is_number_of_threads_set) { 
        printf("threads = %d time = %g\n", nthreads, (t1-t0).seconds()); 
    } else { 
        if ( nthreads == 1 ){ 
            printf("serial run   time = %g\n", (t1-t0).seconds()); 
        } else { 
            printf("parallel run time = %g\n", (t1-t0).seconds()); 
        } 
    } 
    return 1; 
}

int main( int argc, char* argv[] ) { 
    if(!ParseCommandLine( argc, argv )) 
        return 1; 
    if (is_number_of_threads_set) { 
        // Start task scheduler 
        tbb::task_scheduler_init init( NThread ); 
        if(!run_pipeline (NThread)) 
            return 1; 
    } else { // Number of threads wasn't set explicitly. Run serial and parallel version 
        { // serial run 
            tbb::task_scheduler_init init_serial(1); 
            if(!run_pipeline (1)) 
                return 1; 
        } 
        { // parallel run (number of threads is selected automatically) 
            tbb::task_scheduler_init init_parallel; 
            if(!run_pipeline (0)) 
                return 1; 
        } 
    } 
    return 0; 
}

第二个程序,对应debug模式,带上tbb_debug.lib:

#include "tbb/task_scheduler_init.h" 
#include "tbb/blocked_range.h" 
#include "tbb/parallel_for.h"

// 链接tbb_debug.lib 
//#pragma comment(lib, "tbb_debug.lib")

using namespace tbb;

// 对每个Item执行该操作 
void Foo(float value) 

    printf("%.2f\n ", value); 
}

class ApplyFoo 
    { 
        float * const my_a; 
public: 
    void operator () (const blocked_range<size_t> & r) const 
        { 
            float * a = my_a; 
            for (size_t i = r.begin(); i != r.end(); ++ i) 
                Foo(a[i]); 
    }

ApplyFoo(float a[]) : my_a(a) {} 
};

int _tmain(int argc, _TCHAR* argv[]) 

    // 创建task scheduler 
    // task_scheduler_init支持一个参数,以指定使用的线程数 
    task_scheduler_init init; 
    float a[100]; 
    for (int i = 0; i < 100; i ++) 
        a[i] = (float)i; 
    // TBB会把数组分成若干的block 
    // 对block调用ApplyFoo这个functor 
    parallel_for(blocked_range<size_t>(0, 100), ApplyFoo(a)); 
    return 0; 

intel线程库tbb的使用的更多相关文章

  1. c++并行计算库TBB和PPL的基本用法

    并行库充分利用多核的优势,通过并行运算提高程序效率,本文主要介绍c++中两个知名的并行库,一个是intel开发的TBB,一个是微软开发的PPL.本文只介绍其基本的常用用法:并行算法和任务. TBB(I ...

  2. Linux posix线程库总结

    由于历史原因,2.5.x以前的linux对pthreads没有提供内核级的支持,所以在linux上的pthreads实现只能采用n:1的方式,也称为库实现. 线程的实现,经历了如下发展阶段: Linu ...

  3. 【Jetlang】一个高性能的Java线程库

    actor  Jetlang 提供了一个高性能的Java线程库,该库是 JDK 1.5 中的 java.util.concurrent 包的补充,可用于基于并发消息机制的应用. .net的MS CCR ...

  4. Boost线程库学习笔记

    一.创建一个线程 创建线程 boost::thread myThread(threadFun); 需要注意的是:参数可以是函数对象或者函数指针.并且这个函数无参数,并返回void类型. 当一个thre ...

  5. Arduino线程库ProtoThreads

    参考: Arduino线程库ProtoThreads 一个“蝇量级” C 语言协程库

  6. 130行C语言实现个用户态线程库——ezthread

    准确的说是除掉头文件,测试代码和非关键的纯算法代码(只有双向环形链表的ADT),核心代码只有130行左右,已经是蝇量级的用户态线程库了.把这个库取名为ezthread,意思是,这太easy了,人人都可 ...

  7. OS之进程管理---多线程模型和线程库(POSIX PTread)

    多线程简介 线程是CPU使用的基本单元,包括线程ID,程序计数器.寄存器组.各自的堆栈等,在相同线程组中,所有线程共享进程代码段,数据段和其他系统资源. 传统的的单线程模式是每一个进程只能单个控制线程 ...

  8. c++ 封装线程库 2

    1.2线程回收: 首先得知道线程的两个状态: Joinable Detached 简单理解,如果一个线程是joinable的状态,那么这样的线程,就必须使用pthread_join来回收,否则程序结束 ...

  9. posix线程库1

    posix线程库重要的程度不言而喻,这些天学习这个,参考 https://www.ibm.com/developerworks/cn/linux/thread/posix_thread1/   首先先 ...

随机推荐

  1. js中时间戳与日期转换-js日期操作

    常用的一些日期操作. 用js获取一个时间戳. <script type="text/javascript"> var date = new Date();//当前时间 ...

  2. centos7上使用yum安装mysql

    centos yum是没有mysql的,集成的是新的Mariadb,怎么用yum的方式在centos7上安装mysql呢? 1. 下载mysql的repo源 wget http://repo.mysq ...

  3. Web文件管理:elFinder.Net(支持FTP)

    elFinder 是一个基于 Web 的文件管理器,灵感来自 Mac OS X 的 Finder 程序. elFinder.Net是.Net版本的一个Demo,使用ASP.NET MVC 4集成,可以 ...

  4. 使用.NET框架、Web service实现Android的文件上传(二)

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAYUAAAKpCAIAAADcx6fPAAAgAElEQVR4nOydd1hT5+LHg1attbfr1t ...

  5. COM 浅谈

    ArcObject 是基于 COM(Microsoft Component Object Model),即组件对象模型.虽然ArcGIS的终端用户不用理解什么是COM,但是作为基于ArcObject的 ...

  6. 初学Java ssh之Spring 第四篇

    今天我来学习学习Spring中Bean. 在Spring中原来还有<beans.../>标签啊,它相当于<bean.../>标签的老爸,老爸可以有很多个儿子,但是老爸只有一个哦 ...

  7. iOS_SN_UITableView的优化

    1.提前计算并缓存好高度(布局),因为heightForRowAtIndexPath:是调用最频繁的方法. 2.异步绘制,遇到复杂界面,遇到性能瓶颈时,可能就是突破口. 3.滑动时按需加载,这个在大量 ...

  8. iOS项目名称、版本号与屏幕分辨率

    iOS的版本号,一个叫做Version,一个叫做Build,这两个值都可以在Xcode 中选中target,点击“Summary”后看到. Version在plist文件中的key是“CFBundle ...

  9. Swift - 43 - 继承, 多态, 析构函数

    import Foundation /* 什么叫继承: 可以简单理解为一个类可以从它的父类或者基类中直接拿属性或者方法去使用 冒号":"表示两者之间的继承关系 */ class P ...

  10. 高仿QQ即时聊天软件开发系列之一开端

    前段时间在园子里看到一个大神做了一个GG2014IM软件,仿QQ的,那感觉···,赶快下载源码过来试试,还真能直接跑起来,效果也不错.但一看源码,全都给封装到了ESFramework里面了,音视频那部 ...