linux下dup函数,Linux dup dup2函数理解
在linux中,我們需要復制文件描述符,下面是我對文件描述符的理解
int dup(int fd); // 復制一個已經存在的文件描述符,如果成功,返回復制成功后的文件描述符,失敗返回-1
int dup(int fd, int fd2); // 復制一個文件描述符,fd表示已經存在的打開的文件描述符,fd2是指定新的文件描述符,如果fd2等于fd,則直接返回,如果fd2存在并且打開,則先close(fd2)后,重新打開,這樣fd2和fd就指向了同一個文件(共享打開的文件),如果fd2不存在或者沒有打開,則打開fd2,并且指向fd所指向的文件。函數的返回值和fd2一致。該函數可以實現文件的重定位。
每個進程都有一個文件描述符表,每個描述符占用一個描述符項,每個文件描述符可以描述成這樣
struct fileDescription {
int index;
void *pointer;
};
除了整形,還有一個指針,指向文件表,內核為所有打開文件維持一張文件表,每個文件表項包含:
1)文件狀態標志(讀、寫、添寫、同步和非阻塞等)
2)當前文件的偏移量
3)指向該文件v節點表項的指針
v節點表中包含了文件所有者、文件長度、文件所在的設備、指向文件實際數據塊在磁盤上所在位置的指針等等
下面給出一個例子:
#include
#include
#include
#include
#include
#include
using namespace std;
int main()
{
cout << "Hello world!" << endl;
int fd = open("a.txt", O_RDWR | O_CREAT | O_APPEND, S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH);
if (fd < 0)
{
printf("open a.txt failed, fd = %d\n", fd);
return -1;
}
printf("open a.txt success, fd = %d\n", fd);
fflush(stdout);
// 復制標準輸出的文件描述符
int nfd = dup(STDOUT_FILENO);
int fileFd = dup2(fd, STDOUT_FILENO);
if (fileFd < 0)
{
printf("dup2 stdout_fileno failed, fileFd = %d\n", fileFd);
return -1;
}
printf("重定向標準輸出到a.txt, fileFd = %d\n", fileFd);
// 將STDOUT_FILENO復制到fd后,fd并沒有發生變化,依然可以通過它寫入到a.txt中
const char *pStr = "write string through fd\n";
write(fd, pStr, strlen(pStr));
fileFd = dup2(nfd, fileFd);
if (fileFd < 0)
{
printf("dup2 reback stdout_fileno failed\n");
return -1;
}
printf("print back to stdout standard, fileFd = %d\n", fileFd);
// 上面使用dup2的時候,STDOUT_FILENO是存在并打開的,我們來測試下不存在的文件描述符的情況
fileFd = dup2(fd, 20);
if (fileFd < 0)
{
printf("dup2不存在的文件描述符失敗, fileFd = %d\n", fileFd);
}
else
{
printf("dup2不存在的文件描述符成功, fileFd = %d\n", fileFd);
const char *pStr = "write string through fileFd\n";
write(fileFd, pStr, strlen(pStr));
}
close(nfd);
close(fileFd);
return 0;
}
文件指針是關鍵,標志兩個文件描述符是否一致,看文件指針是否一致即可,如果兩個或者多個文件描述符指向同一個文件表,那么對他們的操作是對同一個文件進行操作
總結
以上是生活随笔為你收集整理的linux下dup函数,Linux dup dup2函数理解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux ip head check
- 下一篇: Linux内核链表 内存屏障,为什么需要