系统级程序设计(Linux编程基础 2.2:文件操作&Linux编程基础 3.1:进程管理)

文章目录

目录

文章目录

Linux编程基础 2.2:文件操作

一、函数

1.1 stat函数

1.2 access函数 

1.3 chmod函数

1.4 truncate函数 

Linux编程基础 3.1:进程管理

1.1 创建进程

1.2 创建多个进程

1.3 进程的执行顺序:利用sleep函数,暂缓进程执行


Linux编程基础 2.2:文件操作

一、函数

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

运行结果如下:  

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。

Linux编程基础 3.1:进程管理

fork()
exec函数族
wait()
exit()

1.1 创建进程

#include <unistd.h>
pid_t fork(void);

功能:创建进程;函数执行后,系统会创建一个与原进程几乎相同的进程,之后父子进程都继续执行。

返回值说明:

  • 成功:返回两个值,子进程创建成功后,原程序会被复制,就有了两个fork函数。父进程的fork函数会返回子进程的pid,子进程的fork函数会返回0.
  • 不成功:若子进程创建失败,原程序不会复制,父进程的fork函数返回-1。【案例1】使用stat函数获取文件属性,并输出文件的大小。

【案例 1】使用fork函数创建一个进程,创建成功后父子进程分别执行不同的功能。

test_fork.c
#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

运行结果如下:

 

【思考 1】多次执行test_fork会发现,child process后输出的ppid不等于parent process的pid,而等于1。请说明原因。

父进程终止于子进程之前,而此时子进程并未终止,子进程成为“孤儿进程”,转而由init进程来接收,init优先级高,故导致这种情况。

1.2 创建多个进程

上面的案例是创建一个子进程,如果要创建多个子进程呢?
可否对上面的案例进行修改,进行简单的循环即可:

int i;
for(i = 0; i < 2; i ++){
	tempPid = fork();
}//of for i

    每次调用fork函数,系统会复制原程序
    i=0,第一次循环,会有两份test_fork文件
    i=1,第二次循环,第一份test_fork文件又会有两份test_fork文件,第二份test_fork文件也会有两份
    每一次循环,进程的总数是当前进程数量的两倍,2次循环则为 2 2 = 4 2^2 = 4 22=4个进程。

【解决方法】:如果只希望父进程可以创建新进程,则在for循环中添加一个判断:若当前进程不是父进程,则跳出循环。

【案例 2】

test2.c
#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
		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

 运行结果如下:

【思考 2】:案例2的输出结果有如下问题:
(1)子进程的编号不是递增的;

因为进程的优先级相同,子进程本应由父进程回收,但当子进程被创建后,进程间共同竞争系统资源,父子进程会发生抢占现象,顺序取决于抢占的结果,而非我们所想的简单逻辑顺序。
(2)终端提示符后面仍然有子进程信息打印,而命令提示符在最后一行的开头闪烁。
这是为什么?

因为bash命令在系统下也为进程,参与父子进程竞争系统资源,执行顺序由CPU调用而定。

1.3 进程的执行顺序:利用sleep函数,暂缓进程执行 

test3.c
#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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值