运行命令:g++ -fopenmp xx.cpp -lgomp -lpthread -o xx.out

用例一:
#include <omp.h>
#include <stdio.h>
#include <stdlib.h>
void test (int n) {
    for(int i = 0; i < 100000; ++i) {
    }
    printf("%d, ", n);
}
int main(int argc,char* argv[])
{
omp_set_num_threads(4); //设置线程数
    #pragma omp parallel for
    for(int i = 0; i < 100; ++i)
       test( i );
}





用例二(转):
#include<iostream>
#include<omp.h>
#include<ctime>
using namespace std;
void test_omp(int times);
int main()
{
    cout << omp_get_num_procs() << endl;
    test_omp(1);
    test_omp(2);
    test_omp(4);
    test_omp(9);
    test_omp(17);
}
void test_omp(int times)
{
    omp_set_num_threads(times);
    printf("test get_num_threads result1: %d\n", omp_get_num_threads());
    printf("test get_num_procs result1: %d\n", omp_get_num_procs());
    clock_t start = clock();
#pragma omp parallel for
    for (int i = 0; i < 20; i++)
    {
        if(i==0)
        {
            printf("test get_num_threads result2: %d\n", omp_get_num_threads());
            printf("test get_num_procs result1: %d\n", omp_get_num_procs());
        }

        printf( "Hello from thread: No.%d \n", omp_get_thread_num());
            for (int j = 0; j < 1000000; j++)
            {
                double a = 1585876.058578545361;
                for (int k = 0;k < 10;k++)
                    a *= a;
            }

    }
    clock_t end = clock();
    printf("%d threads para use time: %fs\n", times, double((end - start)) / CLOCKS_PER_SEC);
}



OpenMP的环境变量:

环境变量

描述

示例

OMP_SCHEDULE

控制for循环任务分配结构的调度

OMP_SCHEDULE="guided,2"

OMP_NUM_THREADS

设置默认线程的个数

OMP_SCHEDULE=4

OpenMP的库函数

函数名称

描述

int omp_get_num_threads(void)

返回当前使用的线程个数,如果在并行区域外则返回1

int omp_set_num_threads(int i)

设置要使用的线程个数,它可以覆盖OMP_NUM_THREADS

int omp_get_thread_num(void)

返回当前线程号,0代表主线程

int omp_get_num_procs(void)

返回可用的处理核(处理器)个数,对于支持超线程技术的处理器被算作两个处理核

OpenMP的调度方案

调度类型

描述

static

将所有循环迭代划分成相等大小的块

dynamic

使用一个内部队列,当某线程可用时,为其分配由块大小所制定的一定数量的循环迭代

guided

与dynamic策略类似,但是块大小开始较大,后来逐步减小。可选参数chunk指定块大小的最小值,默认为1

runtime

运行时由OMP_SCHEDULE决定使用上面三种的哪种策略

OpenMP的编译

平台和编译器

命令

windows平台 intel C++编译器

icl /Qopenmp

linux平台 intel C++编译器

icl -openmp

gcc

gcc -fopenmp

_OPENMP宏可以用来判断OpenMP是否被支持,通过它可以写出任何C语言编译器(即使不支持OpenMP)都可以编译的代码。代码如下所示:

#ifdef _OPENMP

#include <omp.h>

#else

#define omp_get_thread_num() 0

#endif

使用Openmp并行化的更多相关文章

  1. OpenMP 并行化处理测试

    OpenMP 并行化处理测试 #pragma omp parallel for 这条语句是用来指定后面的for循环语句变成并行执行的,将for循环里的语句变成并行执行后效率会不会提高呢?还是测试一 下 ...

  2. OpenMP并行化实例----Mandelbrot集合并行化计算

    在理想情况下,编译器使用自动并行化能够管理一切事务,使用OpenMP指令的一个优点是将并行性和算法分离,阅读代码时候无需考虑并行化是如何实现的.当然for循环是可以并行化处理的天然材料,满足一些约束的 ...

  3. 基于GCC的openMP学习与测试(2)

    一.openMP简单测试 1.简单测试(1) #include<omp.h> #include<time.h> #include<iostream> using n ...

  4. 【并行计算】基于OpenMP的并行编程

    我们目前的计算机都是基于冯偌伊曼结构的,在MIMD作为主要研究对象的系统中,分为两种类型:共享内存系统和分布式内存系统,之前我们介绍的基于MPI方式的并行计算编程是属于分布式内存系统的方式,现在我们研 ...

  5. 【openmp】for循环的break问题

    问题描述:在用openmp并行化处理for循环的时候,便无法在for循环中用break语句,那么我们如何实现这样的机制呢?在stackoverflow上看到一个不错的回答总结一下. volatile ...

  6. 并行求pi (C++实现)

    用OpenMP并行化求pi的代码,这里用的是公式法求pi.具体如下: //公式法 #include<omp.h> #include<stdio.h> #include<s ...

  7. 密码破解工具John the Ripper使用说明

    John the Ripper John 包描述 John the Ripper 既功能丰富又运行快速. 它在一个程序中结合了几种破解模式,并且可以根据您的特定需求进行全面地配置(你甚至可以使用支持C ...

  8. OpenMP并行程序设计——for循环并行化详解

    在C/C++中使用OpenMP优化代码方便又简单,代码中需要并行处理的往往是一些比较耗时的for循环,所以重点介绍一下OpenMP中for循环的应用.个人感觉只要掌握了文中讲的这些就足够了,如果想要学 ...

  9. 方阵行列式并行化计算(OpenMP,MPI),并计算加速比

    00][100].在创建方阵时,方阵的阶数N(N<100)由外部输入.然后用两层"for循环"来给方阵 p左上角 N×N个位置赋值.具体实现如下: /* * 定义矩阵阶数N ...

随机推荐

  1. gdal3.1.0+VS2017+geos+kml编译总结

    1.简介 gdal3.1.0编译过程中必须依赖proj,编译gdal必须要编译proj,proj的编译需要sqlite3,因此想要编译gdal3.1.0需要先编译proj和sqlite3 2.关于sq ...

  2. 绘制PCB电路原理图的8种方法

    1.选择集成电路,变压器,晶体管等组件,这些组件体积庞大,有许多引脚并在电路中起主要作用,然后从选定的参考引脚中抽取,以减少错误. 2.如果PCB上标有元件编号(如VD870,R330,C466等), ...

  3. 用C++实现的数独解题程序 SudokuSolver 2.6 的新功能及相关分析

    SudokuSolver 2.6 的新功能及相关分析 SudokuSolver 2.6 的命令清单如下: H:\Read\num\Release>sudoku.exe Order please: ...

  4. (转载)关于Linux C函数strtok的使用要点

    今天遇到了处理字符串的问题,比如分割问题,但是一时间想不起来什么方法,也不想手写一个类似java String中的split函数,于是百度了一下,发现了strtok这个好用的方法,以此作为总结. st ...

  5. 反转单词顺序列 牛客网 剑指Offer

    反转单词顺序列 牛客网 剑指Offer 题目描述 牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上.同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但 ...

  6. Codeforces Round #744 (Div. 3) G题题解

    淦,最后一道题没写出来,...还是我太菜了,不过这个题确实比较有趣. G. Minimal Coverage 简化题意:就是你处在坐标轴的0点上,给你一个序列\(a_i\),每次你可以选择向左走\(a ...

  7. Linux 内核网桥源码分析

    Linux网桥源码的实现 转自: Linux二层网络协议 Linux网桥源码的实现 1.调用 在src/net/core/dev.c的软中断函数static void net_rx_action(st ...

  8. 国产新芯片连不上J-Link?芯海CS32L010系列芯片JLink配置方法

    疫情以来芯片供货紧张,特别是ST的MCU一芯难求.所以很多产品不得不切换成国产.不过也是经过使用后才发现,很多国产芯片的性能还是挺好的.由于芯片比较新,官方J-Link还没有支持,所以调试和烧录有些不 ...

  9. Awesome metaverse projects (元宇宙精选资源汇总)

    Awesome Metaverse 关于 Metaverse 的精彩项目和信息资源列表. 由于关于 Metaverse 是什么存在许多相互竞争的想法,请随时以拉取请求.问题和评论的形式留下反馈. We ...

  10. 用tsc编译ts文件的时候报错,tsc : 无法加载文件,因为在此系统上禁止运行脚本;

    用tsc编译ts文件的时候报错,tsc : 无法加载文件,因为在此系统上禁止运行脚本:SecurityError 在vscode的控制台或者Windows PowerShell中用tsc命令编译ts文 ...