gpt4 book ai didi

windows - 在 Windows 上运行任意子进程并仍然干净地终止?

转载 作者:可可西里 更新时间:2023-11-01 12:27:30 24 4
gpt4 key购买 nike

我有一个应用程序 A,我希望它能够调用用户在配置文件中指定的任意其他进程。

批处理脚本 B 就是这样一个进程,用户希望 A 调用它。B 设置一些环境变量,显示一些消息并调用编译器 C 来完成一些工作。

Windows 是否为任意进程的干净终止提供了标准方法?假设 A 在控制台中运行并收到 CTRL+C。它可以将此传递给 B 和 C 吗?假设A在一个窗口中运行,用户试图关闭窗口,是否可以取消B和C?

TerminateProcess 是一个选项,但不是一个很好的选项。如果 A 在 B 上使用 TerminateProcess,C 会继续运行。如果 C 长时间运行,这可能会导致严重的问题,因为我们可能会启动另一个 C 实例来操作相同的文件,而 C 的第一个实例仍在 secret 工作。此外,TerminateProcess 不会导致干净退出。

GenerateConsoleCtrlEvent 听起来不错,当一切都在控制台中运行时可能会起作用,但文档说您只能将 CTRL+C 发送到您自己的控制台,因此如果 A 在窗口中运行则无济于事。

在 Windows 上有什么等同于 SIGINT 的东西吗?我很想找到这样一篇文章:http://www.cons.org/cracauer/sigint.html适用于 Windows。

最佳答案

我想我在这个问题上有点晚了,但无论如何我都会为遇到同样问题的人写一些东西。

我的问题是类似的,我希望我的应用程序是一个 GUI 应用程序,但执行的进程应该在后台运行,没有附加任何交互式控制台窗口。

我设法使用 GenerateConsoleCtrlEvent() 解决了这个问题。棘手的部分只是文档并没有真正清楚地说明如何使用它以及它的陷阱。

我的解决方案基于所描述的内容 here .但这也没有真正解释所有的细节,所以这里是关于如何让它工作的细节。

  1. 创建一个新的帮助应用程序“Helper.exe”。此应用程序将位于您的应用程序(父)和您希望能够关闭的子进程之间。它还将创建实际的子进程。您必须有这个“中间人”进程,否则 GenerateConsoleCtrlEvent() 将失败。

  2. 使用某种 IPC 机制从父进程向助手进程传达助手应该关闭子进程的信息。当帮助程序获得此事件时,它会调用“GenerateConsoleCtrlEvent(CTRL_BREAK, 0)”,它会关闭自身和子进程。我自己为此使用了一个事件对象,父进程在想要取消子进程时完成。

要创建您的 Helper.exe,请使用 CREATE_NO_WINDOW 和 CREATE_NEW_PROCESS_GROUP 创建它。在创建子进程时,创建它时不带标志 (0),这意味着它将从其父进程派生控制台。如果不这样做,将导致它忽略该事件。

每一步都这样做很重要。我一直在尝试各种不同的组合,但这种组合是唯一有效的组合。您不能发送 CTRL_C 事件。它会返回成功,但会被过程忽略。 CTRL_BREAK 是唯一有效的。并不重要,因为它们最终都会调用 ExitProcess()。

您也不能使用子进程 ID 的进程分组 ID 直接调用 GenerateConsoleCtrlEvent() 以允许辅助进程继续运行。这也会失败。

我花了一整天的时间试图让它工作。此解决方案对我有用,但如果有人有任何其他要添加的内容,请添加。我去了所有其他网络,发现很多人都有类似的问题,但没有明确解决问题的方法。 GenerateConsoleCtrlEvent() 的工作原理也有点奇怪,所以如果有人知道更多详细信息,请分享。

关于windows - 在 Windows 上运行任意子进程并仍然干净地终止?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1453520/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com