[過去ログ]
マルチスレッドプログラミング相談室 (986レス)
マルチスレッドプログラミング相談室 http://toro.5ch.net/test/read.cgi/tech/997345868/
上
下
前次
1-
新
通常表示
512バイト分割
レス栞
抽出解除
レス栞
このスレッドは過去ログ倉庫に格納されています。
次スレ検索
歴削→次スレ
栞削→次スレ
過去ログメニュー
941: 772 [sage] 02/11/17 00:29 >>923 あ、違った。O1がBスレッドにあるという時点で 既に参照カウントがアガってなきゃいかんのか。 鬱だ…。 DataType O1; hr = pDataList->GetItem(index, &O1) ; if (FAILED(hr)) { /* エラー*/ } if (IsWanted(O1) とか。ふむ。確かにリスト側で排他したくなるし、 同時に他スレッドで削除されてると面倒。やっと分かった。 http://toro.5ch.net/test/read.cgi/tech/997345868/941
942: 767=793=902=918=921 [sage] 02/11/17 02:31 >>941 参照を得る/切るタイミングでアトミックにカウントが上がる/下がる必要が あるからなぁ。 そうでないと、無効なオブジェクトを参照してしまう。 ならば、参照カウントが 0 でも有効な(というより、無効かどうか判別できる) ものを作るのも一つの手だな。 bool Object::ref(){ bool valid = false; cs_.enter(); if(refCount_ > 0){ refCount_++; valid = true; } cs_.leave(); return result; } void Object::release(){ cs_.enter(); if(refCount_ > 0){ refCount_--; if(refCount_ == 0){ garbages__.add(this); } } cs_leave(); } で、安全なタイミングで(ってそれが一番むずい気も)garbages__(グローバル変数) の要素を delete してやると。 http://toro.5ch.net/test/read.cgi/tech/997345868/942
メモ帳
(0/65535文字)
上
下
前次
1-
新
書
関
写
板
覧
索
設
栞
歴
スレ情報
赤レス抽出
画像レス抽出
歴の未読スレ
AAサムネイル
Google検索
Wikipedia
ぬこの手
ぬこTOP
0.172s*