//open.c 文件
1.父进程中打开一个现有文件123.c,fork出一个子进程
2.子进程中调用execve函数,新的进程替换子进程
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <string.h>
void main()
{
int fd = open("123.c",O_RDONLY);
printf("%d\n",fd);
if(fd == -1)
{
perror("file open:\n");
close(fd);
return;
}
pid_t pid = fork();
if(pid == 0 )
{
char s[100];
memset(s,0,sizeof(s));
sprintf(s,"%d",fd);
char* argv[] = {"read",s,NULL};
if( -1 == execve("read",argv,NULL))
{
perror("execve failed!\n");
close(fd);
return;
}
}
if(pid >0)
{
printf("parent process\n");
close(fd);
return;
}
if(pid<0)
{
perror("fork failed:\n");
close(fd);
return;
}
}
//read.c
1.将fd 作为main 函数的参数传递给execve 调用的进程
2.读取父进程中打开的文件123.c,由于fork出的子进程与父进程共享文件描述符。只有父子进程中同时关闭fd才能真正关闭文件,因为当前对文件的引用计数为2。
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <unistd.h>
#include <string.h>
int main(int argc,char* argv[])
{
if(argc <2)
{
printf("no file to open for reading!\n");
return -1;
}
if(argv[1] == NULL)
{
printf("file does not exist!\n");
return EXIT_FAILURE ;
}
int fd = atoi(argv[1]);
printf("file description is %d\n",fd);
char buf[1024];
memset(buf,0,sizeof(buf));
read(fd,buf,sizeof(buf));
printf("%s\n",buf);
close(fd);
return EXIT_SUCCESS;
}
最后,附上makefile文件
.SUFFIXES:.c .o
CC=gcc
SRCS1=open.c
SRCS2=read.c
OBJS1=$(SRCS1:.c=.o)
OBJS2=$(SRCS2:.c=.o)
EXEC1=open
EXEC2=read
start:$(OBJS1) $(OBJS2)
$(CC) -o $(EXEC1) $(OBJS1)
$(CC) -o $(EXEC2) $(OBJS2)
@echo '---------------success---------------'
.c.o:
$(CC) -o $@ -c $<
.PHONY : clean
clean:
-rm -f $(OBJS1)
-rm -f $(OBJS2)
-rm -f core*
说明1:.PHONY意思表示clean是一个“伪目标”,。而在rm命令前面加了一个小减号的意思就是,也许某些文件出现问题,但不要管,继续做后面的事。
说明2:clean的规则不要放在文件的开头,不然,这就会变成make的默认目标,不成文的规矩是——“clean从来都是放在文件的最后”。