Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.09.2016, 12:54
mighty_man mighty_man вне форума
Прохожий
 
Регистрация: 22.09.2016
Сообщения: 7
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию Поток не уничтожается

Привет всем!
Проблема такая. Создаю из VCL поток, выполняю в нем действия, затем в VCL уничтожаю этот поток. Ошибок никаких нет, но потом попробовал обращаться к переменной этого потока, чтение и запись происходит, хотя поток был уничтожен. Почему так?
Создаю так:
Код:
procedure TForm1.Button1Click(Sender: TObject);
var i: integer;
begin
  if (OpenDialog1.Execute) and (OpenDialog1.Files.Count > 0) then
    begin
      Data.Clear;
      ReadThread:=TReadThread.Create(OpenDialog1.Files, @Data);
      ReadThread.FreeOnTerminate:=False;
      ReadThread.OnTerminate:=FinishedRead;
      ReadThread.Resume;
      for i:=0 to OpenDialog1.Files.Count-1 do
        Memo1.Lines.Add(OpenDialog1.Files[i]);
    end;
end;

Уничтожаю так:
Код:
procedure TForm1.Timer1Timer(Sender: TObject);
begin
  if Assigned(ReadThread) then
    begin
      if not ReadThread.Terminated then
        begin
          ProgressBar1.Max:=ReadThread.ProgressEnd;
          ProgressBar1.Position:=ReadThread.Progress;
        end
      else
        begin
          ReadThread.Free;
          ProgressBar1.Position:=0;
        end;
    end
end;
Ответить с цитированием
  #2  
Старый 22.09.2016, 13:16
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Код потока бы глянуть...
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 22.09.2016, 13:20
mighty_man mighty_man вне форума
Прохожий
 
Регистрация: 22.09.2016
Сообщения: 7
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Класс потока:
Код:
type TReadThread = class(TThread)
  private
    Filenames: TStrings;
    fData: PData;
  protected
    procedure Execute; override;
  public
    ProgressEnd: Integer;
    Progress: Integer;
    constructor Create(AFilenames: TStrings; AData: PData);
end;

Execute:
Код:
procedure TReadThread.Execute;
var f: TextFile;
s: string;
i: integer;
sl: TItemData;
begin
  for i:=0 to Filenames.Count-1  do
    begin
      AssignFile(f, Filenames[i]);
      Reset(f);
      sl:=TItemData.Create(Filenames[i]);
      fData.Items.Add(sl);

      ProgressEnd:=FileSize(f);
      Progress:=0;
      while not eof(f) do
        begin
          readln(f, s);
          fData.Items.Last.Items.Add(s);
          Progress:=Progress + Length(s);
        end;

      CloseFile(f);
    end;
end;
Ответить с цитированием
  #4  
Старый 22.09.2016, 13:24
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

А покажи мне то место где ты выставляешь свойство потока Terminated в истину...
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #5  
Старый 22.09.2016, 13:27
mighty_man mighty_man вне форума
Прохожий
 
Регистрация: 22.09.2016
Сообщения: 7
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Цитата:
Сообщение от Aristarh Dark
А покажи мне то место где ты выставляешь свойство потока Terminated в истину...
Сам не выставляю. Выполняется execute и поток завершается. Смотрел дебагером, после завершения потока terminated стоит true.
Ответить с цитированием
  #6  
Старый 22.09.2016, 13:32
mighty_man mighty_man вне форума
Прохожий
 
Регистрация: 22.09.2016
Сообщения: 7
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Посмотрел в дебагере вкладку ThreadStatus, поток мой исчезает после выполнения execute.
Ответить с цитированием
  #7  
Старый 22.09.2016, 13:46
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Я не знаю куда и зачем ты смотрел но:
1. Свойство потока Terminated снаружи не видно. Как у тебя работает процедура таймера я не понимаю.
2. Это свойство не выставляется в истину после окончания Execute, да и с чего бы... смотри код ниже, он выдаёт false (по крайней мере в XE)

Форма
Код:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls,
  Unit2;

type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
    FThread:TTestThread;
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
begin
  FThread:=TTestThread.Create;
  FThread.WaitFor;
  ShowMessage(BoolToStr(FThread.Term,True));
  FThread.Free;
end;

end.


поток

Код:
unit Unit2;

interface

uses
  Classes;

type
  TTestThread = class(TThread)
  private
    function GetTerm: Boolean;
    { Private declarations }
  protected
    procedure Execute; override;
  public
    property Term:Boolean read GetTerm;
  end;

implementation



{ TTestThread }

procedure TTestThread.Execute;
begin
  { Place thread code here }
  sleep(3000);
end;

function TTestThread.GetTerm: Boolean;
begin
  Result:=Terminated;
end;

end.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #8  
Старый 22.09.2016, 14:34
Zelius Zelius вне форума
Прохожий
 
Регистрация: 25.05.2009
Сообщения: 6
Репутация: 10
По умолчанию

1 Для определения факта завершения потока проверяй ReadThread.Finished
2 при уничтожении потока ставь переменную в nil: FreeAndNil(ReadThread)
3 Как передается Filenames в конструкторе?
4 Переменную Progress хорошо бы защитить критической секцией
Ответить с цитированием
  #9  
Старый 22.09.2016, 16:08
mighty_man mighty_man вне форума
Прохожий
 
Регистрация: 22.09.2016
Сообщения: 7
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Цитата:
Сообщение от Zelius
4 Переменную Progress хорошо бы защитить критической секцией
Зачем? Я ее только читаю.
Ответить с цитированием
  #10  
Старый 22.09.2016, 16:12
mighty_man mighty_man вне форума
Прохожий
 
Регистрация: 22.09.2016
Сообщения: 7
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Цитата:
Сообщение от Aristarh Dark
Я не знаю куда и зачем ты смотрел но:
1. Свойство потока Terminated снаружи не видно. Как у тебя работает процедура таймера я не понимаю.
2. Это свойство не выставляется в истину после окончания Execute, да и с чего бы... смотри код ниже, он выдаёт false (по крайней мере в XE)

Delphi 10.
Во время работы execute
https://psv4.vk.me/c812236/u23338277...hWJgNcTs73-fww

После завершения execute
https://psv4.vk.me/c812536/u23338277...AjoXU 8bVzYQw

Последний раз редактировалось mighty_man, 22.09.2016 в 16:15.
Ответить с цитированием
  #11  
Старый 23.09.2016, 13:20
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

картинки не грузяццо
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #12  
Старый 23.09.2016, 13:48
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

забуть про потоки, используй пулы.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 18:32.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter