Linux下的C----多进程与多线程
1.多进程实例:
进程:
是一种抽象的概念,从来没有统一的标准定义:
进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动;
进程是一个独立的可调度的活动;
进程是可以并行执行的计算单位;
进程是一个抽象实体,当它执行某个任务时,要分配和释放各种资源;
通常定义:进程是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程,是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。
#include<sys/types.h> #include<unistd.h> #include<stdio.h> #include<stdlib.h> int main() { pid_t pid; char *message; int n; pid=fork(); if (pid<0) { perror("fork failed"); exit(1); } if(pid==0) { message="This is the child\n"; n=6; } else { message="This is the parent\n"; n=8; } for(;n>0;n--) { printf(message); sleep(1); } return 0; }
2.多线程实例:
线程:
早期的操作系统中并没有线程的概念,进程是能拥有资源和独立运行的最小单位,也是程序执行的最小单位。任务调度采用的是时间片轮转的抢占式调度方式,而进程是任务调度的最小单位,每个进程有各自独立的一块内存,使得各个进程之间内存地址相互隔离。
后来,随着计算机的发展,对CPU的要求越来越高,进程之间的切换开销较大,已经无法满足越来越复杂的程序的要求了。于是就发明了线程,线程是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。
#include<stdio.h> #include<pthread.h> void thread() { int i; for(i=0;i<3;i++) printf("This is a pthread\n"); } int main() { pthread_t id; int i,ret; ret=pthread_create(&id,NULL,(void *) thread,NULL); if(ret!=0) { printf("Create pthread error!\n"); exit(1); } for(i=0;i<3;i++) {printf("This is the main process.\n"); } pthread_join(id,NULL); return 0; }
answ0r_lch