`

tcl 中的exec运行第三方,怎么同时打印第三方信息到stdout 。版本2

 
阅读更多

假的长时间运行的程序:

proc long_job {} {
puts "long_job start"
puts "- after 1s start"
after 1000
puts "- after 1s start"
after 1000
puts "- after 1s start"
after 1000
puts "- after 1s start"
after 1000
puts "- after 1s start"
after 1000
puts "- after 2s start"
after 2000
puts "long_job end"
}

long_job

 

 

实现:

 

namespace eval my {}
proc my_jobReader {pipe} {
    if [eof $pipe] {
        if [catch {close $pipe} err] {
        puts $err
        set my::jobError "true"
        }
        set my::jobDone "true"
        return
    }
    puts [gets $pipe]
}
proc my_doJob {job} {
    set my::jobDone "false"
    set my::jobError "false"
    set pipe [open |$job]
    fileevent $pipe readable [list my_jobReader $pipe]
    vwait my::jobDone
    if {$my::jobError == "true"} {
        return -code error
    }
}


puts "general run"
catch {exec tclsh long_job.tcl} out
puts $out;
puts "general run end"

puts ""
puts ""
puts ""

puts "do my_doJob"
my_doJob {tclsh long_job.tcl}
puts "do my_doJob end"

 

 

 

运行:

tclsh t.tcl

 

可以发现,general run是运行完才打印的。

使用my_doJob可以运行同时打印。

分享到:
评论

相关推荐

    Node.js-使用原生系统通知在node.js中不需要第三方库

    标题中的“Node.js-使用原生系统通知在node.js中不需要第三方库”表明我们要讨论的是如何在Node.js环境中利用操作系统自带的功能发送系统通知,而无需依赖任何外部的npm包。这种做法可以减少项目的依赖,提高运行...

    Makefile添加spdlog第三方库示例工程.tar.gz

    本文将深入探讨如何在Makefile中添加并使用第三方库,以`spdlog`为例,这是一个广泛使用的C++日志库,提供高性能且易于使用的日志功能。在Ubuntu 18.04系统中,我们将学习如何集成`spdlog`到你的项目中。 首先,...

    python 打印信息重定向 GUI界面 ,PyQt5实时显示调用外部程序的实时输出显示,subprocess.Popen stdout输出重定向,备注详细!

    python 打印信息重定向 GUI界面 ,PyQt5实时显示调用外部程序的实时输出显示,subprocess.Popen stdout输出重定向,备注详细!

    tcl语言资料/ug后处理的tcl语言

    在 TCL 语言中,有许多特殊变量用于存储各种信息。这些变量包括: * argc:表示命令行参数的个数 * argv:表示包含命令行参数的列表 * argv0:表示被解释的文件或由调用脚本的名称的文件名 * env:表示环境变量数组...

    重定向标准输出STDOUT的demo

    标准输出(STDOUT)通常是指程序运行时输出的信息,如打印在控制台的结果。当我们说“重定向标准输出STDOUT”,意味着我们将这些输出信息导向到别处,而不是直接显示在终端上。在本示例“重定向标准输出STDOUT的demo...

    Go-exec一个golang包用于与一个在后台运行的进程进行交互

    Go-exec是Golang标准库中的一个包,它提供了一种方式来执行外部程序,并与这些程序进行交互。这个包在开发过程中非常有用,特别是在需要控制和管理其他系统进程时。让我们深入了解一下`os/exec`包的功能、用法以及...

    Node.js检查stdout或stderr是否是交互式的

    总结来说,检查`stdout`或`stderr`是否是交互式的关键在于使用`process.stdout.isTTY`和`process.stderr.isTTY`属性,以及在必要时引入第三方库如`sindresorhus/is-interactive`来确保跨平台兼容性。理解这一点对于...

    Tcl输入输出重定向Demo

    在操作系统层面,程序的输入和输出通常通过标准输入(stdin)、标准输出(stdout)和标准错误(stderr)三个流来管理。重定向允许我们将这些流指向不同的位置,比如文件、网络连接甚至是其他进程的输入输出。在Tcl中...

    前端开源库-exec

    2. **命令输出**:`exec`返回的`ChildProcess`对象有`stdout`和`stderr`属性,可以监听这两个事件来获取命令的输出。 3. **回调函数**:通常我们会提供一个回调函数,其中包含两个参数——错误对象和结果数据。只有...

    外部exe程序嵌入到Qt界面,点击按钮在QT中运行显示

    在本文中,我们将深入探讨如何将外部的exe可执行程序集成到Qt界面中,并通过点击按钮在Qt界面上实现程序的运行与显示。Qt是一个功能强大的C++图形用户界面库,广泛应用于桌面应用开发,而将外部应用程序嵌入Qt界面...

    Go-piper-一个旨在通过TLS从进程立即共享stdout的小devtool工具

    在 Go-piper 中,TLS 被用来加密 stdout 的传输,确保在共享过程中不会被第三方窃取或篡改,增强了数据的隐私保护。 Go-piper 的工作原理大致如下:首先,它创建一个本地服务器,该服务器监听特定端口并接收来自...

    stdout.txt

    从给定的文件信息来看,主要涉及的知识点集中在C++编程中的文件重定向、标准输入输出流(stdin, stdout, stderr)的管理以及Windows环境下的多线程编程。以下是对这些知识点的详细解析: ### 文件重定向与标准流...

    Windows管道(Pipe)重定向stdout,stderr,stdin

    有时我们需要重定向stdout,stderr,stdin。比如:将输出写入文件,又或者我们要将命令行程序输出结果显示到Windows对话框中。源码示范如何在Windows中实现,封装了几个简单易用的函数。

    Python中的sys.stdout.write实现打印刷新功能

    ### Python中的`sys.stdout.write`实现打印刷新功能详解 #### 前言 在Python编程过程中,有时我们需要在控制台或终端中实时显示一些信息,比如进度条、定时任务的状态等,而不需要每次打印信息时都换行。这种情况...

    java执行可执行文件,Runtime.exec、ProcessBuilder、commons-exec

    本文将详细介绍三种常用的方法:`Runtime.exec()`、`ProcessBuilder`以及`commons-exec`库。 #### 1. 使用`Runtime.exec()` `Runtime.exec()`是最为传统且简单的执行外部程序的方法。它可以启动一个新的进程,并...

    JAVA StdOut工具类下载

    分享一个JAVA StdOut的工具类,此工具类主要用于输出等一系列变换,推荐大家在我博客百度云盘下载。

    Python使用Paramiko控制linux第三方库.docx

    在上述示例中,我们使用了try-except语句捕获异常并打印错误信息。 5. **关闭连接**: 当完成所有操作后,务必关闭SSH连接以释放资源: ```python ssh_client.close() ``` 在实际项目中,为了代码的可复用性,...

    Qt实现简单的qDebug输出到日志文件

    本教程将详述如何使用Qt自带的`qDebug()`函数将其输出重定向到日志文件,而不依赖任何第三方库,适用于小型项目的需求。 首先,理解`qDebug()`函数。它是Qt提供的一个宏,用于方便地输出调试信息。默认情况下,这些...

    详解使用python的logging模块在stdout输出的两种方法

    这种方式更加灵活,因为它允许我们在日志系统中添加多个不同的处理程序,比如同时将日志输出到文件和控制台。 ```python import sys import logging # 创建日志记录器 log = logging.getLogger() # 创建一个...

    前端开源库-catch-stdout

    `stdout`通常用于打印日志、调试信息或错误消息,`catch-stdout`能够帮助我们更好地控制和管理这些输出,以便在测试环境中避免干扰,并收集必要的测试数据。 `catch-stdout`库的核心功能是提供一种方式来拦截...

Global site tag (gtag.js) - Google Analytics