1

我第一次在这里发帖。

我用 borland c++ 构建了一个小型应用程序,它由商业第三方应用程序通过 shell 命令执行。然后,第二个应用程序会一直等待,直到它收到我的应用程序的退出代码。我想要做的是通过发送消息 wm_copydata 将“0”或“1”发送到第二个应用程序,以模仿退出代码。我这样做是因为我希望我的应用程序在不退出的情况下发送退出代码!这可能吗?

问题是数据永远不会到达,也不会被第二个接收应用程序处理。我实际上不确定第二个应用程序是否实现了处理 wm_copydata 消息的代码,我只是假设它确实......

感谢您的帮助,因为我正在尝试构建一个将我们部门不同供应商的不同软件相互连接的应用程序。这是我正在使用的代码:

void SendMyMessage(char* command)
{
HWND Hamilton_Window_Handle;
int len;
char title[254];
AnsiString stemp;
AnsiString hname = "HAMILTON RUN CONTROL";
Hamilton_Window_Handle = FindWindow(0,0);
while (Hamilton_Window_Handle != 0)
    {
    len = GetWindowText(Hamilton_Window_Handle, title, 255);
    stemp = UpperCase(title);
    if (AnsiPos(hname, stemp) > 0)
            {break;}
    Hamilton_Window_Handle = GetWindow(Hamilton_Window_Handle, GW_HWNDNEXT);
    }

COPYDATASTRUCT cds;
cds.dwData = 0;
cds.cbData = strlen(command) +1;
cds.lpData = command;
SendMessage(Hamilton_Window_Handle, WM_COPYDATA, 0, (LPARAM)&cds);
if(AnsiString(command) == "1")
    {
    Form1->Label1->Caption="Barcodes passed consistency check!";
    Form1->Label1->Font->Color = clGreen;
    }
else
    {

    Form1->Label1->Caption="Barcodes failed consistency check!";
    Form1->Label1->Font->Color = clRed;
    }
}
4

2 回答 2

0

除了@Adriano 所说的之外,您生成的进程不能在不先退出自身的情况下将退出代码返回到启动进程。毕竟,这就是为什么它被称为退出代码的原因。在进程终止之前,Windows 不会看到进程的退出代码。

于 2012-06-14T23:36:21.247 回答
0

简而言之:不,这是不可能的。WM_COPYDATA旨在将数据从一个应用程序传递到另一个应用程序,但两个应用程序都必须知道使用此消息。此外,他们必须为其数据共享一个接口。它不是自动的,您不能假设它确实如此,因为进程退出代码和此消息是不相关的(如果应用程序等待进程退出它为什么应该接受WM_COPYDATA?如果它接受该消息,那么它具有什么结构和目的?) . 如果其他人假设您的应用程序接受 WM_COPYDATA 而不是例如命令行参数,则为图像。您是否处理具有该含义的消息?

您可能需要的是fork()Unix 上可用的命令。Windows 不提供此功能,您可以尝试使用它来模仿它的行为,NtCreateProcess()但这可能非常棘手(而且我不知道它如何与复杂的 GUI 集成)。

一个可能的解决方案是创建一些共享内存,复制所有私有数据并运行另一个进程。然后,第二个进程可以从共享内存中读取其状态,而第一个进程只需使用适当的退出代码终止。

于 2012-06-14T20:37:14.443 回答