Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
 Аватар для Arnike
23 / 23 / 4
Регистрация: 26.12.2008
Сообщений: 142

Поток, избавиться от подвисания главной формы

21.06.2011, 11:58. Показов 902. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В общем дело такое. Имеется главная форма, из которой вызывается функция, которая выполняет множество действий и работает с эксель файлами, в общем довольно длительный процесс. Так вот, вынес я все это в поток, но при его выполнении главная форма все равно "подвисает", что само собой не комильфо) вот код потока
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "Loading.h"
#include "main.h"
#pragma package(smart_init)
#pragma link "Excel_2K_SRVR"
//---------------------------------------------------------------------------
AnsiString ProgPath = ExtractFileDir(Application->ExeName);
struct Excel
{
    float Count;
    AnsiString Name;
    AnsiString Date;
};
Excel Excel[4000];
//---------------------------------------------------------------------------
__fastcall Loading::Loading(bool CreateSuspended)
    : TThread(CreateSuspended)
{
}
//---------------------------------------------------------------------------
void __fastcall Loading::Execute()
{
    Synchronize(&Complite);
    Terminate();
}
//---------------------------------------------------------------------------
void __fastcall Loading::Complite()
{
    Form1->N5->Caption = "Собираю информацию";
    AnalyseExcel(RecCount());
    Form1->N5->Caption = "Формирую файл";
    Formirate(RecCount());
    Form1->N5->Caption = "Ожидание";
    Form1->StatusBar1->Panels->Items[0]->Text = "Файл сформирован";
}
//---------------------------------------------------------------------------
int __fastcall Loading::RecCount()
{
    AnsiString Path = ProgPath + "//Files//Общий анализ.xls";
    Variant App,Sh;
    App=Variant::CreateObject("Excel.Application");
    Sh=App.OlePropertyGet("Workbooks").OlePropertyGet("Open",TVariant(Path)).OlePropertyGet("Worksheets", 1);
    int i;
    AnsiString String;
    for(i=8;i<4000;i++)
    {
        String = Sh.OlePropertyGet("Cells",i,6);
        if(String.IsEmpty())
        {
            App.OleProcedure("Quit");
            return(i-1);
        }
    }
    App.OleProcedure("Quit");
}
//---------------------------------------------------------------------------
void __fastcall Loading::AnalyseExcel(int RecCount)
{
    AnsiString Path = ProgPath + "//Files//Общий анализ.xls",Date;
    Variant App,Sh;
    App=Variant::CreateObject("Excel.Application");
    Sh=App.OlePropertyGet("Workbooks").OlePropertyGet("Open",TVariant(Path)).OlePropertyGet("Worksheets", 1);
    int i;
    for(i=8;i<RecCount;i++)
    {
    AnsiString String = Sh.OlePropertyGet("Cells",i,3);
        if(String == "")
        {
            Excel[i].Count = Sh.OlePropertyGet("Cells",i,6);
            Excel[i].Name = Sh.OlePropertyGet("Cells",i,5);
        }
        else
        {
            Excel[i].Date = Sh.OlePropertyGet("Cells",i,3);
        }
    }
    App.OleProcedure("Quit");
}
//---------------------------------------------------------------------------
void __fastcall Loading::Formirate(int RecCount)
{
    TStringList *Result = new TStringList;
    AnsiString Date;
    String Count;
    int i;
    for(i=8;i<RecCount;i++)
    {
        if(Excel[i].Date != "")
        {
            Date = Excel[i].Date;
        }
        else
        {
            if(Excel[i].Count >= 1)
            {
                if(Count.Length() > 2)
                {
                    Count = StringReplace(FloatToStr(Excel[i].Count),",",".",TReplaceFlags() << rfReplaceAll);
                    Count = Count.Delete(5,Count.Length()-4);
                }
                else
                {
                    Count = FloatToStr(Excel[i].Count) + ".00";
                }
            }
            else
            {
                Count = StringReplace(FloatToStr(Excel[i].Count),",",".",TReplaceFlags() << rfReplaceAll);
                Count = Count.Delete(5,Count.Length()-4);
            }
            if(Count.Length() == 1)
            {
                Count = Count + ".00";
            }
            Result->Add(Excel[i].Name + ";" + Count + ";" + Date + ";");
        }
    }
    Result->SaveToFile(ProgPath + "//Results//Общий анализ.txt");
    delete Result;
    Result = NULL;
}
//---------------------------------------------------------------------------
ничего особенного, через Synchronize вызываю функцию, которая в свою очередь вызывает остальные. Я думаю, что возможно в этом и портак...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.06.2011, 11:58
Ответы с готовыми решениями:

избавиться от подвисания
У меня есть программа, она выполняет довольно сложные расчеты и при выполнении подвисает, данные выводит как надо, да ещё и при выполнении...

Как создать поток вывода в RichTextBox Chart главной формы и как обращаться к этому потоку из других форм
Всем привет. Чтобы получить навыки многопоточного программирования, занялся такой задачкой: Я реализую условный чарт. Есть основная...

Загрузка файла без подвисания формы
Ребят, посоветуйте что сделать, при загрузке файла форма зависает, когда файл скачивается - отвисает. Кучу примеров перепробовал, даже с...

2
return (true);
 Аватар для mimicria
1977 / 1112 / 221
Регистрация: 19.04.2011
Сообщений: 2,346
21.06.2011, 12:08
В циклы вставить Application->ProcessMessages() не?
1
 Аватар для Arnike
23 / 23 / 4
Регистрация: 26.12.2008
Сообщений: 142
21.06.2011, 12:12  [ТС]
Ёедрен батон)как же я мог это забыть...mimicria, спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.06.2011, 12:12
Помогаю со студенческими работами здесь

WaitForSingleObject без подвисания основной формы!? Это реально?
Доброго времени суток. Намекните куда смотреть, пожалуйста. Запускаю процесс ToCMD и передаю в него параметры param. Сам процесс...

Поток не в главной форме
Привет всем! Создаю на форме, которая не главная поток, вот так type ThreadAIISData = class(TThread) private {...

Статический метод как точка входа в поток - как избавиться
Привет всем.Вопрос такой: использую потоки в своей программе,они создаются и уничтожаются в классе, и в классе так же находится...

Избавиться от зависание формы
Здравствуйте. как мне надо посторить своё решение, при неудачном сединении, чтобы форма не подвисала. Тоесть я пытаюсь запустить ...

Как избавиться от постоянной перерисовки формы
Доброго времени суток. Хочу сделать форму со своим дизайном. Для пробы стал рисовать в событии Paint. Рисуется, но вот такая проблема -...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru