重定向动态库中的输出

问题已解决,解决方案如下:
1.一个全局的文件描述符用来记录原来的标准输出文件描述符
2.封装俩个函数,功能分别是打开和关闭标准输出文件描述符的函数
3.封装一个输出函数,函数内部调用第二步封装的打开函数,然后输出,接着调用关闭函数
4.main函数逻辑。首先调用第二步封装的关闭函数,接着如需输出信息则调用第三步封装的输出函数,代码如下:

#include<stdio.h>
#include <stdlib.h>
#include<unistd.h>
#include <stdarg.h>

int fd;
void openStdout()
{
    dup2(fd, 1);
}
void closeStdout()
{
    dup2(1,fd);
    close(1);
}

void privatePrint(const char *format, ...)
{
    //打开stdout
    openStdout();
    va_list vl_p;
    char msg_buf[1024] = { 0 };//如传入参数大于1024,会被丢弃大于1024的部分
    va_start(vl_p, format);
    if (vsnprintf(msg_buf, sizeof(msg_buf), format, ap) < 0)
    {
        return;
    }
    va_end(vl_p);
    printf("%s\n", msg_buf);

    //关闭stdout
    closeStdout();

    return;
}

int main(int argc,char * argv[])
{
    //关闭输出
    closeStdout();
    printf("hello world\n");//无法输出

    //如需输出,使用封装函数
    for (int i = 0; i < argc; i++)
    {
        privatePrint("%d  str:%s\n",i, argv[i]);//正常输出
    }
    return 0;

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值