[Linux]Linux printf 輸出重定向


方法一

 #include <stdlib.h>  
 #include <stdio.h>  
 #include <unistd.h>  
 #include <sys/stat.h>  
 #include <fcntl.h>  
   
   
 int main()  
 {  
     fflush(stdout);  
     setvbuf(stdout,NULL,_IONBF,0);  
     printf("test stdout\n");  
     int save_fd = dup(STDOUT_FILENO); // 保存標准輸出 文件描述符 注:這里一定要用 dup 復制一個文件描述符. 不要用 = 就像是Winodws下的句柄.  
     int fd = open("test1.txt",(O_RDWR | O_CREAT), 0644);  
     dup2(fd,STDOUT_FILENO); // 用我們新打開的文件描述符替換掉 標准輸出  
     printf("test file\n");  
       
     //再恢復回來標准輸出. 兩種方式  
     //方法1 有保存 標准輸出的情況  
     //dup2(save_fd,STDOUT_FILENO);  
       
     //方法2 沒有保存 標准輸出的情況  
      int ttyfd = open("/dev/tty",(O_RDWR), 0644);  
     dup2(ttyfd,STDOUT_FILENO);  
     printf("test tty\n");  
 }  

方法二

#include <stdlib.h>   
#include <stdio.h>   
#include <unistd.h>   
  
 int main()  
 {  
     fflush(stdout);  
     setvbuf(stdout,NULL,_IONBF,0);  
     printf("test stdout\n");  
     freopen("test1.txt","w",stdout); //注: 不要使用這類的代碼 stdout = fopen("test1.txt","w");   這樣的話輸出很詭異的. 最好使用  freopen 這類的函數來替換它.  
     printf("test file\n");  
     freopen("/dev/tty","w",stdout);  
     printf("test tty\n");  
 }  

到這里我們就可以輕松解決 prinft  不輸出到屏幕的問題了.  

不外乎兩種情況.    

第1 標准輸出被重定向了.  

第2 輸出緩沖區的問題. 就是 我們上兩例中 開頭的兩行代碼了.  

 fflush(stdout); //  刷新一下緩沖區 讓它馬上輸出.  在printf 之后調用它,就會馬上輸出了.  

 setvbuf(stdout,NULL,_IONBF,0); //如果你嫌上個方法麻煩, 就使用這個函數. 直接將緩沖區禁止了. 它就直接輸出了.  

這兩個函數都是有關流緩沖區的. 具體使用和說明網上有很多.   我只說一下什么是流緩沖區, 是做什么用的.  操作系統為減少 IO操作 所以設置了緩沖區.  等緩沖區滿了再去操作IO. 這樣是為了提高效率.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM