子进程是作业的一部分,由创建作业的进程启动。 父进程尚未设置 JOB 属性以允许脱离作业。需要在 JOB 上设置"JOB_OBJECT_LIMIT_BREAKAWAY_OK"标志以允许子进程脱离作业,但未设置。
子进程是否可以更改此作业属性并设置标志JOB_OBJECT_LIMIT_BREAKAWAY_OK,以便它或其子进程可以在没有 JOB 的情况下运行。 在线搜索,但没有找到是否可以做到这一点。
已引用的链接
https://learn.microsoft.com/en-us/windows/desktop/procthread/job-objects 和 https://learn.microsoft.com/en-us/windows/desktop/procthread/process-creation-flags
没有说我们是否可以做到这一点。或者如果需要,那么如何做到这一点。
我编写了一个示例应用程序,其中父进程创建一个没有JOB_OBJECT_LIMIT_BREAKAWAY_OK标志的作业。并编写了由父母启动的示例应用程序。在这个孩子中,我尝试设置如下 JOB 属性:
if (bInJob)
{
JOBOBJECT_EXTENDED_LIMIT_INFORMATION info1 = {};
QueryInformationJobObject(NULL, JobObjectBasicLimitInformation, &info1.BasicLimitInformation, sizeof(info1.BasicLimitInformation), NULL);
DWORD dwLimitFlags = info1.BasicLimitInformation.LimitFlags;
SetLastError(0);
info1.BasicLimitInformation.LimitFlags |= JOB_OBJECT_LIMIT_BREAKAWAY_OK;
if (SetInformationJobObject(NULL, JobObjectExtendedLimitInformation, &info1, sizeof(info1)))
{
cout << "failed";
}
DWORD fileError = GetLastError();
JOBOBJECT_BASIC_LIMIT_INFORMATION info = {};
QueryInformationJobObject(NULL, JobObjectBasicLimitInformation, &info, sizeof(info), NULL);
dwLimitFlags = info.LimitFlags;
}
它不起作用,JOB 属性保持不变。
对于需要调用SetInformationJobObject
JOB_OBJECT_LIMIT_BREAKAWAY_OK
对于呼叫SetInformationJobObject
,您需要处理正在设置限制的作业。
但是你在这里传递NULL
句柄。 因此,此时您必须ERROR_INVALID_HANDLE
。
与IsProcessInJob
相比
应用程序无法获取作业对象的句柄,其中 除非它具有作业对象的名称,否则它正在运行。但是,一个 应用程序可以调用
QueryInformationJobObject
函数 使用NULL
获取有关作业对象的信息。
因此,系统特殊不会返回给您运行作业对象的句柄。 这是设计使然。 如果孩子能把自己从工作中移除,这种严重的杀伤感,就会限制子进程。