当前位置: 首页 > news >正文

jsp网站缓存在哪seo网络优化教程

jsp网站缓存在哪,seo网络优化教程,微信小程序公司网站怎么制作,海口网站开发🧠 什么是 OpenMP? OpenMP(Open Multi-Processing) 是一种基于 共享内存多线程并行编程 的标准接口,主要用于 C/C 和 Fortran。 它通过编译器指令(#pragma)和少量函数调用,实现程序…


🧠 什么是 OpenMP?

OpenMP(Open Multi-Processing) 是一种基于 共享内存多线程并行编程 的标准接口,主要用于 C/C++ 和 Fortran
它通过编译器指令(#pragma)和少量函数调用,实现程序的多线程并行执行,广泛用于多核 CPU 的并行加速。

✅ 关键词:简单、快速接入、共享内存模型、线程级并行


📚 基本原理

  • OpenMP 利用多线程模型,多个线程访问同一块共享内存。

  • 主线程启动并分配工作到多个子线程。

  • 子线程完成任务后回收,继续主线程的流程。


🚀 使用步骤(C++ 示例)

1. 头文件引入

#include <omp.h>

2. 编译器支持

使用 -fopenmp(GCC/Clang) 或 /openmp(MSVC):

g++ -fopenmp main.cpp -o my_app

🔧 常用指令详解

1. 并行执行块

#pragma omp parallel
{// 这里的代码由多个线程并行执行
}

2. 并行 for 循环

#pragma omp parallel for
for (int i = 0; i < N; ++i) {// 多线程并行执行每一次迭代
}

3. 指定共享与私有变量

#pragma omp parallel for shared(shared_var) private(i)
  • shared(x):所有线程共享变量

  • private(x):每个线程有自己的副本

4. critical(临界区)

保证某段代码只被一个线程执行:

#pragma omp critical
{// 通常用于修改共享变量(如 push_back、计数等)
}

5. reduction(规约)

并行执行中对变量进行“聚合”:

int sum = 0;
#pragma omp parallel for reduction(+:sum)
for (int i = 0; i < N; ++i)sum += i; // 各线程加和后统一聚合

6. atomic(原子操作)

原子性地更新变量,比 critical 粒度更小:

#pragma omp atomic
sum += i;

7. schedule(任务划分策略)

控制任务在线程间如何分配:

#pragma omp parallel for schedule(static)   // 固定分配
#pragma omp parallel for schedule(dynamic)  // 动态分配

🧮 运行时函数

int omp_get_num_threads();    // 获取当前线程数
int omp_get_thread_num();     // 获取当前线程 ID(从 0 开始)
int omp_get_max_threads();    // 系统支持的最大线程数

🧪 示例:并行求数组和

#include <omp.h>
#include <iostream>
int main() {const int N = 1000;int a[N];for (int i = 0; i < N; ++i) a[i] = i;long long sum = 0;#pragma omp parallel for reduction(+:sum)for (int i = 0; i < N; ++i) {sum += a[i];}std::cout << "Sum = " << sum << std::endl;return 0;
}

⚠️ 使用注意事项

问题描述
❌ 数据竞争多线程读写同一变量未加锁或同步,可能崩溃
❌ 非线程安全容器std::vectordeque 等 STL 容器需手动保护
❌ 非结构化编程不当的 #pragma 结构容易导致 bug
❌ 嵌套并行默认为关闭,需手动打开 omp_set_nested(1)

✅ 适合的使用场景

场景说明
CPU 密集型计算大量循环计算、矩阵乘法、图像处理
数据并行处理同一类型的大量数据
图像 Patch 并行处理图像分块 + #pragma omp parallel for
替代多线程简洁替代 pthread/C++ std::thread 等

🧰 优缺点总结

优点缺点
✅ 易上手❌ 仅支持共享内存系统
✅ 与现有代码融合简单❌ 控制粒度较粗,不适合复杂任务分配
✅ 开销小(无需线程池)❌ 对线程安全性要求高,容易出错

📦 补充工具

  • GOMP(GNU OpenMP Runtime):你遇到的 libgomp.so 就是它,OpenMP 的运行时。

  • Intel TBB / C++20 并行算法:适合更复杂的并行场景。

  • OpenCL / CUDA:适合跨设备(GPU)并行。


执行例子


#include <iostream>
#include <omp.h>int main() {#pragma omp parallel{int tid = omp_get_thread_num();std::cout << "Thread %d says hello\n" << tid << std::endl;int num_threads = omp_get_num_threads();std::cout << "Number of threads: " << num_threads << std::endl;}std::cout << " ------------------------- " << std::endl;#pragma omp parallel forfor (int i = 0; i < 8; ++i) {printf("Thread %d handles i = %d\n", omp_get_thread_num(), i);int tid = omp_get_thread_num();std::cout << "the threads is: " << tid << std::endl;std::cout << std::endl;}std::cout << " ------------------------- " << std::endl;int public_val = 0;for(int i=0; i<10; i++){public_val += 1;}std::cout << "the public_val is: " << public_val << std::endl;public_val = 0;#pragma omp parallel forfor(int i=0; i<10; i++){   #pragma omp criticalpublic_val += 1;}std::cout << "the public_val is: " << public_val << std::endl;public_val = 0;#pragma omp parallel forfor(int i=0; i<10; i++){   public_val += 1;}std::cout << "the public_val is: " << public_val << std::endl;return 0;
}// g++ main.cpp -fopenmp -o hello

http://www.hkea.cn/news/152200/

相关文章:

  • 网站开发yuanmus联合早报 即时消息
  • 为什么只有中国人怕疫情seo 页面
  • 网站开发总结报告十大门户网站
  • 临淄信息港发布信息临沂seo建站
  • 门户网站系统介绍企业推广哪个平台好
  • 免费网站建站排行榜网站策划报告
  • 网站设计的评估最近发生的热点新闻
  • 设建网站广告投放渠道
  • 日ip5000的网站怎么做如何提高网站在搜索引擎中的排名
  • 网站描文本链接怎么做深圳互联网营销
  • 一个服务器做两个网站自己做网站
  • 百草味网站建设的活动方案营销型企业网站有哪些
  • 论文课程网站 建设背景项目推广方式有哪些
  • 内部网站建设关键词优化推广策略
  • 一个公司可以做几个网站备案贵阳网络推广排名
  • 武汉高端网站建设免费广告网
  • 大理建网站常用于网站推广的营销手段是
  • js怎么做网站跨境电商网站
  • 台州外贸网站建设百度推广费用多少
  • 虚拟机怎么做网站空间培训班管理系统 免费
  • wordpress离线文章发布郑州seo关键词排名优化
  • 龙岗区网站建设中国职业培训在线
  • 南山网站建设外包优化网站
  • 个人怎么做网站推广神起网络游戏推广平台
  • 做网站的关键技术运营推广的方式和渠道有哪些
  • jsp做就业网站网推项目
  • 网站开发的目的和意义重庆seo排名电话
  • 顺义专业建站公司最有效的线上推广方式
  • 大连网站网站搭建制作百度识图 上传图片
  • 给人做网站多少钱黑科技引流推广神器怎么下载