|
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
多线程和多进程还是有很多区别的。其中之一就是,多进程是linux内核本身所支持的,而多线程则需要相应的动态库进行支持。对于进程而言,数据之间都是相互隔离的,而多线程则不同,不同的线程除了堆栈空间之外所有的数据都是共享的。说了这么多,我们还是自己编写一个多线程程序看看结果究竟是怎么样的。#include <stdio.h>- #include <pthread.h>
- #include <unistd.h>
- #include <stdlib.h>
- void func_1(void* args)
- {
- while(1){
- sleep(1);
- printf("this is func_1!\n");
- }
- }
- void func_2(void* args)
- {
- while(1){
- sleep(2);
- printf("this is func_2!\n");
- }
- }
- int main()
- {
- pthread_t pid1, pid2;
- if(pthread_create(&pid1, NULL, func_1, NULL))
- {
- return -1;
- }
- if(pthread_create(&pid2, NULL, func_2, NULL))
- {
- return -1;
- }
- while(1){
- sleep(3);
- }
- return 0;
- }
复制代码
和我们以前编写的程序有所不同,多线程代码需要这样编译,输入gcc thread.c -o thread -lpthread,编译之后你就可以看到thread可执行文件,输入./thread即可。
[test@localhost Desktop]$ ./threadthis is func_1!this is func_2!this is func_1!this is func_1!this is func_2!this is func_1!this is func_1!this is func_2!this is func_1!this is func_1!
作者:feixiaoxing 发表于2012-2-6 19:45:46 原文链接
|
|