|
20 / 19 / 1
Регистрация: 13.08.2012
Сообщений: 779
|
|||||||||||
Потоки. Малая разница в производительности01.11.2014, 15:10. Показов 2764. Ответов 24
Метки нет (Все метки)
Здравствуйте, продолжаю дальше разбираться с потоками. Имеется класс потока:
0
|
|||||||||||
| 01.11.2014, 15:10 | |
|
Ответы с готовыми решениями:
24
Непонятная разница в производительности Разница в тестах производительности Разница в производительности процессоров |
|
20 / 19 / 1
Регистрация: 13.08.2012
Сообщений: 779
|
|||||||||||||||||||||
| 04.11.2014, 12:17 [ТС] | |||||||||||||||||||||
|
Avazart, как вы и посоветовали изменил подход, несомненно появился прирост в скорости, сейчас уже 45-50 с против 115-116 с, но проблема с засыпанием главного потока не исчезла, можете подсказать что не так ?
рабочая функция:
0
|
|||||||||||||||||||||
|
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,822
|
|||
| 04.11.2014, 17:27 | |||
|
В последнем моем примере логика ожидания такая: Статусов нет. Есть количество потоков занятых работой. Как только работа одного из них завершается, он сбрасывает переменную состояния. Цикл ожидания уменьшает счетчик занятых потоков и снова становится на ожидание. Если счетчик занятых потоков равен нулю, то выходим из цикла. Или можно использовать std::atomic.
1
|
|||
|
20 / 19 / 1
Регистрация: 13.08.2012
Сообщений: 779
|
|
| 04.11.2014, 17:40 [ТС] | |
|
DrOffset, я изучал ваш код, а если поток завершит работу до того как функция ожидания будет вызвана ?
0
|
|
|
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,822
|
||||||||||||
| 04.11.2014, 18:26 | ||||||||||||
|
NEvOl, Да, это недочет. В таком случае при завершении работы тоже нужно сбрасывать переменную состояния.
Добавлено через 12 минут NEvOl, можно переделать следующим образом: Кликните здесь для просмотра всего текста
Добавлено через 3 минуты (если поток завершился, но не сказал основному проснуться). Да, это решение не пойдет. Сейчас переделаю.Добавлено через 15 минут Как-то так: Кликните здесь для просмотра всего текста
Если что не так, не обессудь. Нет под рукой компилятора.
1
|
||||||||||||
|
20 / 19 / 1
Регистрация: 13.08.2012
Сообщений: 779
|
||||||||||||||||
| 04.11.2014, 21:44 [ТС] | ||||||||||||||||
|
блин, ну я никак не могу понять, что я делаю не так ? почему у меня вырубается главный поток и все зависает. Вроде сделал по подобию DrOffset, но что-то не учел.
вот у меня основной цикл проверки, работоспособности:
нашел ошибку, при добавлении задачи, нужно использовать блокировку)
0
|
||||||||||||||||
| 04.11.2014, 21:44 | |
|
Помогаю со студенческими работами здесь
25
Курсор по запросу и по таблице. Разница в производительности 2 мощные видюхи,будел ли разница производительности Разумно ли использовать потоки и как это скажется на производительности Стоит ли разница в производительности, разнице в цене? HP G62 Redis и MongoDb: есть ли существенная разница по производительности? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
[golang] Breadth-First Search
alhaos 19.05.2026
BFS (Breadth-First Search) — это базовый алгоритм обхода графа в ширину, который поуровнево исследует все связанные вершины. Он начинает с выбранной точки и проверяет всех соседей, прежде чем. . .
|
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера»
Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит.
Придуман Биллом Госпером в 1970-х, опубликован в. . .
|
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb">
<style>
<!]>
</ style>
<g id="bush">
</ g>
</ svg>
function fn(){
let rost;/ / высота древа
let xx=165,yy=210,w=256;
|
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов,
содержащихся в реализации модуля. По-умолчанию все члены модуля доступны:
module Foo
let x = 10
let boo () = printfn "boo"
. . .
|
|
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции.
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible". . .
|
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов.
import "math"
func angleClock(hour int, minutes int) float64 {
. . .
|
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo
https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html
и его же старой инструкции по установке Lazarus с gtk2. . .
|
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер.
Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
|