C语言中的多线程编程

红薯 发布于 2011/04/28 22:19
阅读 1K+
收藏 14

很久很久以前,我对C语言的了解并不是很多,我最早听说多线程编程是用Java,其实C语言也有多线程编程,而且更为简单、方便、强大。下面就让我们简单领略一下Unix C语言环境下的多线程编程吧!
下面先看一个简单的单线程程序:
/* 06.3.6
Sghello.c
Hello,world -- Single Thread
*/
#include
#define NUM 6
int main()
{
void print_msg(char*);
print_msg("hello,");
print_msg("world!");
}
void print_msg(char* m)
{
int i;
for(i=0;i<NUM;i++)
{
printf("%s",m);
fflush(stdout);
sleep(1);
}
}
下图反映了程序的执行流程:

执行结果:
$ ./sghello.exe
hello,hello,hello,hello,hello,hello,world!world!world!world!world!world!

那么如果想同时执行两个对于print_msg函数的调用,就想使用fork建立两个新的进程一样,那该怎么办?这种思想清楚的体现在下图:

那么怎么才能达到这种效果呢?
我们可以使用函数pthread_create创建一个新的线程。
函数原型:
int pthread_create(pthread_t *thread,
pthread_attr_t *attr,
void *(*func)(void*),
void *arg);
参数: thread 指向pthread_t类型变量的指针
attr 指向pthread_attr_t类型变量的指针,或者为NULL
func 指向新线程所运行函数的指针
arg 传递给func的参数
返回值 0 成功返回
errcode 错误
我们可以使用函数pthread_join等待某进程结束。
函数原型:int pthread_join(pthread_t thread,void ** retval);
参数: thread 所等待的进程
retval 指向某存储线程返回值的变量
返回值: 0 成功返回
errorcode 错误
以上两个函数都包含在头文件pthread.h中。
下面请看多线程版的Hello,world!
/* 06.3.6
Mhello1.c
Hello,world -- Multile Thread
*/
#include
#include
#define NUM 6
int main()
{
void print_msg(void*);

pthread_t t1,t2;
pthread_create(&t1,NULL,print_msg,(void *)"hello,");
pthread_create(&t2,NULL,print_msg,(void *)"world!\n");

pthread_join(t1,NULL);
pthread_join(t2,NULL);
}
void print_msg(void* m)
{
char *cp=(char*)m;
int i;
for(i=0;i<NUM;i++)
{
printf("%s",m);
fflush(stdout);
sleep(1);
}
}
运行结果:
$ gcc mhello1.c -o mhello1.exe
$ ./mhello1.exe
hello,world!
hello,world!
hello,world!
hello,world!
hello,world!
hello,world!

C语言有一次拓展了我的视野,多线程的问题还有很多,像线程间的分工合作、使用互斥机制保证线程间数据的安全共享、使用条件变量同步线程间的数据传输、传递多个参数给线程等,若读者有兴趣,可自行深入。
推荐《Understanding Unix/Linux Programming》

加载中
0
BarryWey
BarryWey

貌似,这个会创建多个进程而不是线程来解决问题吧!我记得c语言里面最早是没有线程的说!

0
xunxun
xunxun

引用来自#2楼“Barry Wey”的帖子

貌似,这个会创建多个进程而不是线程来解决问题吧!我记得c语言里面最早是没有线程的说!

谁说的?这让OpenMP情何以堪……

gcc的OpenMP正是建立在pthread之上。

0
罗程

楼主 求反编译个东西

0
asdfsx
asdfsx

unix、linux上 进程是主流吧

0
j
jackprince

引用来自“PcX”的答案

引用来自#2楼“Barry Wey”的帖子

貌似,这个会创建多个进程而不是线程来解决问题吧!我记得c语言里面最早是没有线程的说!

谁说的?这让OpenMP情何以堪……

gcc的OpenMP正是建立在pthread之上。

这个当然是线程。如果进程的话就是fork()了。另外,线程与进程的概念都是跟操作系统有关的,跟纯语言无太大关系。如果你仅仅是学ANSI C的话,当然不会接触到线程啦。

返回顶部
顶部