Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1751512
  • 博文数量: 782
  • 博客积分: 2455
  • 博客等级: 大尉
  • 技术积分: 4140
  • 用 户 组: 普通用户
  • 注册时间: 2011-04-06 21:37
个人简介

Linux ,c/c++, web,前端,php,js

文章分类

全部博文(782)

文章存档

2015年(8)

2014年(28)

2013年(110)

2012年(307)

2011年(329)

分类:

2012-04-21 11:40:57

原文地址:多线程并行计算代码 作者:biti-leaf

要离开实验室了,电脑上的好多小程序不忍心删,带走又没什么价值,就发到博客上来吧。
这事Windows下多线程并行计算的程序的框架,代码如下所示:

点击(此处)折叠或打开

  1. #include <stdio.h>
  2. #include <windows.h>

  3. int array[50];

  4. DWORD WINAPI ComputeProc(LPVOID lp)
  5. {
  6.   int i;
  7.   int *p;
  8.   p = (int *)lp;
  9.   i = *(int *)lp;
  10.   printf("thread %d running.\n", i);
  11.   array[i] = 2*array[i];
  12.   
  13.   free(p);
  14.   return 0;
  15. }

  16. void ComputeF()
  17. {
  18.     int i = 0;
  19.     HANDLE handle[50];
  20.     
  21.     for(i = 0; i < 50; i++)
  22.     {
  23.         int *itmp = (int *)malloc(sizeof(int));
  24.         *itmp = i;
  25.         handle[i] = CreateThread(NULL, 0, ComputeProc, itmp, 0, 0);
  26.         //Sleep(10);//??10??
  27.     }
  28.     for(i = 0; i < 50; i++)
  29.     {
  30.         WaitForSingleObject(handle[i],INFINITE);
  31.     }
  32.     for(i = 0; i < 50; i++)
  33.     {
  34.         CloseHandle(handle[i]);
  35.     }
  36.     printf("all threads execute complete.\n");
  37. }

  38. int main()
  39. {
  40.     int i = 0;
  41.     for(i = 0; i < 50; i++)
  42.     {
  43.         array[i] = i;
  44.     }
  45.     
  46.     ComputeF();
  47.     
  48.     for(i = 0; i < 50; i++)
  49.     {
  50.         printf("%d ", array[i]);
  51.     }
  52.     return 0;
  53. }
需要注意的是,多线程中并行的部分如果访问到同一变量,则需要加上锁,这里由于通过参数确定了每个并行部分访问的变量不会冲突,所以这里没有加。


阅读(769) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~