您好,登錄后才能下訂單哦!
函數原型:
#include
int dup(int oldfd);
int dup2(int oldfd,int newfd);
dup用來復制oldfd所指的文件描述符。但復制成功時返回最小的尚未被使用的文件描述符。若有錯誤則返回-1,錯誤代碼存入errno中。返回的新文件描述符和參數oldfd指向同一個文件,共享所有的鎖定,讀寫指針,和各項權限或標志位。
1.打開一個新文件
2.關掉標準輸出文件符
3.調用dup給文件描述符
4.此時文件描述符變為1
5.將所要打印數據重定向到文件中
#include<stdio.h> #include<stdlib.h> #include<errno.h> #include<string.h> #include<unistd.h> #include<fcntl.h> #include<sys/stat.h> #define _PATH_FILE_ "./log" int main() { umask(0); int fd=open(_PATH_FILE_,O_CREAT|O_RDWR,0644); if(fd<0){ perror("open"); return 1; } close(1); int new_fd=dup(fd); close(fd); int count=0; while(count++<100) { printf("helo world\n"); } fflush(stdout);//must,printf重定向后變為全緩沖,緩沖區滿才會刷新,導致不會寫入文件 close(new_fd); return 0; }
dup2
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<fcntl.h> #include<sys/types.h> #include<sys/stat.h> #define _FILE_ "./log" int main() { umask(0); int fd=open(_FILE_,O_CREAT|O_WRONLY,0644); if(fd<0){ perror("open"); return 1; } close(1);//isn't necessary int ret=dup2(fd,1); if(ret<0){ perror("dup2"); return 2; } char buf[1024]; while(1) { memset(buf,'\0',sizeof(buf)); fgets(buf,sizeof(buf)-1,stdin);//stdin是FILE*,0是文件描述符 if(strncmp(buf,"quit",4)==0)//buf have '\n',you can buf[_s-1]='\0' break; printf("hello:%s",buf); } close(fd); return 0; }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。