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

本文探讨了文件操作中的关键函数,如stat用于获取文件属性,access检查权限,chmod修改权限,以及fork函数创建和管理子进程。还介绍了如何避免子进程无限递归的问题,并展示了如何使用sleep控制进程执行顺序。
摘要由CSDN通过智能技术生成

文件操作函数

1.stat函数

用于获取文件属性,包括文件的文件名、文件大小、文件类型等等

#include <sys/stat.h>
int stat(const char *path, struct stat *buf);

参数path为文件的路径(同目录下为文件名);参数buf即接受文件所拥有的属性。

2.access()

用于测试文件的某些权限是否存在

#include <unistd.h>
int access(const char *pathname, int mode);

参数pathname为文件名;

参数mode取值有4个分别为:R_OK, W_OK, X_OK, F_OK;前3个是测试文件是否具有读、写、执行权限,最后一个测试文件是否存在。

3.chmod()

修改文件的访问权限,与Linux中chmod差不多

#include <sys/stat.h>
int chmod(const char *path, mode_t mode);

参数path为路径名;参数mode为需要修改的权限

4.truncate()

用于修改文件的大小,如果修改后文件大小比起始小了,文件的部分数据会被删除,其功能与lseek函数类似;

#include <sys/stat.h>
int truncate(const char *path, off_t length);

参数说明:

  • path:路径名;
  • length:设置文件大小。

返回值说明:

  • 成功:0;
  • 不成功:-1并设置errno。

进程

1.子进程创建函数:fork()

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

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

创建案例:

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

pid是目前进程的进程ID,ppid是父进程的进程ID,所以child的ppid的值与parent的pid值相同。

多次执行test_fork会发现,child process后输出的ppid不等于parent process的pid,而等于1,这是由于父进程先于子进程终止,子进程变成“孤儿进程”,后面由init进程来接收

多个子进程的创建

int i;
for(i = 0;i < 3 ; i++){
   pid=fork();
}

以上代码会出现一个问题,fork()创建了一个子进程以后在子程序中还会进行循环,那么在第二次循环中子进程也会创建进程,就会出问题,我们的本意是想要父进程创建多个子进程,仅此而已。而现在的情况是父进程创建多个子进程,这些子进程也在创建属于他们自己的子进程。
正确代码:

test_fork2.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

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

利用sleep函数,暂缓进程执行

test_fork3.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(5);
   	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、付费专栏及课程。

余额充值