C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレにお願いします。
前スレ
C++相談室 part149
https://mevius.5ch.net/test/read.cgi/tech/1581974381/
このスレもよろしくね。
【初心者歓迎】C/C++室 Ver.105【環境依存OK】
http://mevius.5ch.net/test/read.cgi/tech/1556142878/
■長いソースを貼るときはここへ。■
http://codepad.org/
https://ideone.com/
[C++ FAQ]
https://isocpp.org/wiki/faq/
http://www.bohyoh.com/CandCPP/FAQ/ (日本語)
テンプレここまで
探検
C++相談室 part150
■ このスレッドは過去ログ倉庫に格納されています
2020/03/24(火) 00:04:33.93ID:YFRNwZnv
611デフォルトの名無しさん
2020/05/03(日) 16:54:49.03ID:+PpSUNNp 64bitだとdoubleとかの書き込みはアトミックになるの
612デフォルトの名無しさん
2020/05/03(日) 17:17:29.21ID:VkK7EFZv C/C++にキャリーフラグ観る機能が無いのはなせ?
613デフォルトの名無しさん
2020/05/03(日) 17:56:41.69ID:baOIQvWk アトミックにしたけりゃstd::atomicを使え
使わない場合は保証されない
使わない場合は保証されない
614デフォルトの名無しさん
2020/05/03(日) 18:16:14.79ID:uzK0zokK615デフォルトの名無しさん
2020/05/03(日) 18:19:51.49ID:uzK0zokK >>613
64bitでない環境だとatomic持ち出したところで使えないじゃん
64bitでない環境だとatomic持ち出したところで使えないじゃん
616デフォルトの名無しさん
2020/05/03(日) 18:25:40.26ID:baOIQvWk 使えるぞ
内部でロックするから遅いけど
内部でロックするから遅いけど
617デフォルトの名無しさん
2020/05/03(日) 20:09:19.86ID:7Ft0FuY4 >>598
90度だろ?
90度だろ?
618デフォルトの名無しさん
2020/05/03(日) 20:16:01.21ID:s7MuzCvB モダンc++入門ってどこみたらいい?
619デフォルトの名無しさん
2020/05/03(日) 21:01:49.43ID:0Fr9Yznx cpprefjp
620デフォルトの名無しさん
2020/05/03(日) 22:43:31.73ID:WVD/IFzz621デフォルトの名無しさん
2020/05/03(日) 22:46:00.66ID:WVD/IFzz622デフォルトの名無しさん
2020/05/03(日) 22:52:17.09ID:WVD/IFzz623デフォルトの名無しさん
2020/05/03(日) 22:53:53.78ID:WVD/IFzz624デフォルトの名無しさん
2020/05/04(月) 03:33:26.41ID:BnrivxPo int128でもint256でも自由に型が作れるのがC++の強みなのに書けないってw
625デフォルトの名無しさん
2020/05/04(月) 06:12:26.01ID:/zUHO7E0 int_<256>みたいの作ってたけど
サイズが発散する問題がすぐ起きる
サイズが発散する問題がすぐ起きる
628デフォルトの名無しさん
2020/05/04(月) 07:22:03.70ID:nMCshN11 x86
629デフォルトの名無しさん
2020/05/04(月) 08:03:18.75ID:S2aUUuq2 shared_ptr<Hoge>をvoid *の領域に格納したいのですがどうすればいいでしょうか?
SetPointer(void *),void* GetPointer()で設定します
shared_ptr<Hoge> hoge
として
SetPointer(hoge)
取り出す時
shared_ptr<Hoge> hoge = GetPointer()
SetPointer(void *),void* GetPointer()で設定します
shared_ptr<Hoge> hoge
として
SetPointer(hoge)
取り出す時
shared_ptr<Hoge> hoge = GetPointer()
630デフォルトの名無しさん
2020/05/04(月) 08:04:47.44ID:S2aUUuq2 後、SetPointerする前にshared_ptrの参照カウントを一つ増やしたいです。
631デフォルトの名無しさん
2020/05/04(月) 09:54:06.17ID:Fiop0J3e >>629-630
所有権込みで格納したいだけなら。
SetPointer(new shared_ptr<Hoge>(hoge));
shared_ptr<Hoge> hoge = *static_cast<shared_ptr<Hoge>*>(GetPointer());
あとはどうにか delete が抜けないようにする。
所有権込みで格納したいだけなら。
SetPointer(new shared_ptr<Hoge>(hoge));
shared_ptr<Hoge> hoge = *static_cast<shared_ptr<Hoge>*>(GetPointer());
あとはどうにか delete が抜けないようにする。
632デフォルトの名無しさん
2020/05/04(月) 10:27:13.66ID:aMJtnkBw 本当にshared_ptrごと格納する必要があるの?
これで良かったりはしない?
shared_ptr<Hoge> p(new(buffer) Hoge, [](Hoge* p){p->~Hoge();});
これで良かったりはしない?
shared_ptr<Hoge> p(new(buffer) Hoge, [](Hoge* p){p->~Hoge();});
633デフォルトの名無しさん
2020/05/04(月) 11:04:11.62ID:BnrivxPo つまりshareする気がないけどshared_ptrを使いたいわけだな
634デフォルトの名無しさん
2020/05/04(月) 11:24:26.33ID:7IQ5DE83 誰かと食べる気はないけど、マックのシェアポテトを食べたい感覚だね
635デフォルトの名無しさん
2020/05/04(月) 12:42:16.41ID:S2aUUuq2 >>632
これ難しすぎて解読できません
まず、やりたいことはWindowsのTreeViewでノードを追加するときに、ノードにLPARAM型の任意のデータを関連づけれるんですが、そこに他の関数から受け取ったshared_ptr<Hoge>を関連付けたいのです
shared_ptrごと格納する必要ないと言えばないのかもしれません
でも中身だけ格納すると、deleter?の情報がとんじゃう?
これ難しすぎて解読できません
まず、やりたいことはWindowsのTreeViewでノードを追加するときに、ノードにLPARAM型の任意のデータを関連づけれるんですが、そこに他の関数から受け取ったshared_ptr<Hoge>を関連付けたいのです
shared_ptrごと格納する必要ないと言えばないのかもしれません
でも中身だけ格納すると、deleter?の情報がとんじゃう?
636デフォルトの名無しさん
2020/05/04(月) 12:55:51.13ID:S2aUUuq2 >>631
こっちの方で後で試してみます
こっちの方で後で試してみます
637デフォルトの名無しさん
2020/05/04(月) 13:16:44.39ID:0skWT8b9 なにがしたいのだかいまいちよくわからない
638デフォルトの名無しさん
2020/05/04(月) 13:20:23.37ID:/R09lZ8N 所有したいのか/参照持ちたいだけなのか
shared_ptrとして使う必要があるのか
参照だけ持ちたいとしてダングリングの可能性が有るのか
shared_ptrとして使う必要があるのか
参照だけ持ちたいとしてダングリングの可能性が有るのか
639デフォルトの名無しさん
2020/05/04(月) 13:46:24.04ID:S2aUUuq2 あーあ。shared_ptrごと格納できるならそっちの方がいいです。
そうしないと誰が最後にdeleteするかめんどくさくなりなすね。
すみませんでした
そうしないと誰が最後にdeleteするかめんどくさくなりなすね。
すみませんでした
640デフォルトの名無しさん
2020/05/04(月) 13:47:34.57ID:aMJtnkBw TreeViewが持つのはポインタだけで、オブジェクトの寿命管理するわけじゃないんだろ?
だったらshared_ptrのdeleterの情報なんか渡す必要ないんじゃないか
オブジェクトの寿命管理する奴が知ってればそれでいい
だったらshared_ptrのdeleterの情報なんか渡す必要ないんじゃないか
オブジェクトの寿命管理する奴が知ってればそれでいい
641デフォルトの名無しさん
2020/05/04(月) 13:56:33.16ID:tzWRkvZC642デフォルトの名無しさん
2020/05/04(月) 14:01:15.39ID:S2aUUuq2 すみません。何か頭混乱してきた・・
>>630が余計だったのか・・
まず、基本方針としてオブジェクトの寿命管理を楽にするためにクラス間でデータをやり取りする場合は
全部shared_ptr経由で参照カウントにより自動で管理してもらおうという方針です。
ですが、既存のライブラリとの都合で例えば、今回のTreeViewのノードにはLPARAM型のデータしか関連づけらられない
ということで、ノードに関連づけるときに参照カウント手動で?増やしてあげて、ノードを削除するときに、
参照カウントを手動で減らして?あげて調整するものなのかなぁーと思った次第です。
>>630が余計だったのか・・
まず、基本方針としてオブジェクトの寿命管理を楽にするためにクラス間でデータをやり取りする場合は
全部shared_ptr経由で参照カウントにより自動で管理してもらおうという方針です。
ですが、既存のライブラリとの都合で例えば、今回のTreeViewのノードにはLPARAM型のデータしか関連づけらられない
ということで、ノードに関連づけるときに参照カウント手動で?増やしてあげて、ノードを削除するときに、
参照カウントを手動で減らして?あげて調整するものなのかなぁーと思った次第です。
643デフォルトの名無しさん
2020/05/04(月) 14:02:14.17ID:/R09lZ8N データの本体は別にあってそっちで所有権管理しているなら、treeviewにはshared_ptr::getで得られるpointer持たせればいい
使う側でshared_ptrである必要があるなら、shared_from_this使う
ダングリングする可能性無いならならこれでおk
使う側でshared_ptrである必要があるなら、shared_from_this使う
ダングリングする可能性無いならならこれでおk
644デフォルトの名無しさん
2020/05/04(月) 14:12:18.91ID:aMJtnkBw void*で渡しちゃう以上はTreeViewに参照カウント減らさせるのは不可能なので、そこは外側で管理してやるしかない
だったらTreeViewはshared_ptrがどうのこうのという情報は知らなくていいし、知らせるべきでない
だったらTreeViewはshared_ptrがどうのこうのという情報は知らなくていいし、知らせるべきでない
645デフォルトの名無しさん
2020/05/04(月) 14:19:40.83ID:tzWRkvZC646デフォルトの名無しさん
2020/05/04(月) 14:23:16.16ID:aMJtnkBw647デフォルトの名無しさん
2020/05/04(月) 14:33:47.37ID:tzWRkvZC648デフォルトの名無しさん
2020/05/04(月) 14:47:05.48ID:aMJtnkBw 何が気に食わなくて噛み付いてるのかよくわかんないけど
TreeViewはshared_ptrのことなんか知らないんだから、そんなものは知らせずに
関連のあるデータを与える(要はshared_ptr<Hoge>*じゃなくてHoge*を渡す)方が設計すっきりするんじゃない?
って言ってるだけなんだがそんなにおかしいか?
TreeViewはshared_ptrのことなんか知らないんだから、そんなものは知らせずに
関連のあるデータを与える(要はshared_ptr<Hoge>*じゃなくてHoge*を渡す)方が設計すっきりするんじゃない?
って言ってるだけなんだがそんなにおかしいか?
649デフォルトの名無しさん
2020/05/04(月) 14:51:53.81ID:Zy37Y+hL 何か追加して問題が出て別の何か追加して解決するの繰り返し
C++の仕様は余計なものが多い
メモリーの所有権の移動とかの暗黙知の極みを気にできるくらいならdelete忘れることはないだろうに
C++の仕様は余計なものが多い
メモリーの所有権の移動とかの暗黙知の極みを気にできるくらいならdelete忘れることはないだろうに
650デフォルトの名無しさん
2020/05/04(月) 14:57:19.53ID:Fiop0J3e Hoge* 渡して済むなら最初から相談なんて発生しないだろうと思ってたんだけど、
>642 みたいな「基本方針」だと shared_ptr の必要性が胡散臭いんで、確かに
Hoge* で済む可能性もありそうな気がしてきた。
>642 みたいな「基本方針」だと shared_ptr の必要性が胡散臭いんで、確かに
Hoge* で済む可能性もありそうな気がしてきた。
651デフォルトの名無しさん
2020/05/04(月) 15:00:15.13ID:tzWRkvZC652デフォルトの名無しさん
2020/05/04(月) 15:10:46.19ID:S2aUUuq2 >Hoge* 渡して済むなら最初から相談なんて発生しないだろう
そうです。Hoge*で渡したくないから質問した次第です。
元のデータが先に捨てられようと、先にTreeViewのノードが破棄されようと、どっちが先でも
OKなように、それらを意識しないようになるべく参照カウントの仕組みで破棄したかったわけです。
そうです。Hoge*で渡したくないから質問した次第です。
元のデータが先に捨てられようと、先にTreeViewのノードが破棄されようと、どっちが先でも
OKなように、それらを意識しないようになるべく参照カウントの仕組みで破棄したかったわけです。
653デフォルトの名無しさん
2020/05/04(月) 15:22:06.17ID:aMJtnkBw だったら>>631も、結局TreeViewの破棄を監視して破棄前にdelete GetPointer()かけないといけないんだけど
それでもいいのか?本当に意識すべきことは減ってるのか?無用な複雑さを持ち込んでるだけじゃないのか?
っていうことを一回冷静に考えた方がいいよ
それでもいいのか?本当に意識すべきことは減ってるのか?無用な複雑さを持ち込んでるだけじゃないのか?
っていうことを一回冷静に考えた方がいいよ
654デフォルトの名無しさん
2020/05/04(月) 15:23:27.04ID:Zy37Y+hL 逆にHoge*で受け取って、
Tree破棄時にPointer破棄処理省いてしまって、
あとはsharedのスコープで全消しすればいい
もちろんノード追加時に参照カウンタ増やす必要もない
Tree破棄時にPointer破棄処理省いてしまって、
あとはsharedのスコープで全消しすればいい
もちろんノード追加時に参照カウンタ増やす必要もない
655デフォルトの名無しさん
2020/05/04(月) 15:24:48.96ID:S2aUUuq2656デフォルトの名無しさん
2020/05/04(月) 15:44:09.03ID:S2aUUuq2 前調べたら
https://docs.microsoft.com/en-us/windows/win32/controls/tvn-deleteitem
ノード削除時に発生するイベントがあるので、ここ1か所にかくだけでいいのかなと
思ったので、その方が分かりやすいかなと思った次第です
てか、この方法駄目そうですね?
>delete GetPointer()
じゃなくて、参照カウントを減らしたいんですけど、無理っぽいのかな・・
COMならAddRef,Releaseで調整できるんですけど
もうちょっと調べて駄目そうならHoge*でいきます
https://docs.microsoft.com/en-us/windows/win32/controls/tvn-deleteitem
ノード削除時に発生するイベントがあるので、ここ1か所にかくだけでいいのかなと
思ったので、その方が分かりやすいかなと思った次第です
てか、この方法駄目そうですね?
>delete GetPointer()
じゃなくて、参照カウントを減らしたいんですけど、無理っぽいのかな・・
COMならAddRef,Releaseで調整できるんですけど
もうちょっと調べて駄目そうならHoge*でいきます
657デフォルトの名無しさん
2020/05/04(月) 15:54:22.23ID:Fiop0J3e658デフォルトの名無しさん
2020/05/04(月) 16:04:26.16ID:aMJtnkBw そもそもTreeViewってViewだから見た目を整えるための奴でしょ
自分ならロジックデータの寿命管理にそんな奴参加させたくないな
まあ、削除時のコールバックが指定できるんだったら、それで後始末するのも手ではあるかもね
小さいプログラムで、見た目の要素の何かとHogeが論理的に一対一対応してるんだったら許容範囲かな
自分ならロジックデータの寿命管理にそんな奴参加させたくないな
まあ、削除時のコールバックが指定できるんだったら、それで後始末するのも手ではあるかもね
小さいプログラムで、見た目の要素の何かとHogeが論理的に一対一対応してるんだったら許容範囲かな
659デフォルトの名無しさん
2020/05/04(月) 16:11:26.04ID:tzWRkvZC >>653
質問者はクラス間で共有するデータは一律shared_ptrにすると言っている
これは全体設計の選択としてまぁある話
しかしこれによって既存コンポーネントのTreeViewで
インタフェースのミスマッチが起こった、さてどうしたらいいでしょう?
という質問なわけ
これもよくある問題
だからって全体設計のポリシーをとりやめようとはならのよ
解決できる手段があるなら部分的な問題は個別に解決したらそれでいい
質問者はクラス間で共有するデータは一律shared_ptrにすると言っている
これは全体設計の選択としてまぁある話
しかしこれによって既存コンポーネントのTreeViewで
インタフェースのミスマッチが起こった、さてどうしたらいいでしょう?
という質問なわけ
これもよくある問題
だからって全体設計のポリシーをとりやめようとはならのよ
解決できる手段があるなら部分的な問題は個別に解決したらそれでいい
660デフォルトの名無しさん
2020/05/04(月) 16:29:01.02ID:aMJtnkBw >>659
言ってることは分かるけど
それでどうしてTreeViewにshared_ptrを埋め込むことに固執するのかがわからない
そこはおとなしくTreeViewには生ポで参照してもらうっていうのも一つの「部分的な問題の個別解決」じゃないの?
言ってることは分かるけど
それでどうしてTreeViewにshared_ptrを埋め込むことに固執するのかがわからない
そこはおとなしくTreeViewには生ポで参照してもらうっていうのも一つの「部分的な問題の個別解決」じゃないの?
661デフォルトの名無しさん
2020/05/04(月) 16:58:42.06ID:b5BOjBYY Linux でのライブラリについて質問があります。
静的リンクライブラリ(拡張子が.aのファイル)は複数のオブジェクトファイル(拡張子が.oのファイル)を ar コマンドでアーカイブしたものと理解しています。
一方自分で調べた限り、動的リンクライブラリ(拡張子が.soのファイル)を作る場合には gcc を用いる場合は-shared (と-fPIC )を指定して一つのソースファイルから一つの.soファイルを作成しているように思います。
例: g++ -shared -fPIC -o sample.so sample.cpp
この理解の上で質問です。
動的リンクライブラリは静的リンクライブラリのように一つのファイルにまとめられないのでしょうか?ソースの数だけ.soファイルが出きてしまうのは避けられないのでしょうか?
静的リンクライブラリ(拡張子が.aのファイル)は複数のオブジェクトファイル(拡張子が.oのファイル)を ar コマンドでアーカイブしたものと理解しています。
一方自分で調べた限り、動的リンクライブラリ(拡張子が.soのファイル)を作る場合には gcc を用いる場合は-shared (と-fPIC )を指定して一つのソースファイルから一つの.soファイルを作成しているように思います。
例: g++ -shared -fPIC -o sample.so sample.cpp
この理解の上で質問です。
動的リンクライブラリは静的リンクライブラリのように一つのファイルにまとめられないのでしょうか?ソースの数だけ.soファイルが出きてしまうのは避けられないのでしょうか?
662デフォルトの名無しさん
2020/05/04(月) 17:07:30.46ID:aMJtnkBw 単に.oを複数与えればいいんじゃないの?
何か問題あったっけ
何か問題あったっけ
663デフォルトの名無しさん
2020/05/04(月) 17:11:45.42ID:mcNTUyFW664デフォルトの名無しさん
2020/05/04(月) 17:12:19.55ID:heXhx7kW >>628
ちょっx86やx64でアトミックに読み書きできる(バスサイクルが他コアに割り込まれない)ことが保証されているのは
32 bitまででしかも32 bit境界に整列している場合のみのでは…
ちなdoubleは64 bit
ちょっx86やx64でアトミックに読み書きできる(バスサイクルが他コアに割り込まれない)ことが保証されているのは
32 bitまででしかも32 bit境界に整列している場合のみのでは…
ちなdoubleは64 bit
665デフォルトの名無しさん
2020/05/04(月) 17:30:50.31ID:b5BOjBYY666デフォルトの名無しさん
2020/05/04(月) 18:05:00.17ID:hwmiGMKy667デフォルトの名無しさん
2020/05/04(月) 18:43:33.39ID:wRQD0Fqh wandbox上だとatomic<double>はロックフリーらしい、多分x86-64環境なら同じ
https://wandbox.org/permlink/0LWMsNPNmSn6rpZ4
https://wandbox.org/permlink/0LWMsNPNmSn6rpZ4
668デフォルトの名無しさん
2020/05/04(月) 18:54:28.70ID:heXhx7kW >>666
>64bit境界であることは必須
ハア(゚Д゚)?
ていうことは
char *p = 〜;
*p = 'a';
は、pが8の倍数でなければ非アトミック??
short *q = 〜;
*q = 123;
もまた、qが8の倍数でなければ非アトミック???
なんと?!
>64bit境界であることは必須
ハア(゚Д゚)?
ていうことは
char *p = 〜;
*p = 'a';
は、pが8の倍数でなければ非アトミック??
short *q = 〜;
*q = 123;
もまた、qが8の倍数でなければ非アトミック???
なんと?!
669デフォルトの名無しさん
2020/05/04(月) 18:56:20.07ID:/R09lZ8N doubleの話をcharに拡大して何がしたいのか
670デフォルトの名無しさん
2020/05/04(月) 18:57:04.84ID:aRLx0l42 アスペは文脈が読めない
671デフォルトの名無しさん
2020/05/04(月) 19:00:17.65ID:aMJtnkBw shortだって64bit境界跨いでたら非アトミックだぞ
わざわざ作らなければそんなことにならないだろうけど
わざわざ作らなければそんなことにならないだろうけど
672デフォルトの名無しさん
2020/05/04(月) 19:06:17.15ID:heXhx7kW つかインテルアーキテクチャーのソフトウェアーデベロッパーズマニュアルによると
「8.1.1 Guaranteed Atomic Operations」
に書いてあったわサーセン;;;;
「8.1.1 Guaranteed Atomic Operations」
に書いてあったわサーセン;;;;
673デフォルトの名無しさん
2020/05/04(月) 19:09:35.51ID:heXhx7kW The Intel486 processor (and newer processors since) guarantees:
- Reading or writing a byte
- Reading or writing a word aligned on a 16-bit boundary
- Reading or writing a doubleword aligned on a 32-bit boundary
The Pentium processor (and newer processors since) guarantees:
- Reading or writing a quadword aligned on a 64-bit boundary
- 16-bit accesses to uncached memory locations that fit within a 32-bit data bus
The P6 family processors (and newer processors since) guarantee:
- Unaligned 16-, 32-, and 64-bit accesses to cached memory that fit within a cache line
とのことなので「The Pentium processor (and newer processors since) 」ならおk
- Reading or writing a byte
- Reading or writing a word aligned on a 16-bit boundary
- Reading or writing a doubleword aligned on a 32-bit boundary
The Pentium processor (and newer processors since) guarantees:
- Reading or writing a quadword aligned on a 64-bit boundary
- 16-bit accesses to uncached memory locations that fit within a 32-bit data bus
The P6 family processors (and newer processors since) guarantee:
- Unaligned 16-, 32-, and 64-bit accesses to cached memory that fit within a cache line
とのことなので「The Pentium processor (and newer processors since) 」ならおk
674デフォルトの名無しさん
2020/05/04(月) 19:15:43.74ID:heXhx7kW で、「The P6 family processors (and newer processors since) 」において
キャッシュラインを跨ぐとatomicが保証されない旨がその下に書かれているので、
- Unaligned 16-, 32-, and 64-bit accesses to cached memory that fit within a cache line
は妄信はできん
やっぱalignedな場合しか信用できん
キャッシュラインを跨ぐとatomicが保証されない旨がその下に書かれているので、
- Unaligned 16-, 32-, and 64-bit accesses to cached memory that fit within a cache line
は妄信はできん
やっぱalignedな場合しか信用できん
675デフォルトの名無しさん
2020/05/04(月) 19:18:59.34ID:/R09lZ8N まあ今時のプロセッサだとキャッシュライン単位でしかdramアクセスしないからそうなるのが自然なんだよね
676デフォルトの名無しさん
2020/05/04(月) 20:44:57.79ID:Aib9AjJN こういう非常時でも特に誰かがプログラムで社会貢献してるとは聞かないな
677デフォルトの名無しさん
2020/05/05(火) 05:46:34.77ID:EU5dGh0t アングル:コロナ感染経路、スマホ使った「接触追跡」の最前線
https://jp.reuters.com/article/health-coronavirus-tracing-idJPKCN21X0LE
つかビッグデータ取り扱い系分野は災害時に地味に活躍している印象
ホンダとか東日本大震災翌日からインターナビで収集した情報で被災地の道路寸断マップを
作って公開したんだったと思った(記憶モード
https://www.honda.co.jp/news/2011/4111109.html
https://jp.reuters.com/article/health-coronavirus-tracing-idJPKCN21X0LE
つかビッグデータ取り扱い系分野は災害時に地味に活躍している印象
ホンダとか東日本大震災翌日からインターナビで収集した情報で被災地の道路寸断マップを
作って公開したんだったと思った(記憶モード
https://www.honda.co.jp/news/2011/4111109.html
678デフォルトの名無しさん
2020/05/05(火) 07:41:06.24ID:NyxHUKM5 ビッグデータを公開してくれれば誰か作るんじゃね
679デフォルトの名無しさん
2020/05/05(火) 07:46:04.08ID:pSJxQCb1680デフォルトの名無しさん
2020/05/06(水) 11:06:32.37ID:lE4/XlkX >>611
その変の話は詳しくないので分からないのですが、この質問は、マルチコアやマルチCPUでの話ですか。
前から、その辺は、CriticalSection()などで排他処理すれば問題ないのではないかと思っていたのですが、その変どうなんでしょう?
それとも、自作OSなどで、 CriticalSection()のようなものを自作する場合の話でしょうか?
ちなみに、xor xchg などの話はよく理解できてません。
これらは、複数のCPUが1つのフラグを同時に読み書きした場合の問題なんでしょうか。
その変の話は詳しくないので分からないのですが、この質問は、マルチコアやマルチCPUでの話ですか。
前から、その辺は、CriticalSection()などで排他処理すれば問題ないのではないかと思っていたのですが、その変どうなんでしょう?
それとも、自作OSなどで、 CriticalSection()のようなものを自作する場合の話でしょうか?
ちなみに、xor xchg などの話はよく理解できてません。
これらは、複数のCPUが1つのフラグを同時に読み書きした場合の問題なんでしょうか。
681デフォルトの名無しさん
2020/05/06(水) 11:15:03.91ID:lE4/XlkX >>680
マルチCPUなどの場合は、キャッシュの同期(?)も関係してくるので、
そもそも何を持って「atomic」かどうかということが疑問になってきます。
キャッシュの内側で、CPUが、atomicにキャッシュに書きこんだつもりで
あっても、他の CPU のキャッシュに反映されない可能性があるので意味が
ないように思えます。
となれば、キャッシュ制御まで含めて考えないといけません。
キャッシュも、1次キャッシュ、2次キャッシュ、データ用キャッシュ、
コード用キャッシュ、パイプライン、などものすごく複雑になっているので、
果たしてそういうようなものを含めて「atomic」という言葉ですべてを語ることが
出来るのかどうかも疑問です。
マルチCPUなどの場合は、キャッシュの同期(?)も関係してくるので、
そもそも何を持って「atomic」かどうかということが疑問になってきます。
キャッシュの内側で、CPUが、atomicにキャッシュに書きこんだつもりで
あっても、他の CPU のキャッシュに反映されない可能性があるので意味が
ないように思えます。
となれば、キャッシュ制御まで含めて考えないといけません。
キャッシュも、1次キャッシュ、2次キャッシュ、データ用キャッシュ、
コード用キャッシュ、パイプライン、などものすごく複雑になっているので、
果たしてそういうようなものを含めて「atomic」という言葉ですべてを語ることが
出来るのかどうかも疑問です。
682デフォルトの名無しさん
2020/05/06(水) 11:18:02.52ID:q6Rk1GB6 自演かと思ったらレス繋いでるだけか
紛らわしい
紛らわしい
683はちみつ餃子 ◆8X2XSCHEME
2020/05/06(水) 11:26:57.76ID:exILxtx0684デフォルトの名無しさん
2020/05/06(水) 12:03:09.47ID:+O5RjP+P >>611の意味は
読み書きの途中で他のCPUやコア、スレッドが別の処理を行う事で一貫性が無くなる事は無いということ
例えばatomicでないと
64bitの一部を書き込んだところで
他のスレッドが値を読んでしまって
64bit全体としてあり得ない値になる
というような事が起こらない
というだけ
同期とか他の読み書きとの順番とか
そういう事はatomicは何も保証しない
読み書きの途中で他のCPUやコア、スレッドが別の処理を行う事で一貫性が無くなる事は無いということ
例えばatomicでないと
64bitの一部を書き込んだところで
他のスレッドが値を読んでしまって
64bit全体としてあり得ない値になる
というような事が起こらない
というだけ
同期とか他の読み書きとの順番とか
そういう事はatomicは何も保証しない
685はちみつ餃子 ◆8X2XSCHEME
2020/05/06(水) 12:24:44.67ID:exILxtx0 データベースとかで言う Atomicity と同じやね。
686デフォルトの名無しさん
2020/05/06(水) 14:18:32.19ID:lE4/XlkX687デフォルトの名無しさん
2020/05/06(水) 14:20:11.10ID:lE4/XlkX OSカーネルの実装以外では、命令自体の atomic 性に期待するのではなくて、
ちゃんと、OS が用意している API や system call を使って、CriticalSection
的なブロックを作って、その中で読み書きするのが基本ではないですかね。
ちゃんと、OS が用意している API や system call を使って、CriticalSection
的なブロックを作って、その中で読み書きするのが基本ではないですかね。
688デフォルトの名無しさん
2020/05/06(水) 14:25:21.35ID:E/8R3YZo689デフォルトの名無しさん
2020/05/06(水) 14:39:37.52ID:lE4/XlkX MotherBoard上にもキャッシュがありますし、マルチコアではなく、マルチCPUの
環境だと、いくらCPUがatomicに書いているつもりでも、バスでつながっている
他のCPUのキャッシュには反映されていない可能性もあるのではないでしょうか。
環境だと、いくらCPUがatomicに書いているつもりでも、バスでつながっている
他のCPUのキャッシュには反映されていない可能性もあるのではないでしょうか。
690デフォルトの名無しさん
2020/05/06(水) 14:47:57.71ID:E/8R3YZo691デフォルトの名無しさん
2020/05/06(水) 14:50:55.17ID:E/8R3YZo お前のバカなところはてめぇの無知を自覚せずに
atomicは不要というぶったぎり論を始めたところだ
もしいい年したおっさんなら芽がない
atomicは不要というぶったぎり論を始めたところだ
もしいい年したおっさんなら芽がない
693デフォルトの名無しさん
2020/05/06(水) 15:28:47.16ID:dxwAL6rC >>691
そんなに物知りなら、こんなところで聞かずにIntelマニュアルでも調べたら分かることじゃないか。
そんなに物知りなら、こんなところで聞かずにIntelマニュアルでも調べたら分かることじゃないか。
694デフォルトの名無しさん
2020/05/06(水) 15:32:15.22ID:dxwAL6rC はっきり言って、ここで double 値への書き込み atomic だなんて言ってる人の言うことはどこまで信用できるか分からん。
x86 CPU的には、xchg命令など一部の命令を除いてはそんなことは保障されてるかどうか定かではない。
x86 CPU的には、xchg命令など一部の命令を除いてはそんなことは保障されてるかどうか定かではない。
695デフォルトの名無しさん
2020/05/06(水) 15:40:04.68ID:g1nQsgpd696デフォルトの名無しさん
2020/05/06(水) 16:04:50.82ID:dxwAL6rC lock prefix は、mov 命令には付けられないがな。
697デフォルトの名無しさん
2020/05/06(水) 16:15:13.22ID:zSUZ9nVL データ競合と競合状態ごっちゃにしてない?
698デフォルトの名無しさん
2020/05/06(水) 16:36:19.56ID:DK2U3wBE アトミックはいわゆるout of thin airな値の発生を防ぐためのもの
それ以上でもそれ以下でもない
それ以上でもそれ以下でもない
699デフォルトの名無しさん
2020/05/06(水) 16:50:28.87ID:8YawtAIF std::atomic の意味付けとごっちゃになるから、「割り込み不可」「不可分」あたりと使い分けてほしいなぁ。
700デフォルトの名無しさん
2020/05/06(水) 17:03:54.41ID:dxwAL6rC もしかして、
double g_dbl[1024];
に対して、何かの値を足すような動作を、2つ以上のスレッドで
分担して行うことで高速化しようとしているのか?
そんなやり方は、マルチスレッドプログラミングでやっていいのだろうか。
普通は、要素番号 0〜511 までをスレッド1が、512〜1023 までをスレッド2
が計算して高速化する。
全く同じ場所に複数のスレッドが書きこむことは原則としてやらないはずだ。
double g_dbl[1024];
に対して、何かの値を足すような動作を、2つ以上のスレッドで
分担して行うことで高速化しようとしているのか?
そんなやり方は、マルチスレッドプログラミングでやっていいのだろうか。
普通は、要素番号 0〜511 までをスレッド1が、512〜1023 までをスレッド2
が計算して高速化する。
全く同じ場所に複数のスレッドが書きこむことは原則としてやらないはずだ。
701デフォルトの名無しさん
2020/05/06(水) 17:08:11.44ID:dxwAL6rC >>701
GPGPUを使ったレイトレーシングでも、画面上の別のピクセルをそれぞれのコアが
計算するのが原則で、1つのピクセルを複数のコアが分担して計算するには、それなりの
工夫がいる。
工夫というのは、途中までは別のワーキングエリアに書きこんでおいて、最後に
その結果を基本的にシングルコアで足し合わせて最終結果とするようなことだ。
これだと、例えば、途中の計算を double型で行うとしても、doubleへの書き込みが
atomicであることは特に必要ない。
GPGPUを使ったレイトレーシングでも、画面上の別のピクセルをそれぞれのコアが
計算するのが原則で、1つのピクセルを複数のコアが分担して計算するには、それなりの
工夫がいる。
工夫というのは、途中までは別のワーキングエリアに書きこんでおいて、最後に
その結果を基本的にシングルコアで足し合わせて最終結果とするようなことだ。
これだと、例えば、途中の計算を double型で行うとしても、doubleへの書き込みが
atomicであることは特に必要ない。
702デフォルトの名無しさん
2020/05/06(水) 17:11:26.13ID:E/8R3YZo703デフォルトの名無しさん
2020/05/06(水) 17:14:17.87ID:dxwAL6rC 気になったのは、「atomic」というコンピュータサイエンスで用いられている
言葉を >>611 のように実際のCPUで出来ているかどうか質問していること。
IntelのCPUマニュアルでは、atomicという言葉は使わずに、#LOCK PINアサート
が立つかどうかや、キャッシュコヒーレンシー、といった言葉で説明されている。
「atomic」という言葉は、キャッシュなどが「無いものとして分かり易く」
理解するには有効であるが、実際のCPUではキャッシュの一貫性や、PCIバス規格
と絡んだ詳細な説明が必要となる。
何を持って「atomic」というか、という問題が起きるからだ。
言葉を >>611 のように実際のCPUで出来ているかどうか質問していること。
IntelのCPUマニュアルでは、atomicという言葉は使わずに、#LOCK PINアサート
が立つかどうかや、キャッシュコヒーレンシー、といった言葉で説明されている。
「atomic」という言葉は、キャッシュなどが「無いものとして分かり易く」
理解するには有効であるが、実際のCPUではキャッシュの一貫性や、PCIバス規格
と絡んだ詳細な説明が必要となる。
何を持って「atomic」というか、という問題が起きるからだ。
704デフォルトの名無しさん
2020/05/06(水) 17:18:53.44ID:dxwAL6rC >>702
movも、実際のCPUでは必ずしもatomicとは限らない。
まず、alignment 境界を跨いででいるような場合や、
物理的に複数のCPUがマザーボード上にある場合のキャッシュの一貫性の問題が
あるから。
Intelの最適化マニュアルなどで、マルチコア並列化の例として上がってないような
方法は、勝手にやると破綻するかもしれない。
実機で実験してやるのは自由だが、他の人のCPUでは誤動作するのは覚悟した方がいい。
「アメリカ人は、書いてないものを勝手に使ったあなたが悪い」
という思想だぞ。
movも、実際のCPUでは必ずしもatomicとは限らない。
まず、alignment 境界を跨いででいるような場合や、
物理的に複数のCPUがマザーボード上にある場合のキャッシュの一貫性の問題が
あるから。
Intelの最適化マニュアルなどで、マルチコア並列化の例として上がってないような
方法は、勝手にやると破綻するかもしれない。
実機で実験してやるのは自由だが、他の人のCPUでは誤動作するのは覚悟した方がいい。
「アメリカ人は、書いてないものを勝手に使ったあなたが悪い」
という思想だぞ。
705デフォルトの名無しさん
2020/05/06(水) 17:31:25.73ID:E/8R3YZo >>704
マニュアルに安全な具体例として載ってないから疑ってるって話ね
ご自由にどうぞ
でもそれはあくまでお前の判断
メジャーコンパイラがintelのサポートうけてないとは思えないから
おれはコンパイラの出力眺めてみるけどね
マニュアルに安全な具体例として載ってないから疑ってるって話ね
ご自由にどうぞ
でもそれはあくまでお前の判断
メジャーコンパイラがintelのサポートうけてないとは思えないから
おれはコンパイラの出力眺めてみるけどね
706デフォルトの名無しさん
2020/05/06(水) 17:39:01.96ID:dxwAL6rC707デフォルトの名無しさん
2020/05/06(水) 17:49:26.97ID:+O5RjP+P708デフォルトの名無しさん
2020/05/06(水) 17:51:54.81ID:+O5RjP+P 色々な理由でやむを得ず使う上級者の技を
素人がまねしなくて良い
素人がまねしなくて良い
709デフォルトの名無しさん
2020/05/06(水) 17:57:11.74ID:E/8R3YZo >>706
ちなみにメジャーコンパイラが
std::atomic<double> & std::memory_order::relaxed
をどう展開するか知ってるんだよね?
これを疑ったらコンパイラを自作するしかないんでは?
ちなみにメジャーコンパイラが
std::atomic<double> & std::memory_order::relaxed
をどう展開するか知ってるんだよね?
これを疑ったらコンパイラを自作するしかないんでは?
710デフォルトの名無しさん
2020/05/06(水) 18:31:40.49ID:dxwAL6rC■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 空自機レーダー照射、音声データ公開 中国 ★3 [蚤の市★]
- 日銀「歴史的」利上げ迫る 35年ぶりの年間上げ幅、0.5%の壁を突破 [蚤の市★] [蚤の市★]
- 【YouTuber】バイク事故で入院のゆたぼん、振込で「お見舞金」募る [muffin★]
- 津波警報の発表中にグーグル検索、AIが「すべて解除」と誤情報 [蚤の市★]
- 低所得層のマクドナルド離れが深刻に 広がる「ファストフード格差」の真相 米国 [少考さん★]
- 堀江貴文、キャッシュレス非対応の店にモヤッ 『PayPay』立ち上げの人物にまさかの直談判「現金決済しかできないんだけど…」 [冬月記者★]
- 【実況】博衣こよりのえちえち朝活🧪
- 寒すぎてハゲたんやが
- 【悲報】婚活女子(38)「婚活パーティーに行ったら婚活男性の大部分が年収350万円身長165cm未満のコミュ障子供部屋おじさんで絶望してる… [257926174]
- 「農林水産業」で賞与が激増!コメや卵など食料品高騰で大儲け [481941988]
- (´・ω・`)おはよ
- 朝からハイエースでカップラーメン食べてるドカタ
