多线程并行计算数据总和 —— 优化计算思想(多线程去计算)—— C语言demo
2017-05-08 11:37
525 查看
多线程计算整型数组数据总和:
在此也可以结合队列来使用,队列控制取到的计算点
#include <stdio.h> #include <stdlib.h> #include <Windows.h> #include<process.h> #include <time.h> #define N 1024 struct Myinfo { int *pstart;//开始地址 int length;//长度 int id;//线程编号 int sum;//存储数据的和 }; void add(void *p) //void *p可以保存任何类型的指针 { struct Myinfo *pinfo = p; for (int i = 0; i < pinfo->length;i++) { pinfo->sum += pinfo->pstart[i]; } printf("\n线程%d计算的结果%d", pinfo->id, pinfo->sum); } void main() { time_t ts; unsigned int num = time(&ts);//传递地址 srand(num); int data = { 0 }; // 进行赋值 for (int i = 0; i < N; i++) { data[i] = rand() % 1000; //printf("%4d", data[i] = rand() % 1000); } int sum = 0; //计算总和 for (int i = 0; i < N; i++) { sum += data[i]; } printf("\n总和=%d", sum); struct Myinfo info[8] = { 0 }; for (int i = 0; i < 8;i++) { info[i].id = i; info[i].length = N / 8; info[i].sum = 0; info[i].pstart = data + i*N / 8; //注意这里地址的移动 _beginthread(add, 0, &info[i]); } system("pause"); int lastsum=0; for (int i = 0; i < 8;i++) { lastsum += info[i].sum; } printf("\n多线程总和=%d", lastsum); system("pause"); }
在此也可以结合队列来使用,队列控制取到的计算点
相关文章推荐
- 多线程并行计算Fibonacci(互相分开,无数据交流)
- 单核单线程、单核多线程、多核多线程以及并行计算对大数据和复杂算法的简单效应
- 大数据应用之HBase数据插入性能优化之多线程并行插入测试案例
- 大数据应用之HBase数据插入性能优化之多线程并行插入测试案例
- 大数据应用之HBase数据插入性能优化之多线程并行插入测试案例
- 大数据应用之HBase数据插入性能优化之多线程并行插入测试案例
- 【大数据技巧】MaxCompute优化去重计算的性能
- 4.0中的并行计算和多线程详解(二)
- 4.0中的并行计算和多线程详解(二)
- 并行计算简介和多核CPU编程Demo
- 利用curl_multi_init并行多线程处理网络数据
- CUDA数据并行计算
- 03-大数据内存计算spark系列贴-spark整合hbase,优化BI平台
- SAP ABAP程序优化-多线程并行处理
- 浅谈多核CPU、多线程与并行计算
- SAP ABAP程序优化-多线程并行处理
- c语言数据类型存储值的范围的计算
- C语言二进制思想以及数据的存储
- 浅谈.NET下的多线程和并行计算(十二)CLR via C#第三版阅读笔记(1)
- 如何利用VS的代码优化和openmp并行计算提高程序运行速度