Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.88/34: Рейтинг темы: голосов - 34, средняя оценка - 4.88
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93

Нажатие кнопки тормозит фоновый поток

07.04.2017, 14:11. Показов 7038. Ответов 49
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Есть приложение Windows Form на C# (visual studio 2010) с одной
кнопкой (функция кнопки пустая)! В приложении создаю еще один поток (ставил
разные приоритеты),который получает Ethernet пакеты из сети каждые 10 мс,
и после каждого полученного пакета сразу же отсылает отвентый пакет (см. рисунок).
Когда нажимается кнопка, то отдельный поток "подвисает" (см. рисунок)! В клоне
этого приложения, написанном на MFC(С++) такого не происходит, хотя перенес все один в один!
Как сделать так, чтобы НАЖАТИЕ кнопки не ВЛИЯЛО на остальные потоки процесса?
Миниатюры
Нажатие кнопки тормозит фоновый поток  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.04.2017, 14:11
Ответы с готовыми решениями:

Как заставить дочерний поток реагировать на нажатие кнопки
Как в дочерних потоках генерировать исключения по нажатию на кнопку? При остановке генерации и отлова дочерние потоки должны продолжать...

Чем отличается фоновый поток от не фонового?
Добрый день. receiveThread.IsBackground = true; Что значит, если устанавливаю это свойство в true, что именно изменится?

Фоновый поток не отслеживает изменение глобальной переменной
есть некая глобальная переменная int i=0; и есть событие кнопки, которое меняет значение этой переменной i=1; есть некий фоновый...

49
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
07.04.2017, 21:01  [ТС]
То есть, если посчитать, то нажатие кнопки удерживает ДОЧЕРНИЙ поток на 120 мс (см. рисунок)! АХРЕНЕТЬ! Почему вообще, кнопка формы влияет на ИНОЙ поток? КАК?
Поток создается при помощи класса Thread. Или механизм Thread настолько не доработан!? Почему в MFC такого даже близко нет(функция Afx.....) ?
0
 Аватар для Aferuga
645 / 529 / 324
Регистрация: 20.05.2015
Сообщений: 1,471
07.04.2017, 22:52
async/await
backgroundWorker
0
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
07.04.2017, 23:03
Валеронище, приведите код.
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 13:23  [ТС]
Здравствуйте! Немного упростил, чтобы было наглядней! Три кнопки: старт, стоп и пустая! В первом
варианте запускаю новый Thread, в котором в цикле, каждые 10мс отсылаю сообщения в сеть!
Во время циклической посылки сообщений нажимаю десять раз пустую кнопку. В мониторе
сообщений отсортировал пакеты по времени (в крайнем левом столбце показана разница времени по отношению к прошлому пакету),
чтобы было все очевидно: видим десять пакетов (что соответсвтует нажатию пустой кнопки)
время отсылки которых значительно превышает необходимые 10мс!
Во втором варианте использовал не Thread, а BackgroundWorker! Привожу код для двух вариантов и
снимки мониторинга фонового потока отсылки пакетов!
В обоих случаях нажатие ПУСТОЙ кнопки прерывает приостанавливает поток, - ПРОБЛЕМА!!!
ЧТО ЖЕ ДЕЛАТЬ? Повторюсь, в MFC при использовании функции AfxBeginThread(ThreadSend, 0) такого бардака не происходит!!!
Миниатюры
Нажатие кнопки тормозит фоновый поток   Нажатие кнопки тормозит фоновый поток   Нажатие кнопки тормозит фоновый поток  

Нажатие кнопки тормозит фоновый поток  
0
907 / 664 / 318
Регистрация: 23.10.2016
Сообщений: 1,543
08.04.2017, 14:12
Валеронище, покажите ещё, как время замеряется/выводится.
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 20:00  [ТС]
Посредством программы WireShark мониторинга сетевого трафика, работает непосредственно с сетевой картой!

Я специально провел эксперимент, перенеся строки моего приложения на MFC и выполняя те же действия по нажатию кнопки, - пакеты следуют без заминок, всегда через 10мс (с небольшой погрешностью, так как Windows - не ОС реального времени)

Добавлено через 5 часов 17 минут
Что, никто не знает, как в C# с потокам дружить? Всё, СДУЛИСЬ? А я остался с проблемой, которая как я понял, не последнее значение имеет, так как это уже не отдельный поток, а зависимый от формы, хотя заявляется, как отдельный!

Добавлено через 12 минут
Так же, загнал все, что касается посылки пакетов в отдельный класс, и попробовал все это с Tasks, - эффект ТОЧНО такой же!

Добавлено через 1 минуту
Чем же AfxBeginThread в MFC такой сказочный, чего не может С# ???????????????????????????

Добавлено через 1 минуту
И нафига тогда в С# все эти распараллеливания, если банальная кнопка формы и то все подпорчивает???
0
Эксперт .NET
 Аватар для Rius
13121 / 7682 / 1675
Регистрация: 25.05.2015
Сообщений: 23,452
Записей в блоге: 14
08.04.2017, 20:01
Валеронище, "приведите код" значит "выложите проект". Причём весь проект, а не скриншоты избранных функций. Можно демонстрационный. Чтобы собрать и запустить.
0
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
08.04.2017, 20:29
Валеронище,
Вот код:
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
using System;
using System.Net;
using System.Net.Sockets;
using System.Windows.Forms;
 
namespace WindowsFormsApplication367
{
    public partial class Form1 : Form
    {
        UdpClient client = new UdpClient();
        private byte[] data = new byte[] { 1, 2, 3, 4, 5 };
 
        public Form1()
        {
            InitializeComponent();
 
            var tm = new System.Timers.Timer(30);
            tm.Elapsed += tm_Elapsed;
            tm.Start();
        }
 
        void tm_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
        {
            client.BeginSend(data, data.Length, new IPEndPoint(IPAddress.Broadcast, 12345), null, null);
        }
    }
}
Отсылает пакеты каждые 30 мс. На форме лежит кнопка. Что ее нажимай, что не нажимай, интервал от этого не меняется.

А по вашим скриншотам понять ничего нельзя. Что такое wait(...) ? Что такое ICaptureDevice? Ищите проблемы там. Потоки тут не при чем. Они точно такие же как в MFC.

Не по теме:

И да, поменьше понтов, восклицательных знаков и капса плз. Подворотня напротив.

0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 20:57  [ТС]
Ссори, все понял!
WireShark не получилось прикрепить, 20 метров не хочет!
Вложения
Тип файла: rar Threads.rar (184.4 Кб, 5 просмотров)
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 22:30  [ТС]
Storm23, Я за чистоту эксперимента! Поюзал твой пример с инетом и без! Разные результаты! Отключи (не кабель) интернет! Таймер твой не точный (System)! Скрин твоего примера, с таймером по-точнее в скрине! По wireshark-y без кнопки все гуд, с кнопкой задержка! Есть влияние и с твоим ЮДИПИКЛАЕНТОМ! Так что ФОРМА виновата!
Миниатюры
Нажатие кнопки тормозит фоновый поток  
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 22:37  [ТС]
P.S. Восклицательные знаки машинально ставлю после сайтов знакомств
0
Эксперт .NET
 Аватар для Rius
13121 / 7682 / 1675
Регистрация: 25.05.2015
Сообщений: 23,452
Записей в блоге: 14
08.04.2017, 22:47
Валеронище, там пакеты сотнями же бегут. Как вы решаете, какие именно были задержаны нажатием кнопки?
И как убрать ненужные пакеты? Фильтр по MAC поставил 11:11:11:11:11:11, всё равно несколько лишних пролезает.
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 23:22  [ТС]
Там все четко, сейчас расскажу!
В строке Filter eth.src == 11.11.11.11.11.11
Много у кого, даже у нескольких пакетов, кроме твоих таких мак адресов?

Добавлено через 17 минут
А решаю я это, отсортировав пакеты по времени! Кстати, поставь во View галочку, чтобы показывал время со времени прежнего пакета, тогда будешь видеть эти 10 мс! Отсортируй, после остановки в мониторе, пакеты по времени! Попробуй с нажатием кнопки и без этого и посмотри результат!
0
Эксперт .NET
 Аватар для Rius
13121 / 7682 / 1675
Регистрация: 25.05.2015
Сообщений: 23,452
Записей в блоге: 14
08.04.2017, 23:27
Цитата Сообщение от Валеронище Посмотреть сообщение
Много у кого, даже у нескольких пакетов, кроме твоих таких мак адресов?
Несколько десятков. Только вот у них MAC вообще другие, от сетевухи и роутера.


Цитата Сообщение от Валеронище Посмотреть сообщение
Попробуй с нажатием кнопки и без этого и посмотри результат!
Запустил прогу, подождал. Запустил мониторинг, записал, остановил.
Результат:
есть и 0.000762
в основном есть ~0.0098, как ожидалось,
есть и до 0.025640.

Только вот ни форму, ни кнопок я вообще не трогал.
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
08.04.2017, 23:32  [ТС]
Инет отключи! Просто отключи с компа свой инет! Будешь видеть лишь то, что ты шлешь в данный момент! Исключи любые влияния извне!
0
Эксперт .NET
 Аватар для Rius
13121 / 7682 / 1675
Регистрация: 25.05.2015
Сообщений: 23,452
Записей в блоге: 14
08.04.2017, 23:48
Отключил. От нажатий значимо и стабильно ничего не меняется.

А вот процессорное время эта функция wait жрёт просто на ура. Потому как там цикл, не отдающий сам ненужное время другим процессам.

Цитата Сообщение от Валеронище Посмотреть сообщение
Инет отключи! Просто отключи с компа свой инет! Будешь видеть лишь то, что ты шлешь в данный момент! Исключи любые влияния извне!
Это сферический процесс в вакууме, не имеющий ничего общего с реальной работой. Всё это бессмысленно.

Можете залить такой же мелкий проект с AfxBeginThread для VS 2017 Community?
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
09.04.2017, 00:04  [ТС]
Я на нескольких компах одну и ту же прогу протестировал, ничего не привносил, что и вам отдал, и что же? Одно и то же! Для меня заминка в 30 мс важна! Таймер у меня высокоточный средствами винды может у тебя в матери нет такой поддержки, хотя тогда бы вообще не работала задержка.... ! Либо у тебя слишком быстрый игровой комп, что эти задержки хавает, поэтому и не видишь из за погрешности даже высокоточного таймера! Залью с Afx тоже!
ПОТОМУ ЧТО, при ОДНИХ И ТЕХ же УСЛОВИЯХ, в ФОРМАХ - ЛАЖАЕТ, А В MFC НЕТ!!!
Единственное, у меня только в VS 2010
0
Эксперт .NET
 Аватар для Rius
13121 / 7682 / 1675
Регистрация: 25.05.2015
Сообщений: 23,452
Записей в блоге: 14
09.04.2017, 00:07
Цитата Сообщение от Валеронище Посмотреть сообщение
Таймер у меня высокоточный средствами винды
Это я вижу. Задержка на его основе непозволительно сильно нагружает систему. Для реальной работы сие не допустимо.
Конфиг компа в моём профиле указан.

Цитата Сообщение от Валеронище Посмотреть сообщение
Для меня заминка в 30 мс важна!
Это не RTOS. Смиритесь.

Жду проекта.
0
0 / 0 / 2
Регистрация: 04.07.2014
Сообщений: 93
09.04.2017, 00:20  [ТС]
Не, не, поверь другая тема, я ее уже хорошо проследил, только не пойму все же где собака порылась! Верь мне, здесь что-то не так! То что НЕРЕАЛЬНОГО, я согласен, имеем дело и с РЕАЛЬНЫМИ

Я же ранее четкие скрины скинул, там ведь все наглядно! Единственное, что не скинул пока с MFC! Убираю лишнее

P.S. И чем же твой комп, не такой, как мои два разных? Ну может чуть круче, разве что!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.04.2017, 00:20
Помогаю со студенческими работами здесь

Эмулировать нажатие кнопки мыши или нажатие клавиши на Web - странице
Здравствуйте. Как на эмулировать переходы по страницам на сайте, открытом в Интернет эксплорере!. Например: В определенные...

Нажатие каждой кнопки приводит к ее сокрытию и показу ранее скрытой кнопки
Нажатие каждой кнопки приводит к ее сокрытию и показу ранее скрытой кнопки. При этом номер (название) ранее скрытой кнопки отображается в...

Нажатие кнопки приводит к изменению цвета формы и заголовка кнопки
Помогите пожалуйста так сделать : "Нажатие кнопки приводит к изменению цвета формы на синий, а надпись на кнопке меняется".

Привязать выполнение действия кнопки на нажатие кнопки Enter
У меня кнопка - Button, выполняет такое то действие, не подскажите, как привязать выполнение действия этой кнопки на нажатие кнопки Enter?

Определить нажатие кнопки Home и кнопки сворачивания приложения
По аналогии с backPressed: @Override public void onBackPressed() { }


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
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. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru