1、man 2 dup,一般就是用dup和dup2两个
都指向old打开的那个文件,动态文件,操作这两个,其实都是old fd打开的那个,其实构成了文件共享
#include<stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <string.h> int main(void) { int fd1 = -1, fd2 = -1; fd1 = open("a.txt", O_RDWR | O_CREAT | O_TRUNC, 0644); printf("fd1 = %d.\n", fd1); fd2 = dup(fd1); printf("fd2 = %d.\n", fd2); close(fd1); return 0; }
dup不能指定复制的fd的大小,基本就是空闲的最小的,dup返回的fd都指向打开的动态文件,操作这两个fd,其实都是oldfd打开的文件,其实构成了一个文件共享。oldfd和dup返回的fd 是分别写还是接续写。
缺陷,并不能指定newdup的大小,所以根据实际使用情况,判断使用dup还是dup2
之前讲过0/1/2是标准输入/标准输出/标准错误,
关闭1 close(1),等于关闭了标准输出,dup给oldfd复制了1,标准输出的重定位 newfd = 1,以后输出到标准输出的信息,就可以到a.txt中查看
#include<stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <string.h> int main(void) { int fd1 = -1, fd2 = -1; fd1 = open("a.txt", O_RDWR | O_CREAT | O_TRUNC, 0644); printf("fd1 = %d.\n", fd1); close(1);//关闭标准输出 fd2 = dup(fd1);//标准输出重映射 printf("fd2 = %d.\n", fd2); close(fd1); return 0; }可以看出 我们可以使用close 和 dup来重定位(改变输出路径)
dup2跟dup的作用是一样的,但是允许用户指定新的fd的数字
关键是要学会看man手册,会写代码测试api的使用
#include<stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <string.h> #define FILENAME "a.txt" int main(void) { int fd1 = -1, fd2 = -1; fd1 = open(FILENAME, O_RDWR | O_CREAT | O_TRUNC, 0644); //close(1); printf("fd1 = %d.\n", fd1); fd2 = dup2(fd1, 18); printf("fd2 = %d.\n", fd2); close(fd1); return 0; }
看看分别写入还是接续写入
#include<stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <string.h> #define FILENAME "a.txt" int main(void) { int fd1 = -1, fd2 = -1; fd1 = open(FILENAME, O_RDWR | O_CREAT | O_TRUNC, 0644); //close(1); printf("fd1 = %d.\n", fd1); fd2 = dup2(fd1, 18); printf("fd2 = %d.\n", fd2); while(1) { write(fd1, "aa", 2); sleep(1); write(fd2, "bb", 2); } close(fd1); return 0; }
输出结果显示是接续显示的。
虽然两个FD是不同的,但是指向同意文件,交叉写入的时候,结果接续写入的,应该是自己写代码测试
Linux支持一个符号>来重定位打印信息
ls > a.txt 将打印信息重定位到a.txt中,输出结果重定位符号
这个就是close(1)+dup来实现的,还有open打开一个文件,原来就是这么实现的