前スレ
C++相談室 part155
https://mevius.5ch.net/test/read.cgi/tech/1616555235/
C++相談室 part156
レス数が1000を超えています。これ以上書き込みはできません。
1デフォルトの名無しさん
2021/05/19(水) 10:55:13.24ID:LZZifCH2981デフォルトの名無しさん
2021/08/08(日) 19:31:37.38ID:R0ImpkBa std::threadってなぜかスレッドが実行中かどうかを調べるだけの関数がないんだよね
絶対にあった方が良いと思うんだけどなんか理由があるのかな
絶対にあった方が良いと思うんだけどなんか理由があるのかな
982デフォルトの名無しさん
2021/08/08(日) 19:40:44.42ID:Cdmlpdjr joinableだけじゃ足りん?
983デフォルトの名無しさん
2021/08/08(日) 19:45:39.50ID:8fWNQyKy pthreadsにそういうAPIが無いからなぁ
984デフォルトの名無しさん
2021/08/08(日) 19:55:15.31ID:GYDyEW6S pthread_timedjoin_np()使えばいいじゃない
985デフォルトの名無しさん
2021/08/08(日) 20:02:19.74ID:8fWNQyKy none portableじゃないですかやーだー (でも使う)
標準としては難しそう
標準としては難しそう
986蟻人間 ◆T6xkBnTXz7B0
2021/08/08(日) 20:27:26.52ID:7BKdY7dG native handleをgetしてWaitForSingleObject使うとか
987デフォルトの名無しさん
2021/08/08(日) 20:52:17.07ID:GYDyEW6S >>985
nandemo portable の略だから大丈夫
nandemo portable の略だから大丈夫
988デフォルトの名無しさん
2021/08/08(日) 21:39:14.34ID:yBkpHZYz 普通にミューテックスで排他して状態管理せよ……
だいたいスレッドが動いているかどうかという1 bitだけを外部が欲しがるという用途は(join操作そのものを除き)あんま無く、
キュー的なブツに対するデータの排他的な出し入れが普通伴うはず……
だいたいスレッドが動いているかどうかという1 bitだけを外部が欲しがるという用途は(join操作そのものを除き)あんま無く、
キュー的なブツに対するデータの排他的な出し入れが普通伴うはず……
989デフォルトの名無しさん
2021/08/08(日) 21:44:02.93ID:yBkpHZYz ミューテックスで数千クロックサイクル浪費するのが嫌という向きは知らん
スピンロックとかdouble-checking lockみたいな対策になるかと思うが絶対安全かつポータブルな
方法というものは無くなる希ガス
スピンロックとかdouble-checking lockみたいな対策になるかと思うが絶対安全かつポータブルな
方法というものは無くなる希ガス
990デフォルトの名無しさん
2021/08/08(日) 22:18:09.18ID:GYDyEW6S >>988
速度重視でmap/unordered_mapでコンテナ作ってみたけどやっぱり仕様変更に耐えられるvector/listコンテナ最強的なオチに似たものある
速度重視でmap/unordered_mapでコンテナ作ってみたけどやっぱり仕様変更に耐えられるvector/listコンテナ最強的なオチに似たものある
991デフォルトの名無しさん
2021/08/08(日) 22:43:58.32ID:8fWNQyKy キューへの投入と取り出しがそれぞれ1スレッドだけならミューテックスを使わなくてもアトミック変数だけで排他出来る(OSに仲裁してもらわなくていい)
992デフォルトの名無しさん
2021/08/08(日) 23:27:24.23ID:yBkpHZYz OSの助けなしにどうやって待ち(と起床)を実現するつもりなんじゃ……
993デフォルトの名無しさん
2021/08/08(日) 23:43:25.11ID:2XV4yDHI スレッドが実行中か確認したいってどんなときなのかな?
確認したところで次の瞬間には終了してる可能性あるわけじゃん
終了を待機したいならjoinすればいいし実行中をなんのために確認したいのかよくわからん
確認したところで次の瞬間には終了してる可能性あるわけじゃん
終了を待機したいならjoinすればいいし実行中をなんのために確認したいのかよくわからん
994デフォルトの名無しさん
2021/08/09(月) 00:16:27.81ID:bkD+cive Linuxのpthread_mutexの実装で使われているfutexも競合しないタイミングならユーザランドだけで処理が完結する (OSが仲裁する必要があるのは競合する場合だけ)
> Futex operation occurs entirely in user space for the
> noncontended case. The kernel is involved only to arbitrate the
> contended case. As any sane design will strive for
> noncontention, futexes are also optimized for this situation.
>
> https://man7.org/linux/man-pages/man7/futex.7.html
キューが固定長, 投入スレッド1つ, 取り出しスレッド1つという条件でならアトミック変数2つ(読み出し位置, 書き込み位置)で「競合しない」ように出来るので, OSの仲裁が必要じゃなくなる
> Futex operation occurs entirely in user space for the
> noncontended case. The kernel is involved only to arbitrate the
> contended case. As any sane design will strive for
> noncontention, futexes are also optimized for this situation.
>
> https://man7.org/linux/man-pages/man7/futex.7.html
キューが固定長, 投入スレッド1つ, 取り出しスレッド1つという条件でならアトミック変数2つ(読み出し位置, 書き込み位置)で「競合しない」ように出来るので, OSの仲裁が必要じゃなくなる
995デフォルトの名無しさん
2021/08/09(月) 00:22:59.44ID:bkD+cive あと(pthread_mutexのようなネイティブの)mutexはそういう理由で大抵の場合は最速のロック機構になっているので, 自分で作るなら普通にmutex使った方がいいというのは同意
素人(俺とか)の考えたロックフリーデータ構造とか大抵設計か実装かその両方でバグが入る
素人(俺とか)の考えたロックフリーデータ構造とか大抵設計か実装かその両方でバグが入る
996デフォルトの名無しさん
2021/08/09(月) 07:54:40.07ID:eF2Q2UUf >>989
mutexが遅くてイヤならatomicじゃね?
mutexが遅くてイヤならatomicじゃね?
997デフォルトの名無しさん
2021/08/09(月) 09:47:15.53ID:TRAo/ccI >スレッドが実行中か確認したいってどんなときなのかな?
排他制御付きのキューを自力実装するときまれによくある……
キューがあふれそうになったときpushする側(producer)を待たせる作りにした場合、
popする側(consumer)はデータをpop後、producerが待っていたらその待ちを解除、
待っていなかったら何もしないという判断が居るのでこのためのフラグ
(producer側にpushを継続する意思があるかどうか、またはpush待ち中かどうかを表すフラグ)が居る
producerよりconsumerがいつも速い見込みでキューがあふれない前提(キューが必要に応じていくらでも大きくなる)
だったりその他(待ち解除が条件変数ではなくキューイングされるイベントだったり)だと無くてもよいから
ぜってー必要か、というとビミョーだがあった方がすっきり効率的なコードとして書ける
排他制御付きのキューを自力実装するときまれによくある……
キューがあふれそうになったときpushする側(producer)を待たせる作りにした場合、
popする側(consumer)はデータをpop後、producerが待っていたらその待ちを解除、
待っていなかったら何もしないという判断が居るのでこのためのフラグ
(producer側にpushを継続する意思があるかどうか、またはpush待ち中かどうかを表すフラグ)が居る
producerよりconsumerがいつも速い見込みでキューがあふれない前提(キューが必要に応じていくらでも大きくなる)
だったりその他(待ち解除が条件変数ではなくキューイングされるイベントだったり)だと無くてもよいから
ぜってー必要か、というとビミョーだがあった方がすっきり効率的なコードとして書ける
998デフォルトの名無しさん
2021/08/09(月) 09:51:30.16ID:TRAo/ccI999デフォルトの名無しさん
2021/08/09(月) 09:55:16.95ID:TRAo/ccI となるようにインクリメントするカウンタの意味を仕向ける
1000デフォルトの名無しさん
2021/08/09(月) 09:55:21.66ID:eF2Q2UUf >>998
アンカーミスってねい?
アンカーミスってねい?
10011001
Over 1000Thread このスレッドは1000を超えました。
新しいスレッドを立ててください。
life time: 81日 23時間 0分 8秒
新しいスレッドを立ててください。
life time: 81日 23時間 0分 8秒
レス数が1000を超えています。これ以上書き込みはできません。
ニュース
- 【速報】ヤクルト・村上宗隆、ホワイトソックスと2年総額53億で合意! 米報道…低迷チームが白羽の矢、短期契約 [冬月記者★]
- 立民・岡田克也氏「国民の感情をコントロールしていかないと」、日中議連発言は「侮辱」保守党・有本香氏に怒 ★3 [少考さん★]
- M-1グランプリ2025 優勝はたくろう ★3 [Anonymous★]
- パナソニック、マツダ、三菱電機も…人手不足なのに「中高年リストラ」が黒字大企業で加速するワケ [七波羅探題★]
- 【読売世論調査】高市内閣の支持率73%で最高更新、細川・小泉内閣に続き「発足2か月後も70%」維持 [蚤の市★]
- 【サッカー】モナコ南野拓実、担架でピッチを後に。両手で顔を覆う…地元紙は「深刻なようだ」とレポート。森保ジャパンに新たな負傷者 [久太郎★]
- 【悲報】高市、核保有発言で北朝鮮まで敵に回すwwwwwwwwwwwwwwwwwwwww [817260143]
- 【速報】村上宗隆ホワイトソックスwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww
- 俺の口癖が「今のは俺がいじわるだった、忘れてくれ」なんだが
- Fate/GOスレ
- 最凶のネームドって誰?
- ぼっちざろっくの喜多郁代ちゃんの足を舐めたい
