前スレ
C++相談室 part155
https://mevius.5ch.net/test/read.cgi/tech/1616555235/
探検
C++相談室 part156
レス数が1000を超えています。これ以上書き込みはできません。
1デフォルトの名無しさん
2021/05/19(水) 10:55:13.24ID:LZZifCH2986蟻人間 ◆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を超えています。これ以上書き込みはできません。
ニュース
- 【物価高騰】「クリスマスケーキを用意できない」が7割超 炊き出しにも長蛇の列 生活困窮者に厳しい年の瀬が到来 [ぐれ★]
- 無職の妻(55) 6102万円を失う SNSで知り合った男からのメッセージ「裏で操作されています」、信じて送金 夫に相談し詐欺発覚 [煮卵★]
- NY円、一時157円台半ばに下落 日銀総裁の利上げ慎重姿勢を警戒 ★2 [蚤の市★]
- 【東京】「誰もいないはずの自宅にチェーン錠が…」母親と息子3人の計4人死亡 無理心中か 部屋から血の付いた斧と包丁見つかる 西東京市 [ぐれ★]
- 強制送還されたパキスタン人男性 大臣は配慮を強調したが…「諸般の事情」で権利侵害を押し切る入管のズルさ:東京新聞 [少考さん★]
- 【芸能】浜崎あゆみ、「コンプレックスあった」「安室奈美恵ちゃんはダンスが凄い上手で…MISIAさん、椎名林檎さんはスキルが凄いし」 [冬月記者★]
- GDP世界二位だった日本国が、経済もモラルも失われてしまった原因って冗談を抜いて何のせい????? [804169411]
- オバマ大統領「ラブライブが今年一番聞いた曲です」省 [347751896]
- 【高市悲報】ゴールドマン・サックス首席「日本は詰んでます🤗」知ってた🤗 [359965264]
- 報ステ「官邸幹部の核保有発言、オフレコですが非核三原則は日本の安全保障政策の根幹に関わる問題、報道すべきと判断した」ヤフコメ激怒 [256556981]
- 【高市吉報】NISA枠、2027年から600万円増額決定wmwmwmwmwmwmwmwmwmw【石破悲報】 [517459952]
- そろそろすこり納めの季節やな☃🏡
