加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

objective-c – 如何将STDOUT重定向到NSTextView?

发布时间:2020-12-16 03:41:37 所属栏目:百科 来源:网络整理
导读:有人能告诉我如何将Stdout重定向到NSTextView吗? 以及NSLog打印的信息是否属于std? 谢谢 解决方法 下面的代码使用dup2将stdout插入NSPipe对象的写端.使用GCD调度源观察读取端,该源从管道读取数据并将其附加到textview. NSPipe* pipe = [NSPipe pipe];NSFil
有人能告诉我如何将Stdout重定向到NSTextView吗?

以及NSLog打印的信息是否属于std?

谢谢

解决方法

下面的代码使用dup2将stdout插入NSPipe对象的写端.使用GCD调度源观察读取端,该源从管道读取数据并将其附加到textview.
NSPipe* pipe = [NSPipe pipe];
NSFileHandle* pipeReadHandle = [pipe fileHandleForReading];
dup2([[pipe fileHandleForWriting] fileDescriptor],fileno(stdout));
dispatch_source_t source = dispatch_source_create(DISPATCH_SOURCE_TYPE_READ,[pipeReadHandle fileDescriptor],dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0));
dispatch_source_set_event_handler(source,^{
    void* data = malloc(4096);
    ssize_t readResult = 0;
    do
    {
        errno = 0;
        readResult = read([pipeReadHandle fileDescriptor],data,4096);
    } while (readResult == -1 && errno == EINTR);
    if (readResult > 0)
    {
        //AppKit UI should only be updated from the main thread
        dispatch_async(dispatch_get_main_queue(),^{
            NSString* stdOutString = [[NSString alloc] initWithBytesNoCopy:data length:readResult encoding:NSUTF8StringEncoding freeWhenDone:YES];
            NSAttributedString* stdOutAttributedString = [[NSAttributedString alloc] initWithString:stdOutString];
            [self.logView.textStorage appendAttributedString:stdOutAttributedString];
        });
    }
    else{free(data);}
});
dispatch_resume(source);

NSLog(@“…”)不输出到stdout – 它打印到stderr.如果要将其重定向到文本视图,请更改

dup2([[pipe fileHandleForWriting] fileDescriptor],fileno(stdout));

dup2([[pipe fileHandleForWriting] fileDescriptor],fileno(stderr));

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读