C++相談室 part150

■ このスレッドは過去ログ倉庫に格納されています
2020/03/24(火) 00:04:33.93ID:YFRNwZnv
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/ (日本語)

テンプレここまで
2020/05/01(金) 18:21:10.38ID:wrmDV0oq
>>569
それは当たり前で、マシンには4GB以上のメモリが乗っているので、32BIT
では、OSレベルでは扱いにくい。
多くのプログラマにとって大事なのは、個々のアプリの問題だから、
OSレベルの話は関係ない。、
また、Windows OSがメモリーを食いすぎているという問題もある。
2020/05/01(金) 18:23:48.97ID:wrmDV0oq
>>580
補足すれば、グラフィック用のRAMは大きくなりがちで、最近のWindowsでは、
1つのWindowに仮想VRAMを割り当てているから、アプリが起動するたびに
グラフィック用になかなか大きなメモリーを消費する。
それと、ブラウザで複数のタブを開いている影響。
あれもグラフィックのレンダリング用に大量のメモリーを食っているのかもしれない。
2020/05/01(金) 18:31:06.76ID:IyliQkiG
>>577
他人を説得するつもりがないなら不特定多数が集まる場で自論を展開せず、馬鹿なこと言ってるなフフッて一人悦に入ってればいいんでない?
2020/05/01(金) 18:32:39.35ID:IyliQkiG
>>575
全面的に同意
2020/05/01(金) 18:40:33.09ID:DtDCGOpK
>>575
私も同意
2020/05/01(金) 19:15:32.79ID:wrmDV0oq
>>580
今は、見えないものまで含めれば50個のプロセスが動いているなんてことは当たり前になっている。
だから、個々のプロセスが80MBのメモリしか使って無くても、合計すれば4GBになる。
さらにファイルバッファや、OSが高速化のためにさまざまなキャッシュ的なデータを保持している。
しかも、ファイルバッファやキャッシュはいくらあっても不足する時代となった。
ブラウザがページを記録するためのキャッシュも必要だ。
そういう訳で、アプリが80MBしか使って無くても、OS全体では4GBではメモリが不足する。
というわけで、4GBを超えるメモリが必要となっている。
タスクマネージャーで見ていても、個々のアプリは、多くても数百MB程度のものが多い。
ファイル高速検索ツールなんかが、1.6GBも使っていたりするが、それは特殊。
だから「特殊なものを除いては」今のアプリが2GBを超えるメモリーを必要とすることは稀、だと言っている。
2020/05/01(金) 19:19:38.83ID:DtDCGOpK
それ
64bitで4倍
とどういう関係?
2020/05/01(金) 19:22:30.31ID:DtDCGOpK
32bit Windowsが4GBまでなのはWindowsの仕様であってCPU自体はそんな縛りは無いし
2020/05/01(金) 19:51:53.68ID:wrmDV0oq
>>587
典型的には、32BIT mode でも、PAE サポートによって OS は 4GB を超える
メモリーを扱えるね。
2020/05/01(金) 20:58:17.99ID:9yUywlA0
64GBまで使えるようになったのPentium Proからだぜ?w
Klamathより前!!
2020/05/02(土) 00:04:20.13ID:jVHOaTi/
>>547
釣り針でかいなw ここム板だぜw
2020/05/02(土) 00:05:14.57ID:jVHOaTi/
>>587
おまえ嘘ばかりだなw
2020/05/02(土) 01:38:26.25ID:2lkgjmOV
>>591
いや、彼は正しいことを言っている。
あなたがIntel CPUの仕様を詳しく知らないだけ。
PAEという仕組みなどで32BITモードでも4GBを超える物理メモリーを扱うことができるようになっていた。
593デフォルトの名無しさん
垢版 |
2020/05/02(土) 01:45:40.91ID:ZXOrLboX
PAEが何なのか全く分かってなさそう
2020/05/02(土) 02:28:22.28ID:2lkgjmOV
QZは女なのだろうか。
ショックかも知れないがはっきり言えば、本質的に物事が正確に理解できていないようだ。
2020/05/03(日) 09:20:54.04ID:slLa0KBW
EMSなら前に聞いたことがある
2020/05/03(日) 09:24:35.32ID:WVD/IFzz
8bit CPUは256Bしか扱えないと思ってる人いる?
2020/05/03(日) 09:29:47.71ID:6v/wuiGx
16bitのCPUでも16bitアドレスの最大値である64KBを超えて1MBもアクセスできていたからな。
2020/05/03(日) 10:03:25.11ID:WVD/IFzz
>>594
女なら180度対応を変えます
2020/05/03(日) 10:22:47.73ID:LxtsyLet
>>597
16BIT CPU であった 8086は、16bit アドレスを超える範囲は、セグメントレジスタ
と合わせた seg:ofs の形式の far pointer を使わなくてはならならず、
単純に扱えるのは16BITまでで、16BITを超えた範囲では、seg レジスタの値を
足していかないといけなかった。しかも、segがアドレスの上位16BITだったなら
まだしも、16バイト単位のアドレスだったので、segレジスタに入れる値を計算
するのがとても重くなってしまっていた。
ところが、Z80 などの 8BIT CPUは、普通に 16BIT レジスタの
HL や DE, BC, IX, IY をもっており、8086 と比べれば扱いは容易だった。
その意味では、8086は、メモリーアクセスに関してはZ80と同じくらいしか
能力を持っていなかった。
それで8086の16BITモードでは限界が来て32BITモードのOSが待望された。
そしてMacのGUIを真似た機能を持っていたこととも合わせて32BITモードで
動いたWin95となった。

ただし、このような状況は64BIT化に関しては全く無い。
2020/05/03(日) 10:32:19.81ID:6v/wuiGx
そりゃまあ、64bitCPUがすでにいきわたっていてOS変えるだけで対応できたからね
WINAPIだって16→32のコンパイルはまず動かないけど32→64なら普通は動く
DOS時代のUMBみたいなみみっちい事態にならなくてよかったじゃん
2020/05/03(日) 10:35:22.17ID:OJMdC3Cv
86用コンパイラでnearとfarの他にhugeが有ると知らず、無限ループ作ってOSごと来なくなったあの頃
2020/05/03(日) 11:16:28.83ID:WVD/IFzz
結局64bit CPUだと速度4倍のコードは?
2020/05/03(日) 13:08:16.85ID:m/iHOjCC
long longとint64_tの違いってlong longは環境によって64bitじゃなくなるけどint64_tは常に64ってことですか?
2020/05/03(日) 13:13:36.85ID:LxtsyLet
>>603
まあ、そういうこと。
2020/05/03(日) 14:04:07.52ID:slLa0KBW
           |
            |  彡⌒ミ
           \ (´・ω・`) またhugeの話してる・・・
             (|   |)::::
              (γ /:::::::
               し \:::
                  \
2020/05/03(日) 14:24:10.29ID:m/iHOjCC
>>604
ありがとうございます
2020/05/03(日) 15:56:11.79ID:gvP0MmQx
32bitの環境で32bitの境界を超えるような64bit値の計算ってどうやって実現してるの?
2020/05/03(日) 16:00:56.90ID:uzK0zokK
cpuに命令なければソフト的にやるに決まってんじゃん
2020/05/03(日) 16:06:34.35ID:uzK0zokK
ちなみに32bitの掛け算の答えに64bit必要ってわかってない人多いよね
同様に64bitなら128bit
610843
垢版 |
2020/05/03(日) 16:22:11.00ID:OGvyQUVV
>>607
まずは筆算の足し算からやり直そうか
2020/05/03(日) 16:54:49.03ID:+PpSUNNp
64bitだとdoubleとかの書き込みはアトミックになるの
612デフォルトの名無しさん
垢版 |
2020/05/03(日) 17:17:29.21ID:VkK7EFZv
C/C++にキャリーフラグ観る機能が無いのはなせ?
2020/05/03(日) 17:56:41.69ID:baOIQvWk
アトミックにしたけりゃstd::atomicを使え
使わない場合は保証されない
2020/05/03(日) 18:16:14.79ID:uzK0zokK
>>612
いれるとしたらどんな仕様でいれる?
そこまで考えてから書いてみたんだよな?
2020/05/03(日) 18:19:51.49ID:uzK0zokK
>>613
64bitでない環境だとatomic持ち出したところで使えないじゃん
2020/05/03(日) 18:25:40.26ID:baOIQvWk
使えるぞ
内部でロックするから遅いけど
2020/05/03(日) 20:09:19.86ID:7Ft0FuY4
>>598
90度だろ?
2020/05/03(日) 20:16:01.21ID:s7MuzCvB
モダンc++入門ってどこみたらいい?
2020/05/03(日) 21:01:49.43ID:0Fr9Yznx
cpprefjp
2020/05/03(日) 22:43:31.73ID:WVD/IFzz
>>611
ほとんどの環境でYES
32bit CPUでもアトミックな環境もある
2020/05/03(日) 22:46:00.66ID:WVD/IFzz
>>612
キャリーフラグが無いCPUも有るから
CPU固有の機能はintrinsicを使う
2020/05/03(日) 22:52:17.09ID:WVD/IFzz
>>609
整数の乗算を全範囲正確に求めたい場合の話だな
これもC++では書けない
intrinsicを使う
2020/05/03(日) 22:53:53.78ID:WVD/IFzz
>>617
なんで90度?
180度だって書いてるのに
2020/05/04(月) 03:33:26.41ID:BnrivxPo
int128でもint256でも自由に型が作れるのがC++の強みなのに書けないってw
2020/05/04(月) 06:12:26.01ID:/zUHO7E0
int_<256>みたいの作ってたけど
サイズが発散する問題がすぐ起きる
626843
垢版 |
2020/05/04(月) 07:19:32.37ID:oxprEh+7
>>620
> 32bit CPUでもアトミックな環境もある
具体的な環境名教えて
627843
垢版 |
2020/05/04(月) 07:20:47.92ID:MJc5y26W
>>623
(女は)話をはぐらかすって事だろ
2020/05/04(月) 07:22:03.70ID:nMCshN11
x86
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()
2020/05/04(月) 08:04:47.44ID:S2aUUuq2
後、SetPointerする前にshared_ptrの参照カウントを一つ増やしたいです。
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 が抜けないようにする。
2020/05/04(月) 10:27:13.66ID:aMJtnkBw
本当にshared_ptrごと格納する必要があるの?
これで良かったりはしない?

shared_ptr<Hoge> p(new(buffer) Hoge, [](Hoge* p){p->~Hoge();});
2020/05/04(月) 11:04:11.62ID:BnrivxPo
つまりshareする気がないけどshared_ptrを使いたいわけだな
2020/05/04(月) 11:24:26.33ID:7IQ5DE83
誰かと食べる気はないけど、マックのシェアポテトを食べたい感覚だね
2020/05/04(月) 12:42:16.41ID:S2aUUuq2
>>632
これ難しすぎて解読できません

まず、やりたいことはWindowsのTreeViewでノードを追加するときに、ノードにLPARAM型の任意のデータを関連づけれるんですが、そこに他の関数から受け取ったshared_ptr<Hoge>を関連付けたいのです

shared_ptrごと格納する必要ないと言えばないのかもしれません
でも中身だけ格納すると、deleter?の情報がとんじゃう?
2020/05/04(月) 12:55:51.13ID:S2aUUuq2
>>631
こっちの方で後で試してみます
2020/05/04(月) 13:16:44.39ID:0skWT8b9
なにがしたいのだかいまいちよくわからない
2020/05/04(月) 13:20:23.37ID:/R09lZ8N
所有したいのか/参照持ちたいだけなのか
shared_ptrとして使う必要があるのか
参照だけ持ちたいとしてダングリングの可能性が有るのか
2020/05/04(月) 13:46:24.04ID:S2aUUuq2
あーあ。shared_ptrごと格納できるならそっちの方がいいです。
そうしないと誰が最後にdeleteするかめんどくさくなりなすね。
すみませんでした
2020/05/04(月) 13:47:34.57ID:aMJtnkBw
TreeViewが持つのはポインタだけで、オブジェクトの寿命管理するわけじゃないんだろ?
だったらshared_ptrのdeleterの情報なんか渡す必要ないんじゃないか
オブジェクトの寿命管理する奴が知ってればそれでいい
2020/05/04(月) 13:56:33.16ID:tzWRkvZC
>>639
shared_ptrはlparamに収まらないから無理
sizeofで確かめてみ
2020/05/04(月) 14:01:15.39ID:S2aUUuq2
すみません。何か頭混乱してきた・・
>>630が余計だったのか・・

まず、基本方針としてオブジェクトの寿命管理を楽にするためにクラス間でデータをやり取りする場合は
全部shared_ptr経由で参照カウントにより自動で管理してもらおうという方針です。

ですが、既存のライブラリとの都合で例えば、今回のTreeViewのノードにはLPARAM型のデータしか関連づけらられない
ということで、ノードに関連づけるときに参照カウント手動で?増やしてあげて、ノードを削除するときに、
参照カウントを手動で減らして?あげて調整するものなのかなぁーと思った次第です。
2020/05/04(月) 14:02:14.17ID:/R09lZ8N
データの本体は別にあってそっちで所有権管理しているなら、treeviewにはshared_ptr::getで得られるpointer持たせればいい
使う側でshared_ptrである必要があるなら、shared_from_this使う

ダングリングする可能性無いならならこれでおk
2020/05/04(月) 14:12:18.91ID:aMJtnkBw
void*で渡しちゃう以上はTreeViewに参照カウント減らさせるのは不可能なので、そこは外側で管理してやるしかない
だったらTreeViewはshared_ptrがどうのこうのという情報は知らなくていいし、知らせるべきでない
2020/05/04(月) 14:19:40.83ID:tzWRkvZC
>>644
TreeViewってのはWindowsの既存のコンポーネントだろ
ちょっとまとはずれだよ
答えは >>631 で出てる

>>639
手動deleteが本当にいやならあとは黒魔術使うしかないね
unique_ptrなら64bitにおさまるだろう
2020/05/04(月) 14:23:16.16ID:aMJtnkBw
>>645
既存のコンポーネントだからだよ
shared_ptrのこと知らんやつにshared_ptr渡したってろくなことにならんだろ
2020/05/04(月) 14:33:47.37ID:tzWRkvZC
>>646
荒らしたくないがもうちょっと質問者の内容くみとってから返事書いてやれよ
shared_ptrの型で渡すんじゃなくてvoid*の型で渡すって最初から言ってんじゃん
2020/05/04(月) 14:47:05.48ID:aMJtnkBw
何が気に食わなくて噛み付いてるのかよくわかんないけど
TreeViewはshared_ptrのことなんか知らないんだから、そんなものは知らせずに
関連のあるデータを与える(要はshared_ptr<Hoge>*じゃなくてHoge*を渡す)方が設計すっきりするんじゃない?
って言ってるだけなんだがそんなにおかしいか?
2020/05/04(月) 14:51:53.81ID:Zy37Y+hL
何か追加して問題が出て別の何か追加して解決するの繰り返し
C++の仕様は余計なものが多い
メモリーの所有権の移動とかの暗黙知の極みを気にできるくらいならdelete忘れることはないだろうに
2020/05/04(月) 14:57:19.53ID:Fiop0J3e
Hoge* 渡して済むなら最初から相談なんて発生しないだろうと思ってたんだけど、
>642 みたいな「基本方針」だと shared_ptr の必要性が胡散臭いんで、確かに
Hoge* で済む可能性もありそうな気がしてきた。
2020/05/04(月) 15:00:15.13ID:tzWRkvZC
>>648
shared_ptrでわたってくるものをvoid*で管理したいってことで
それは質問の前提条件
解としてHoge* にするってのは破綻するからダメでしょ
2020/05/04(月) 15:10:46.19ID:S2aUUuq2
>Hoge* 渡して済むなら最初から相談なんて発生しないだろう
そうです。Hoge*で渡したくないから質問した次第です。

元のデータが先に捨てられようと、先にTreeViewのノードが破棄されようと、どっちが先でも
OKなように、それらを意識しないようになるべく参照カウントの仕組みで破棄したかったわけです。
2020/05/04(月) 15:22:06.17ID:aMJtnkBw
だったら>>631も、結局TreeViewの破棄を監視して破棄前にdelete GetPointer()かけないといけないんだけど
それでもいいのか?本当に意識すべきことは減ってるのか?無用な複雑さを持ち込んでるだけじゃないのか?
っていうことを一回冷静に考えた方がいいよ
2020/05/04(月) 15:23:27.04ID:Zy37Y+hL
逆にHoge*で受け取って、
Tree破棄時にPointer破棄処理省いてしまって、
あとはsharedのスコープで全消しすればいい
もちろんノード追加時に参照カウンタ増やす必要もない
2020/05/04(月) 15:24:48.96ID:S2aUUuq2
>>653
それは問題ないです。
>>642
>参照カウントを手動で減らして?あげて調整する
って元からそれをやる前提でした
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*でいきます
2020/05/04(月) 15:54:22.23ID:Fiop0J3e
>>656
new した shared_ptr を delete すれば参照カウント減るよ。
でも Hoge* で済むならそっちで済ませたほうが面倒も無くて効率もいいだろうよ。
2020/05/04(月) 16:04:26.16ID:aMJtnkBw
そもそもTreeViewってViewだから見た目を整えるための奴でしょ
自分ならロジックデータの寿命管理にそんな奴参加させたくないな

まあ、削除時のコールバックが指定できるんだったら、それで後始末するのも手ではあるかもね
小さいプログラムで、見た目の要素の何かとHogeが論理的に一対一対応してるんだったら許容範囲かな
2020/05/04(月) 16:11:26.04ID:tzWRkvZC
>>653
質問者はクラス間で共有するデータは一律shared_ptrにすると言っている
これは全体設計の選択としてまぁある話

しかしこれによって既存コンポーネントのTreeViewで
インタフェースのミスマッチが起こった、さてどうしたらいいでしょう?
という質問なわけ
これもよくある問題

だからって全体設計のポリシーをとりやめようとはならのよ
解決できる手段があるなら部分的な問題は個別に解決したらそれでいい
2020/05/04(月) 16:29:01.02ID:aMJtnkBw
>>659
言ってることは分かるけど
それでどうしてTreeViewにshared_ptrを埋め込むことに固執するのかがわからない
そこはおとなしくTreeViewには生ポで参照してもらうっていうのも一つの「部分的な問題の個別解決」じゃないの?
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ファイルが出きてしまうのは避けられないのでしょうか?
2020/05/04(月) 17:07:30.46ID:aMJtnkBw
単に.oを複数与えればいいんじゃないの?
何か問題あったっけ
2020/05/04(月) 17:11:45.42ID:mcNTUyFW
>>656
汚い手段を避けるなら、
shared_ptr を受け取って保管し、管理用のハンドルを返すクラスを作って
TreeViewにそのハンドルを入れとけばいいのでは。
2020/05/04(月) 17:12:19.55ID:heXhx7kW
>>628
ちょっx86やx64でアトミックに読み書きできる(バスサイクルが他コアに割り込まれない)ことが保証されているのは
32 bitまででしかも32 bit境界に整列している場合のみのでは…
ちなdoubleは64 bit
2020/05/04(月) 17:30:50.31ID:b5BOjBYY
>>662
あっ、それでできるんですか。
ありがとうございます、やってみます!
2020/05/04(月) 18:05:00.17ID:hwmiGMKy
>>664
64bit境界であることは必須
あとは大昔のCPUじゃなければアトミック
2020/05/04(月) 18:43:33.39ID:wRQD0Fqh
wandbox上だとatomic<double>はロックフリーらしい、多分x86-64環境なら同じ
https://wandbox.org/permlink/0LWMsNPNmSn6rpZ4
2020/05/04(月) 18:54:28.70ID:heXhx7kW
>>666
>64bit境界であることは必須
ハア(゚Д゚)?
ていうことは
 char *p = 〜;
 *p = 'a';
は、pが8の倍数でなければ非アトミック??
 short *q = 〜;
 *q = 123;
もまた、qが8の倍数でなければ非アトミック???

なんと?!
2020/05/04(月) 18:56:20.07ID:/R09lZ8N
doubleの話をcharに拡大して何がしたいのか
2020/05/04(月) 18:57:04.84ID:aRLx0l42
アスペは文脈が読めない
2020/05/04(月) 19:00:17.65ID:aMJtnkBw
shortだって64bit境界跨いでたら非アトミックだぞ
わざわざ作らなければそんなことにならないだろうけど
2020/05/04(月) 19:06:17.15ID:heXhx7kW
つかインテルアーキテクチャーのソフトウェアーデベロッパーズマニュアルによると
「8.1.1 Guaranteed Atomic Operations」
に書いてあったわサーセン;;;;
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
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な場合しか信用できん
2020/05/04(月) 19:18:59.34ID:/R09lZ8N
まあ今時のプロセッサだとキャッシュライン単位でしかdramアクセスしないからそうなるのが自然なんだよね
2020/05/04(月) 20:44:57.79ID:Aib9AjJN
こういう非常時でも特に誰かがプログラムで社会貢献してるとは聞かないな
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
2020/05/05(火) 07:41:06.24ID:NyxHUKM5
ビッグデータを公開してくれれば誰か作るんじゃね
2020/05/05(火) 07:46:04.08ID:pSJxQCb1
>>677
見た夢をそのまま書くスレ26
https://mao.5ch.net/test/read.cgi/occult/1584792697/
2020/05/06(水) 11:06:32.37ID:lE4/XlkX
>>611
その変の話は詳しくないので分からないのですが、この質問は、マルチコアやマルチCPUでの話ですか。
前から、その辺は、CriticalSection()などで排他処理すれば問題ないのではないかと思っていたのですが、その変どうなんでしょう?
それとも、自作OSなどで、 CriticalSection()のようなものを自作する場合の話でしょうか?
ちなみに、xor xchg などの話はよく理解できてません。
これらは、複数のCPUが1つのフラグを同時に読み書きした場合の問題なんでしょうか。
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況