1.開啟日志定向
2.關(guān)閉日志定向(在你想關(guān)閉的時(shí)間地點(diǎn)寫入即可)
以下為參考博客地址:http://blog.csdn.net/lurendetiankong/article/details/53487206
/本文通過(guò)標(biāo)準(zhǔn)輸出的重定向和恢復(fù)的過(guò)程來(lái)解釋dup和dup2的使用方法/
include <stdio.h>
include <unistd.h>
include <fcntl.h>
//STDIN_FILENO標(biāo)準(zhǔn)輸入描述符(0)
//STDOUT_FILENO標(biāo)準(zhǔn)輸出描述符(1)
//STDERR_FILENO標(biāo)準(zhǔn)錯(cuò)誤描述符(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);//文件描述符的賦值此時(shí)s_fd和STDOOUT_FILENO指向同一個(gè)內(nèi)核文件表項(xiàng)
n_fd = dup2(fd, STDOUT_FILENO);//標(biāo)準(zhǔn)輸出的重定向,此時(shí)進(jìn)程文件表項(xiàng)中STDOUT_FILENO的文件指針發(fā)生變化,變?yōu)楹蚮d的文件指針指向相同的一個(gè)內(nèi)核文件表
//項(xiàng)草讶,n_fd是新的文件描述符滩届,STDOUT_FILENO(1)是對(duì)n_fd大小的設(shè)置
//注:n_fd和STDOUT_FIELNO是代表同一個(gè)進(jìn)程文件表項(xiàng)
if(n_fd < 0) {
perror("dup2 error");
exit(0);
}
write(STDOUT_FILENO, "hello1", 6);//在dup.txt文件中寫入六個(gè)字節(jié)
dup2(s_fd, STDOUT_FILENO);//對(duì)標(biāo)準(zhǔn)輸出重定向,此時(shí)進(jìn)程文件表項(xiàng)中STDOUT_FILENO的文件指針發(fā)生變化,和s_fd共享一個(gè)內(nèi)核表項(xiàng),即恢復(fù)為原來(lái)的標(biāo)準(zhǔn)輸出
write(STDOUT_FILENO, "hello2", 6);//在終端輸出6個(gè)字節(jié)
close(fd);
}