提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
前言
对进程管理学习的记录和总结
一、文件管理
stat()
access()
chmod()
truncate()
link()
1.1 stat函数
#include <sys/stat.h>
int stat(const char *path, struct stat *buf);
功能:用于获取文件的属性;
参数说明:
path:文件路径;
buf:接收获取到的文件属性;文件属性存储在inode中,函数从inode结构体中获取文件信息。
返回值说明:
成功:0
不成功:-1并设置errno
【案例1】使用stat函数获取文件属性,并输出文件的大小。
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/stat.h>
int main(){
struct stat tempSBuf;
int tempRet = 2;
tempRet = stat("a.out", &tempSBuf);
if(tempRet == -1){
perror("stat error:");
exit(1);
}//of if
printf("len = %d\n", tempSBuf.st_size);
return 0;
}//of main
运行结果
__off_t类型为long int 里面应为%ld
修改后运行结果:
1.2 access函数
#include <unistd.h>
int access(const char *pathname, int mode);
功能:用于测试文件是否拥有某种权限;
参数说明:
pathname:文件名;
mode:取值有4个:R_OK, W_OK, X_OK, F_OK;前面3个是测试文件是否有读、写、执行权限,最后一个测试文件是否存在。
返回值说明:
成功:0,表示文件存在或具有某种权限。
不成功:-1并设置errno
1.3 chmod函数
#include <sys/stat.h>
int chmod(const char *path, mode_t mode);
功能:用于修改文件的访问权限;
参数说明:
path:路径名;
mode:传递修改后的权限。
返回值说明:
成功:0,表示文件存在或具有某种权限;
不成功:-1并设置errno。
1.4 truncate函数
#include <sys/stat.h>
int truncate(const char *path, off_t length);
功能:用于修改文件大小,常用于扩展文件,其功能与lseek函数类似;
参数说明:
path:路径名;
length:设置文件大小。
返回值说明:
成功:0;
不成功:-1并设置errno。
二、进程控制
fork()
exec函数族
wait()
exit()
1.1 创建进程
#include <unistd.h>
pid_t fork(void);
功能:创建进程;函数执行后,系统会创建一个与原进程几乎相同的进程,之后父子进程都继续执行
参数说明: 无
返回值说明:
成功:返回两个值,子进程创建成功后,原程序会被复制,就有了两个fork函数。父进程的fork函数会返回子进程的pid,子进程的fork函数会返回0.
不成功:若子进程创建失败,原程序不会复制,父进程的fork函数返回-1。
【案例】用fork函数创建一个子进程,创建成功后父子进程分别执行不同功能
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(){
pid_t tempPid;
tempPid = fork();
if (tempPid == -1){
perror("fork error");
}else if(tempPid > 0){//parent
printf("parent process, pid = %d, ppid = %d\n",getpid(), getppid());
}else{//child
printf("child process, pid = %d, ppid = %d\n",getpid(), getppid());
}//of if
printf("......finish......");
return 0;
}//of main
运行结果
【思考】 多次执行test_fork会发现,child process后输出的ppid不等于parent process的pid,而等于1。请说明原因
【提示】 父进程先于子进程终止,子进程变成“孤儿进程”,后面会由init进程接收。
1.2 创建多个进程
【案例2】 直接使用for循环会让子进程在再创建子进程,因此在for循环中加入判断,如果是子进程,就退出循环
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(){
pid_t tempPid;
int i;
for(i = 0; i < 4; i ++){
if((tempPid = fork()) == 0){
break;
}//of if
}//of for i
if(tempPid == -1){
perror("fork error");
}else if(tempPid > 0){//parent
printf("parent process, pid = %d, ppid = %d\n", getpid(), getppid());
}else{//child
printf("I am child process = %d, pid = %d, ppid = %d\n", i + 1, getpid(), getppid());
}//of if
printf("......finish......");
return 0;
}//of main
运行结果
【思考】(1)子进程的编号不是递增的;
(2)终端提示符后面仍然有子进程信息打印,而命令提示符在最后一行的开头闪烁。
这是为什么?
【提示】(1).每个进程优先级相同,被CPU调度的机会相等
(2)Shell命令提示符也是一个进程,它需要和新建的进程一起竞争CPU
1.3 进程的执行顺序:利用sleep函数,暂缓进程执行
【案例3】
include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(){
pid_t tempPid;
int i;
for(i = 0; i < 2; i ++){
if((tempPid = fork()) == 0){
break;
}//of if
}//of for i
if(tempPid == -1){
perror("fork error");
}else if(tempPid > 0){//parent
sleep(2);
printf("parent process, pid = %d, ppid = %d\n", getpid(), getppid());
}else{//child
sleep(i);
printf("I am child process = %d, pid = %d, ppid = %d\n", i + 1, getpid(), getppid());
}//of if
printf("......finish......");
return 0;
}//of main
运行结果
总结
1.学习了通过fork()函数创建进程,通过循环并设置子进程退出循环来让父进程创建多个子进程,通过sleep()函数让进程挂起,可用来控制进程执行顺序
参考连接:Linux编程基础 3.1:进程管理-1