Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
44 / 33 / 14
Регистрация: 27.04.2012
Сообщений: 153

Зависает форма и RichTextBox при выполнении программы

14.09.2015, 13:41. Показов 1806. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, форумчане!

Возникла проблема с тем, что при выполнении кода зависает форма и отвисает только после завершения работы.
Смысл программы в том, что она по телнету коннектится к серверу и выполняет на нем команды. Вывод консоли сервера, а также мои комментарии должны вывестись в RichTextBox. Собственно, я вижу только как ползунок на полосе прокрутки уменьшается, когда добавляется текст, но прокрутить его не могу.

Вот код
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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
 
namespace Formatting_Moxa
{
    public partial class Form1 : Form
    {
        public static string[] COMMANDS = {@"cp /etc/inittab /etc/inittab.orig", //0 Editing inittab
                                           @"head -2 /etc/inittab > /etc/inittab.tmp", //1
                                           @"mv /etc/inittab.tmp /etc/inittab", //2
                                           @"umount /dev/mmc1",// 3 Unmount SD card
                                           @"mke2fs /dev/mmc1", //4 Formatting SD card
                                           @"mkdir /mnt/sd/alarms /mnt/sd/alarms/temp /mnt/sd/alarms/temp/Alarms", //5 Creation of directories
                                           @"mkdir /mnt/sd/logs /mnt/sd/out /mnt/sd/stats /mnt/sd/tmp /mnt/sd/usage", //6
                                           @"mv /etc/inittab.orig /etc/inittab" //7 Restoring inittab
                                         };
 
        public Form1()
        {
            InitializeComponent();
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            string IP = tb_IP.Text;
            string login = tb_Login.Text;
            string password = tb_Password.Text;
 
            //Check for empty fields
            if (IP == null || login == null || password == null)
            {
                MessageBox.Show("Проверьте ввод данных. Чего-то не хватает.", "Не хватает данных",
                 MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
 
            //Connection
            MinimalisticTelnet.TelnetConnection tc = new MinimalisticTelnet.TelnetConnection(IP, 23);
 
            if (tc.IsConnected)
            {
                string s = tc.Login(login, password, 100);
                rtb_Output.Text = s;
                System.Threading.Thread.Sleep(1000);
                string log = tc.Read();
                if (log.TrimEnd().EndsWith("#"))
                {
                    rtb_Output.AppendText(log);
 
                    //Check for inittab.orig
                    tc.WriteLine(@"ls /etc");
                    string ls = tc.Read();
                    if (ls.Contains("inittab.orig"))
                    {
                        //if inittab.orig already exist move it to inittab
                        tc.WriteLine(@"mv /etc/inittab.orig /etc/inittab");
                    }
                    tc.Read();
                    rtb_Output.AppendText("*** Редактирование файла inittab начато. ***");
                    tc.WriteLine(COMMANDS[0]);
                    tc.WriteLine(COMMANDS[1]);
                    tc.WriteLine(COMMANDS[2]);
                    //Check for result of previous commands
                    tc.WriteLine(@"ls /etc");
                    string editoutput = tc.Read();
                    bool doflag = true;
                    while (doflag)
                    {
                        if (editoutput.Contains("inittab.orig"))
                        {
                            doflag = false;
                            rtb_Output.AppendText("*** Редактирование успешно завершено. ***");
                            //Loop for reboot timer
                            for (int i = 3; i > -1; i--)
                            {
                                if (i != 0)
                                {
                                    rtb_Output.AppendText("Перезагрузка через " + i + "...");
                                    System.Threading.Thread.Sleep(1000);
                                }
                                else
                                {
                                    tc.WriteLine("\n");
                                    tc.WriteLine("reboot");
                                }
                            }
                        }
                        else
                        {
                            doflag = true;
                            editoutput = tc.Read();
                            rtb_Output.AppendText(editoutput);
                        }
                    }
                    System.Threading.Thread.Sleep(11000);
                    tc.Reconnect();
                    if (tc.IsConnected)
                    {
                        tc.Read();
                        rtb_Output.AppendText("*** Извлечение SD карты. ***");
                        tc.WriteLine(COMMANDS[3]);
                        System.Threading.Thread.Sleep(3000);
                        string mounterrors = tc.Read();
                        rtb_Output.AppendText(mounterrors);
                        if (mounterrors.Contains("busy") || mounterrors.Contains("Invalid"))
                        {
                            rtb_Output.AppendText("Ошибка! Карта находится в работе. Попробуйте позже.");
 
                        }
                        else
                        {
                            tc.WriteLine("df");
                            string df = tc.Read();
                            df = tc.Read();
                            if (!df.Contains("mmc1"))
                            {
                                rtb_Output.AppendText("*** Извлечение успешно завершено. ***\n" +
                                                  "*** Начато форматирование SD карты. ***"
                                                  );
                                tc.WriteLine(COMMANDS[4]);
                                string formatoutput = tc.Read();
                                rtb_Output.AppendText(formatoutput);
                                if (formatoutput.Contains("mounted"))
                                {
                                    rtb_Output.AppendText("*** Ошибка! Карта не извлечена. ***");
                                }
                                else
                                {
                                    bool doneflag = false;
                                    int done = 1;
                                    //while (!formatoutput.Contains("180.00 days")) //180.00 days. Or by two done
                                    while (doneflag == false)
                                    {
                                        if (formatoutput.Contains("done"))
                                        {
                                            switch (done)
                                            {
                                                case 1: done++; break;
                                                case 2: doneflag = true; break;
                                            }
                                        }
                                        formatoutput = tc.Read();
                                        if (formatoutput != "")
                                        {
                                            rtb_Output.AppendText(formatoutput);
                                        }
                                        System.Threading.Thread.Sleep(10000);
                                    }
                                    if (doneflag)
                                    {
                                        rtb_Output.AppendText("*** Форматирование успешно завершено. ***");
                                        for (int i = 3; i > -1; i--)
                                        {
                                            if (i != 0)
                                            {
                                                rtb_Output.AppendText("Перезагрузка через " + i + "...");
                                                System.Threading.Thread.Sleep(1000);
                                            }
                                            else
                                            {
                                                tc.WriteLine("\n");
                                                tc.WriteLine("reboot");
                                            }
                                        }
                                    }
 
                                    System.Threading.Thread.Sleep(12000);
                                    string createdirs = "";
                                    tc.Reconnect();
                                    tc.Read();
                                    rtb_Output.AppendText(@"*** Этап 1/2. Создание директорий. ***");
                                    tc.WriteLine(COMMANDS[5]);
                                    tc.WriteLine(COMMANDS[6]);
                                    createdirs = tc.Read();
                                    rtb_Output.AppendText(createdirs);
                                    rtb_Output.AppendText(@"*** Создание завершено. ***\n" +
                                                 @"*** Шаг 2/2. Редактирование файла inittab. ***");
                                    tc.WriteLine(COMMANDS[7]);
                                    createdirs = tc.Read();
                                    rtb_Output.AppendText(createdirs);
                                    tc.Read();
                                    tc.WriteLine(@"ls /etc");
                                    createdirs = tc.Read();
                                    if (!createdirs.Contains("inittab.orig"))
                                    {
                                        rtb_Output.AppendText("*** Редактирование завершено. Система работает. ***");
                                        rtb_Output.AppendText("*** Нажмите кнопку Закрыть, чтобы закрыть программу. ***");
 
                                    }
                                    else
                                    {
                                        rtb_Output.AppendText("*** Восстановление файла inittab завершилось неудачей. Обратитесь к электромеханику. ***");
                                        rtb_Output.AppendText("*** Нажмите кнопку Закрыть, чтобы закрыть программу. ***");
                                    }
                                }
                            }
                            else
                            {
                                rtb_Output.AppendText("*** Ошибка! Карта не извлечена. ***");
                            }
                        }
                    }
                }
                else //TrimEnd # IF statement after login
                {
                    MessageBox.Show("Что-то пошло не так.", "Ошибка",
                 MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
            } //IF statement for check connection after connection
            else
            {
                //no connection
            }
        }
 
        private void textBox1_KeyPress(object sender, KeyPressEventArgs e)
        {
            if (Char.IsDigit(e.KeyChar) || e.KeyChar == '.' || e.KeyChar == ',' || e.KeyChar == (char) Keys.Back || e.KeyChar == (char) Keys.Delete)
            {
                if (e.KeyChar == ',') e.KeyChar = '.';
                e.Handled = false;
            }
            else
                e.Handled = true;
        }
    }
}
Попробовал один метод из похожих тем, но он начал ругаться, что не может подключиться к потоку для вывода в текстбокс или получить данные с другого потока.
В потоках я не очень силен, буду рад, если укажите куда что надо вставить и приложите мануал.
Так же код может быть корявым и нелогичным, поэтому, если у вас глаз зацепился за какую-то глупость, приму ваши замечания по оптимизации кода.
P.S. До этого была консольная версия этой программы, всё работало как надо, но попросили сделать интерфейс.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.09.2015, 13:41
Ответы с готовыми решениями:

Зависает форма при выполнении цикла
Всем привет! Пытаюсь посредством цикла перемешать элементы массива, избегая повторов. Пользуюсь таким алгоритмом: randomize; i:=0;...

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

GUI зависает при выполнении MFC программы
У меня есть небольшая программка с интерфейсом на мфц, но когда я нажимаю на кнопку и выполняю полезную работу, то окно зависает. Что...

3
113 / 100 / 68
Регистрация: 21.04.2014
Сообщений: 1,420
14.09.2015, 13:53
Svorky, пойдёт? https://outcoldman.com/ru/arch... %BA%D0%B5/
0
[Bicycle Reinventor]
 Аватар для Exerion
332 / 270 / 109
Регистрация: 19.10.2011
Сообщений: 668
Записей в блоге: 2
14.09.2015, 14:06
Лучший ответ Сообщение было отмечено Svorky как решение

Решение

Вы правильно думаете в сторону потоков. Весь ваш код, привязанный к кнопке, работает в основном потоке - в том же, в которой крутится пользовательский интерфейс. Пока код, написанный на кнопке, не закончит работу, пользовательский интерфейс не будет работать. В особенности из-за слипов по 12 секунд.
Чтобы интерфейс обновлялся как положено, необходимо все долгосрочные операции выносить в отдельный поток. Если из него необходимо обновлять элементы интерфейса, то нужно воспользоваться методом контролов Invoke:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public void AppendToRtb(string text)
{
    if (rtb_Output.InvokeRequired)
    {
        rtb_Output.Invoke((MethodInvoker)delegate
        {
            AppendToRtb(text);
        });
    }
    else
    {
        rtb_Output.AppendText(text);
        rtb_Output.ScrollToCaret();
    }
}
Как реализовывать потоки - вам придётся разобраться, потому что тема полезная, и мануалов по ней не мало. Можно написать поток с использованием Thread, можно с использованием BackgroundWorker.
1
44 / 33 / 14
Регистрация: 27.04.2012
Сообщений: 153
14.09.2015, 14:21  [ТС]
Цитата Сообщение от FaceHoof Посмотреть сообщение
Сделал метод backgroundWorker1_DoWork, запихал туда свой код. В обработчик кнопки написал backgroundWorker1.RunWorkerAsync(). После нажатия кнопки ничего не происходит.
backgroundWorker создавал перетягиванием в конструкторе из панели элементов.
Сейчас буду пробовать что-то ещё наколдовать с ним.



Добавлено через 9 минут
Exerion, Спасибо большое! Ваш код отработал на отлично! Буду теперь его разбирать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.09.2015, 14:21
Помогаю со студенческими работами здесь

Зависает программа при выполнении printArray
Зависает программа при выполнении этого printArray(a, 15-(deletefromArray(a, 15))); #include <stdio.h> #include <stdlib.h>...

При выполнении парсинга программа зависает
Занимаюсь C# недавно. Поэтому не могу решить проблему самостоятельно. При выполнении кода программа на пару секунд (время выполнения...

Зависает браузер при выполнении кода
window.onload = function () { var mas = document.getElementById('back-fon').children; var i = 0; while(i<3) { ...

Прога зависает при выполнении процедуры
В лазаре 1.2.6 процедура работала нормально, а в лазаре 1.6 программа зависает при выполнении этой процедуры procedure...

Зависает программа при выполнении цикла
Здравствуйте, на 3 кнопки написаны циклы, при их выполнении программа зависает, подскажите в чем проблема пожалуйста, за кривые коды не...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru