实验十七Linux下进程线程的创建.ppt

上传人:wuy****n92 文档编号:90681701 上传时间:2023-05-17 格式:PPT 页数:25 大小:1,010.50KB
返回 下载 相关 举报
实验十七Linux下进程线程的创建.ppt_第1页
第1页 / 共25页
实验十七Linux下进程线程的创建.ppt_第2页
第2页 / 共25页
点击查看更多>>
资源描述

《实验十七Linux下进程线程的创建.ppt》由会员分享,可在线阅读,更多相关《实验十七Linux下进程线程的创建.ppt(25页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、LinuxLinux下进程和线程的创建下进程和线程的创建 吴国伟学习Linux中创建进程的方法学习系统调用Fork的使用方法学习系统调用Exec族的使用方法学习Linux中创建线程的方法学习pthread_create使用方法5/17/2023PIDPID:进程号。PPIDPPID:父进程号。UIDUID:其创建者的用户标识号,父子进程有相同的UID值。LinuxLinux进程创建进程创建Linux进程的族亲关系Linux进程之间不是孤立存在的,它们之间有一定的族亲关系。一个进程的子进程可以多于一个。一个进程只会有一个父进程。进程1进程2父进程子进程产产 生生LinuxLinux进程创建进程创

2、建系统加电启动后,系统中只有一个进程初始化进程,又称init进程,是所有进程的祖先进程,它的进程pid=1在linux中除了init进程是由系统启动时创建的外,其他所有进程都是由当前进程使用系统调用fork()创建的。进程创建后父子进程在系统中并发执行。进程结构进程结构同时运行grep程序,在不同文件中查找不同的字符串PID 101代码数据s=“one”函数库文件Trek.txtPID 102代码数据s=“two”函数库文件Next.txtgrep程序代码C语言函数库ForkFork()()系统调用系统调用此时一个进程“分裂”成两个进程:父进程和子进程。区别:进程ID。利用getpid()来得

3、到进程号。通过fork创建一个新进程,系统复制当前进程,在进程表中创建一个新的表项新进程几乎与原进程相同,执行代码也相同但有自己的数据空间,环境,文件描述符等#include pid_t fork();ForkFork()()系统调用系统调用fork调用的一个奇妙之处就是它仅仅被调用一次,却能够返回两次,它可能有三种不同的返回值:父进程:返回子进程的PID;子进程:返回0;出现错误:返回-1;最初的进程fork()原进程继续执行新进程返回一个新的pid返回05/17/2023#include#include#include int main()int pid=fork();if(pid=-1)

4、printf(error!n);else if(pid=0)printf(This is the child process!nchild process id=%dn,getpid();else printf(This is the parent process!nparent process id=%dn,getpid();return 0;5/17/2023运行结果:This is the child process!child process id=4800This is the parent process!parent process id=4799ForkFork()()系统调用

5、系统调用等待一个进程结束等待一个进程结束#include#includepid_t wait(int*stat_loc)父进程调用1.wait系统调用将暂停父进程直到它的子进程结束为止2.返回子进程的PID3.状态信息允许父进程了解子进程的退出状态,即子进程main函数返回值或子进程中exit函数的退出码4.若stat_loc不为空指针,状态信息被写入他指定的为止5/17/2023父进程创建子进程后,子进程一般要执行不同的程序.为了调用系统程序,我们可以使用系统调用exec 族调用。Exec函数可以把当前进程替换为一个新进程exec函数包含以下五个函数:#includeint execl(co

6、nstchar*path,const char*arg,);int execlp(constchar*file,const char*arg,);int execle(constchar*path,const char*arg,char*const envp);int execv(constchar*path,char*const argv);int execvp(constchar*file,char*const argv);5/17/2023其中只有execve是真正意义上的系统调用,其它都是在此基础上经过包装的库函数。#includeintexecve(constchar*path,ch

7、ar*const argv,char*const envp);path:可执行文件路径。argv:要执行的文件名或命令名。envp:环境变量,可省略Linux Linux 创建线程创建线程线程:一个进程内部的一个控制序列每个进程都至少有一个执行线程创建线程与创建线程与forkfork区别区别fork:fork:当前进程的拷贝,有自己的变量和PID,时间调度独立,执行几乎完全独立于父进程新线程:新线程:有自己独立栈(有局部变量)但与创建者共享全局变量,文件描述,信号句柄和当前状态等线程优缺点线程优缺点优点:一般而言,线程创建以及线程之间的切换需要操作系统做的工作比进程少得多。例子:编辑文档过程的

8、多线程,一个线程负责用户输入和编辑,一个线程负责字数统计缺点:缺点:多线程程序因变量共享可能引发潜在错误,调试困难pthread_creatpthread_creatint pthread_create(pthread_t*thread,pthread_attr_t*attr,void*(*start_routine)(void*),void*arg)参数1.该指针指向的变量中将被写入一个标识符,用该 标识符来引用新线程2.设置线程属性,一般不用设为null3.表示线程将要启动执行的函数4.该函数需要的参数调用成功返回值为0,否则返回错误代码void pthread_exit(void*ret

9、val)void pthread_exit(void*retval)调用上面函数终止线程返回一个指向某个对象的指针注意:不能用它来返回一个指向局部变量的指针,因为线程调用该函数后,这个局部变量就不存在了pthread_joinpthread_joinint pthread_join(pthread_t th,void*thread_return)等待线程结束,收集线程信息参数1.指定了将要等待结束的线程参数2.是一个指针,指向了一个指针,后者指向线程的返回值例子例子#include#include#include#include void*thread_function(void*arg);c

10、har message=Hello world;int main()int res;pthread_t a_thread;void*thread_result;res=pthread_create(&a_thread,NULL,thread_function,(void*)message);if(res!=0)perror(Thread creation failed);exit(EXIT_FAILURE);printf(Waiting for thread to finish.n);res=pthread_join(a_thread,&thread_result);if(res!=0)per

11、ror(Thread join failed);exit(EXIT_FAILURE);printf(Thread joined,it returned%sn,(char*)thread_result);printf(Message is now%sn,message);exit(EXIT_SUCCESS);void*thread_function(void*arg)printf(thread_function is running.Argument was%s n,(char*)arg);sleep(3);strcpy(message,Bye!);pthread_exit(Thank you

12、for the CPU time);运行结果运行结果Waiting for thread to finish.thread_function is running.Argument was Hello worldThread joined,it returned Thank you for the CPU timeMessage is now Bye!编译须知:gcc-lpthread-o file file.c 随堂作业随堂作业3.4 3.64.7 4.113.6Fibonacci序列是一组:0,1,1,2,3,5,8,fib0=0;fib1=1;fibn=fibn-1+fibn-2;使用系

13、统调用fork()编写一个C程序,它在其子程序中生成Fibonacci序列,序列号码将会在命令行中提供。例如,如果提供的是5,Fibonacci序列中的前5个数将由子进程输出。由于父进程和子进程都有他们自己的数据副本,对子进程而言,输出序列式必要的。退出程序前,父进程调用wait()调用来等待子进程结束。执行必要的错误检查以保证不会接受命令行传递来的负数号码。4.11Fibonacci序列是一组:0,1,1,2,3,5,8,fib0=0;fib1=1;fibn=fibn-1+fibn-2;使用phtread多线程编程程序来生成Fibonacci序列。程序应该这样工作:用户运行程序时,在命令行输入要产生Fibonaci序列数,然后程序创建一个新的线程来产生Fibonacci数,把这个序列放到线程共享的数据中(数组可能是一种最方便的数据结构)。当线程执行完成后,父线程将输出子线程产生的序列。由于在子线程结束前,父线程不能开始输出Fibonacci序列,因此,父线程需要等子线程结束

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 大学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁