- 17 名前:デフォルトの名無しさん mailto:sage [2005/11/07(月) 13:39:08 ]
- C#スレで質問していたのですがこちらのスレのほうが適切化と思ったので再度質問させていただきます。
たとえば次のような場合どうします? 株価などのように高頻度に値が更新されてそれに対する処理、その値を基にしたほかの株価データをを必要とする計算や表示などを行う必要がある。 値が更新されるー>対象となるデータノードを検索ー>それに対し値などに応じた必要な処理という流れ。 対象となるデータのノード数は10万単位。ただしすべてメモリ処理するものとする。 複数のノードにまたがる更新処理はない。 ノードの削除処理はない。 こんな場合どんなロックの粒度にしてどんなデータ構造にします? 自分の場合だとデータノードをインスタンスとしてそれをコレクションクラスにぶっこんであるとして、データノードにその変化に応じて処理するobserverが引っ付いている。 コレクションクラスをロックー>データノード検索ー>コレクションクラスのロック解除ー>ノードの必要な箇所にロック-> ノード内の関連データをその部分にロックかけながらアトミックにupdate-> 該当箇所のロックをはずしobserverに通知->各observerがおのおの独自の処理を行う。その際におのおの必要なロックをかける。 こんなんなんですが、皆さんはどんな風にされるんでしょう?
|

|