【操作系统】Linux之进程管理二

第1关:进程等待

if(wait(&status) != -1)

{

if(WIFEXITED(status))

status = WEXITSTATUS(status);

else

status = -1;

}

else

{

status = -1;

}

第2关:进程创建操作-exec函数族

void execlProcess()

{

pid_t pid = vfork();

if(pid == -1)

{

printf("创建子进程失败(%s)\n", strerror(errno));

return -1;

}

else if(pid == 0)

{

//子进程

/********** BEGIN **********/

if(execle("touch","touch","testDir",NULL)<0)

{

exit(-1);

}

/********** END **********/

}

else

{

//父进程

/********** BEGIN **********/

printf("Parent Process");

/********** END **********/

}

}

第3关:进程创建操作-system

int test=system("mkdir testDir");

if(test==1)

{

return test;

}

第4关:实现一个简单的命令解析器

int i=0;

while(i<commandNum)

{

system(cmd[i]);

i++;

}

相关推荐
流浪0019 分钟前
Linux基础篇(三)轻松拿捏入门级指令
linux·运维·服务器
宵时待雨17 分钟前
优选算法专题6:模拟
数据结构·c++·算法·leetcode·职场和发展
Waay17 分钟前
Linux Shell 知识点考评(三):awk文本分析(附答案)
linux·服务器·编辑器
爱喝水的鱼丶18 分钟前
SAP-ABAP:ABAP Development Tools(ADT)安装配置学习分享教程(四篇连载) 第二篇:ADT客户端完整安装与初始配置教程
运维·开发语言·学习·sap·abap
Liangwei Lin23 分钟前
LeetCode 35. 搜索插入位置
数据结构·算法·leetcode
xlq2232234 分钟前
53.tcp socket
linux·服务器·开发语言·网络·网络协议·tcp/ip
L_090734 分钟前
【C++】STL— 封装红黑树以实现map 和 set
数据结构·c++
m0_46644103詹湛37 分钟前
FPGA时序优化与高速接口实战手册
笔记·学习·fpga开发·硬件架构·verilog
Shingmc344 分钟前
【Linux】传输层协议UDP
linux·网络·udp
问心无愧05131 小时前
ctf show web 入门39
android·前端·笔记