橙色
dup函数
- int dup(int oldfd); //复制文件描述符
/*
#include <unistd.h>
int dup(int oldfd);
作用:复制一个新的文件描述符
fd=3, int fd1 = dup(fd),
fd指向的是a.txt, fd1也是指向a.txt
从空闲的文件描述符表中找一个最小的,作为新的拷贝的文件描述符
*/
如下图,文件描述符标的前三位都是默认被占据,每出现一个新的文件描述符,都会从当前的文件描述符表中空闲的位置分配一个最小的号。
下面这段代码中,首先利用open新建了一个txt文件,然后dup函数复制出了一个文件描述符fd1。打印出两个文件描述符的值,发现是3和4,这与上面所说相吻合。首先fd=3,再创建了一个文件描述符fd1,就从当前文件描述符表中找了一个未分配的最小的,也就是4。
接着关闭fd,通过fd1写入内容,发现确实可以通过利用dup复制出来的文件描述符,对原文件描述符所指向的文件进行操作。其实复制出来的文件描述符就是指向原文件
#include <unistd.h>
#include <stdio.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
int main() {
int fd = open("a.txt", O_RDWR | O_CREAT, 0664);
int fd1 = dup(fd);
if(fd1 == -1) {
perror("dup");
return -1;
}
printf("fd : %d , fd1 : %d\n", fd, fd1);
close(fd);
char * str = "hello,world";
int ret = write(fd1, str, strlen(str));
if(ret == -1) {
perror("write");
return -1;
}
close(fd1);
return 0;
}
dup2函数
- int dup2(int oldfd,int newfd);//重定向文件描述符
/*
#include <unistd.h>
int dup2(int oldfd, int newfd);
作用:重定向文件描述符
oldfd 指向 a.txt, newfd 指向 b.txt
调用函数成功后:newfd 和 b.txt 做close, newfd 指向了 a.txt
oldfd 必须是一个有效的文件描述符
oldfd和newfd值相同,相当于什么都没有做
dup2的返回值与newfd相同,在后续关闭文件描述符时只需要关闭newfd即可
*/
下面的代码通过open创建了1.txt和2.txt。fd指向1.txt,fd1指向2.txt。通过dup2函数,使fd1指向了fd所指向的文件(也就是1.txt),当然,fd仍旧指向1.txt没有改变。接着,通过向fd1所指向的文件写入内容,验证了在通过dup2函数后,fd1指向了1.txt。
同时,通过打印fd、fd1和dup2函数的返回值fd2,验证了fd1和fd2相等。
最后关闭了fd和fd1.
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <fcntl.h>
int main() {
int fd = open("1.txt", O_RDWR | O_CREAT, 0664);
if(fd == -1) {
perror("open");
return -1;
}
int fd1 = open("2.txt", O_RDWR | O_CREAT, 0664);
if(fd1 == -1) {
perror("open");
return -1;
}
printf("fd : %d, fd1 : %d\n", fd, fd1);
int fd2 = dup2(fd, fd1);
if(fd2 == -1) {
perror("dup2");
return -1;
}
// 通过fd1去写数据,实际操作的是1.txt,而不是2.txt
char * str = "hello, dup2";
int len = write(fd1, str, strlen(str));
if(len == -1) {
perror("write");
return -1;
}
printf("fd : %d, fd1 : %d, fd2 : %d\n", fd, fd1, fd2);
close(fd);
close(fd1);
return 0;
}