Linux编程基础2.2:文件操作& 3.1:进程管理-1

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

对进程管理学习的记录和总结


一、文件管理

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值