1.dup2
#include "csapp.h"
int main(int argc, char *argv[])
{
int fd1, fd2, fd3;
char c1, c2, c3;
char *fname = argv[1];
fd1 = open(fname, O_RDONLY, 0);
fd2 = open(fname, O_RDONLY, 0);
fd3 =open(fname, O_RDONLY, 0);
dup2(fd2, fd3);
read(fd1, &c1, 1);
read(fd2, &c2, 1);
read(fd3, &c3, 1);
printf("c1 = %c, c2 = %c, c3 = %c\n", c1, c2, c3);
close(fd1);
close(fd2);
close(fd3);
return 0;
}
由运行结果可知,最开始打开一个新文件,并且接收到一个叫fd1的文件描述符,由read(fd1,&c1,1)可知,c1读取的就是文件中的第一个字符。因为调用了dup2(fd2,fd3),fd3与fd2其实是一样的,所以c2其实是返回的fd3中的第一个字符,并且fd3所指向的文件并没有关闭,所以c3其实读取的应该是fd3所指向的文件的第二的字符。所以最后运行结果应该是c1=a,c2=a,c3=b。
2.dup
#include "csapp.h"
int main(int argc, char *argv[])
{
int fd1, fd2, fd3;
char *fname = argv[1];
fd1 = open(fname, O_CREAT|O_TRUNC|O_RDWR, S_IRUSR|S_IWUSR);
write(fd1, "pqrs", 4);
fd3 = open(fname, O_APPEND|O_WRONLY, 0);
write(fd3, "jklmn", 5);
fd2 = dup(fd1); /* Allocates new descriptor */
write(fd2, "wxyz", 4);
write(fd3, "ef", 2);
close(fd1);
close(fd2);
close(fd3);
return 0;
}
通过运行:
最开始的文件里面的内容是:
运行之后,文件里面的内容变为:
由程序可知,首先是将fd1指向那个文件,然后通过write像fd1写入pqrs,然后fd3又指向这个文件,并且在文件后添加写入jklmn这5个字符,然后通过调用fd2=dup(fd1),这个就是将fd1拷贝到fd2来,后来的两个write就是默认为在fd1后面添加字符,所以中间添加的jklmn这5个字符就被覆盖了,所以最后结果是“pqrswxyznef”