我在控制台应用程序中的BackgroundWorker(高级OmniThreadLibrary组件)中的主线程有问题。主线程(整个应用程序)中的对象在为后台任务调度WorkItems后立即死亡。主线程不等待OnRequestDone方法调用。
procedure TEntityIndexer.StartReindex;
begin
if LoadTable then
// in ProcessRecords method I schedule WorkItems for BackgroundWorker
ProcessRecords;
// when ProcessRecords method is done, application is at the end and
// main thread is destoryed, so object in main thread is destroyed
// and BackgroundWorker in object in main thread is destroyed too
end;
procedure TEntityIndexer.ProcessRecords;
var
_id: Integer;
_omniValue: TOmniValue;
begin
FVTable.First;
while not FVTable.Eof do
begin
_id := FVTable.FieldByName('record_id').AsInteger;
WriteLogText(cProcesIndexLog, 'ID=' + IntToStr(_id) + '....PROCESS STARTED');
_omniValue := TOmniValue.CreateNamed(
[ovIdKey, _id,
ovXMLKey, FVTable.FieldByName('mx').AsString,
ovGenKey, FVTable.FieldByName('created_str').AsString
]);
FBackgroundWorker.Schedule(FBackgroundWorker.CreateWorkItem(_omniValue));
FVTable.Next;
end;
end;
有没有解决这种情况的解决方案?
答案 0 :(得分:6)
OTL依赖于主线程中的Windows消息队列。你必须抽信息。这在GUI应用程序中自然发生,但不是控制台应用程序。在程序中添加消息循环。
示例编号62演示了这一点:https://github.com/gabr42/OmniThreadLibrary/tree/master/tests/62_Console