|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
|
Обработка поступающих данных без задержки основного цикла17.06.2011, 00:51. Показов 4613. Ответов 42
Метки нет (Все метки)
Получаю из какого-то соединения днс адреса сайтов. Считываю их из буфера в цикле. Один цикл - один днс. Нужно чтобы каждый днс переводился в ip и этот ip заносился вконец вектора. Но при этом основной цикл не должен тормозиться ни на миллисекунду, а функция преобразования dns -> ip всилу наличия пинга между моим компом и днс сервером и всилу наличия задержки у самого сервера - очень сильно тормозит... иногда на время более одной секунды. Что посоветуете в данном случае?
0
|
|
| 17.06.2011, 00:51 | |
|
Ответы с готовыми решениями:
42
Библиотека BASS (un4seen): возможна ли обработка звука в реальном времени без существенной задержки? Обновление данных в базе без задержки Обработка поступающих вложений doc |
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
||
| 17.06.2011, 08:50 | ||
|
И покажите
0
|
||
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
||||||
| 17.06.2011, 16:46 [ТС] | ||||||
|
Ну типо вот как-то так:
А функция gethostbyname срабатывает с задержкой, т.к. отсылает запрос на dns сервер, далее сервер долго думает и потом отсылает ip. Тормоза днс сервера и пинг создают общую задержку около секунды. Я не совсем представляю как это сделать.
0
|
||||||
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
|||
| 17.06.2011, 17:42 | |||
|
Расскажите подробнее, что же делается с этим адресом в итоге.
0
|
|||
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
|
| 17.06.2011, 18:41 [ТС] | |
|
Всмысле while(1)
![]() С этим адресом ничего не делается. Код, который выполняется дальше - математическая функция, считает уже свои задачи, никак не связанные с полученными dns и ip адресами. Т.е. задача проста - нужно по dns получить ip и положить (залогировать) его в вектор и больше ничего с ним не делать, а дальше вычислять математическую задачку, и так в каждой итерации цикла.
0
|
|
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
|
| 17.06.2011, 18:55 | |
|
Может тогда просто запоминать в цикле имена, а ресолвить в отдельной ните потихоньку?
1
|
|
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
|
| 17.06.2011, 19:08 [ТС] | |
|
Я смотрел реализации многопоточности и не нашел подходящего варианта. Они все направленны на распараллеливание сложных вычислений. А вот как создать отдельную нить и передавать в неё я не нашел таких примеров...
Направьте меня слегка в какую сторону капать
0
|
|
|
|
||
| 17.06.2011, 19:24 | ||
|
1
|
||
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
|
| 17.06.2011, 19:25 | |
|
man pthread_create
создавать 1 поток ресолвера или по потоку на клиента или еще как - решать вам. Для ускорения процесса можно посмотреть в сторону асинхронных ресолверов.
1
|
|
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
|
| 17.06.2011, 19:32 [ТС] | |
|
У меня через еполл уже реализовано. Нужно только логировать. Задам вопрос по конкретнее, какую многопоточность лучше всего использовать в данной задаче... если так можно выразиться, и может есть у кого небольшой пример именно заведения второго потока и передачи в него параметров, чтобы он их сам обработал и помещал куда-либо?
0
|
|
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
||
| 17.06.2011, 19:36 | ||
|
Примеров в гугле да и на этом форуме полно - забейте в поиск pthread_create
0
|
||
|
бжни
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
|
|
| 17.06.2011, 19:52 | |
|
0
|
|
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
|
| 17.06.2011, 19:56 | |
|
0
|
|
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
||||||
| 17.06.2011, 19:59 [ТС] | ||||||
|
Не не, раздел же назван "С/С++ под Linux"
![]() Не буду запариваться, использую pthread. Буду исходить из этого кода
0
|
||||||
|
бжни
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
|
|
| 17.06.2011, 20:04 | |
|
да, линукс же тема
Union, ? sem_t, pthread_mutex_t итп ?
0
|
|
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
||
| 17.06.2011, 20:17 | ||
|
До 45й строки обе нити будут работать параллельно (ну или последовательно в случае одного цпу/не хватке ресурсов).
0
|
||
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
|
| 17.06.2011, 20:46 [ТС] | |
|
Т.е. на 42-ой строке вызываемая функция wait_thread() будет отрабатывать в основном потоке, а в 34 не в основном и вместе они парралельно отработают и закончат почти в одно и тоже время?
А чтобы не основной поток получал dns, преобразовывал его в ip и клал в вектор - мне получается просто нужно в нем создать цикл, и этим циклом постоянно проверять какой-то буфер, в который я заношу из основного потока dns'ки, так? Но тогда если буфер пуст - цикл будет крутиться постоянном проверяя буфер, полностью нагружая проц...? Что делать в этом случае? Нужно как-то тормозить его через pthread_mutex?
0
|
|
|
1259 / 650 / 44
Регистрация: 06.02.2011
Сообщений: 1,654
|
||
| 17.06.2011, 20:50 | ||
мьютекс тут наверное не к чему (точнее мьтексом можно обернуть операации с вектором или что там у вас будет вместо него), почитайте man pthread_cond_wait pthread_cond_signal
1
|
||
|
бжни
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
|
||||||
| 17.06.2011, 21:06 | ||||||
http://liveworkspace.org/code/... 42c60bbfb5
1
|
||||||
| 17.06.2011, 21:06 | |
|
Помогаю со студенческими работами здесь
20
Обработка строк, поступающих через COM порт Реализация задержки с использованием цикла Передача данных в регистр без использование цикла Scanner без задержки Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
|
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|