IOS 日志重定向的開啟與關(guān)閉

1.開啟日志定向


70D46065-EBC3-4EF9-BCD0-EE3F72491196.png

2.關(guān)閉日志定向(在你想關(guān)閉的時間地點寫入即可)

C896A801-8353-489F-9433-1FBF3309256B.png

以下為參考博客地址:http://blog.csdn.net/lurendetiankong/article/details/53487206
/本文通過標準輸出的重定向和恢復(fù)的過程來解釋dup和dup2的使用方法/

include <stdio.h>

include <unistd.h>

include <fcntl.h>

//STDIN_FILENO標準輸入描述符(0)
//STDOUT_FILENO標準輸出描述符(1)
//STDERR_FILENO標準錯誤描述符(2)
int main(void)
{
int n_fd;
int s_fd;
int fd = open("dup.txt", O_RDWR);
if(fd < 0) {
perror("open error");
exit(0);
}
s_fd = dup(STDOUT_FILENO);//文件描述符的賦值此時s_fd和STDOOUT_FILENO指向同一個內(nèi)核文件表項
n_fd = dup2(fd, STDOUT_FILENO);//標準輸出的重定向,此時進程文件表項中STDOUT_FILENO的文件指針發(fā)生變化,變?yōu)楹蚮d的文件指針指向相同的一個內(nèi)核文件表
//項,n_fd是新的文件描述符,STDOUT_FILENO(1)是對n_fd大小的設(shè)置
//注:n_fd和STDOUT_FIELNO是代表同一個進程文件表項
if(n_fd < 0) {
perror("dup2 error");
exit(0);
}

write(STDOUT_FILENO, "hello1", 6);//在dup.txt文件中寫入六個字節(jié)
dup2(s_fd, STDOUT_FILENO);//對標準輸出重定向,此時進程文件表項中STDOUT_FILENO的文件指針發(fā)生變化,和s_fd共享一個內(nèi)核表項,即恢復(fù)為原來的標準輸出
write(STDOUT_FILENO, "hello2", 6);//在終端輸出6個字節(jié)
close(fd);
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容