C# TreeViewについて質問させてください。
ノード(子ノード含む)を数万件以上登録する際に、効率の良い方法を教えて頂けないでしょうか?
実際のコードとは異なりますが、大まかに以下のような処理をメインスレッドで行っています。
class MyTreeNode : TreeNode{
void AddNode(){
BeginUpdate();
SuspendLayout();
foreach( var 親ノード情報 in 親ノード情報リスト ){
TreeNode parentNode = new TreeNode( 親ノード名 );
foreach( var 子ノード情報 in 子ノード情報リスト ){
TreeNode childNode = new TreeNode( 子ノード名);
parentNode.Nodes.Add( childNode );
}
this.Nodes.Add( parentNode );
}
ResumeLayout();
EndUpdate();
}
}
この方法ですと、かなり時間がかかってしまい、UIが固まったようになってしまいます。
(TreeViewに、子ノードの一斉展開機能が必要なので、親ノード展開時のイベントを拾って
子ノードを追加する方法は上記と同じく遅くなってしまうのではと思っていますがどうなんでしょうか?)
No.1ベストアンサー
- 回答日時:
今試せる環境がないので半分くらい無責任発言なんですが、一応案として、何かの参考になれば。
・効率が良くなるかもしれない方法
TreeNodeを配列化してAddRangeする(Addを使わず配列で渡す)
※配列はListではなくTreeNode[]でnew
・追加時間を短縮する方法
System.Threading.Tasks.Parallelを使って並列実行する
ぱっと見、1つの「親ノード情報」に対する子は予め決まってそうなので、「親ノード情報」単位で並列化が可能にみえます。ノード間で何かしら依存する場合はたぶん無理です。
・ノード追加処理を非同期化させるか、メッセージ処理をはさむ
UIが固まるのは、処理が重いからというより、ウインドウが長時間メッセージを処理できなくなるからです。
なので、たとえば何階層か展開する毎にメッセージ処理を挟めばUIが止まることはなくなります(処理中にウインドウが操作を受け付けるようになるので別の問題起き得ます)。
回答、ありがとうございます。
色々とバタバタして返信が遅くなってしまいました、すいません。
> TreeNodeを配列化してAddRangeする
この手法にて、約10万件追加されるときの時間が1秒以上改善されました。
大変たすかりました、ありがとうございます。
また、調査の結果、一番のネックになっているところが見つかりました。
(指摘頂いたコードを抜粋して質問させていただきましたが、そのあとの処理で親子ノード1個追加される度に、毎回Sortを実行していたので...)
試しに上記サンプルとSortを外して実行してみると、大きなストレスなく動作させることができました。
要望として、親ノードのソートはしたいですが、子ノードまでソートする必要はないと思われるので、ソート部分を自作して乗り切ろうと思います。
結局、質問した際のコードとは別のところが一番の原因で、大変申し訳ございません。
次はもう少し気をつけて質問します。
> System.Threading.Tasks.Parallelを使って並列実行する
> ノード追加処理を非同期化させるか、メッセージ処理をはさむ
上記2点についての案もありがとうございます。
私の今の力量では、期間内に両方検証し比較することができないので、後日時間があるときに、確認してみたいと思います。
(特にSystem.Threading.Tasks.Parallelは機能を確認してみると、できるとすごく便利そうです。)
複数の案とともに、処理改善もでき、一番の原因も判明いたしましたので、duke_kimuraさんをベストアンサーにさせていただき、この問題は解決済みにさせていただきたいと思います。
本当にありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コンテキストメニュークリック...
-
SNMP リンクダウンとノードダ...
-
ツリービューを閉じさせたくない。
-
C言語:文字列の並び替え
-
C# TreeViewのノードの判定
-
ルート要素ノードが2個ある場合?
-
昔Winnyってありましたけど、あ...
-
CPUの考え方を教えてください ...
-
ToolStripMenuItemの選択(VB)
-
ノード数とは?
-
複数のマックPCによる数値計算...
-
ノードとは
-
東芝のDynabookなのですがアン...
-
特殊記号が勝手にエスケープさ...
-
<xsl:key>とtopreceding-siblin...
-
UTF-8でエンコーディングとはど...
-
【アプリ開発】日本語を含むXML...
-
Visual Basic .NET の識別子は...
-
複数のxmlファイルの合体
-
XSLTでの正規表現判定
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CPUの考え方を教えてください ...
-
SNMP リンクダウンとノードダ...
-
同じタグ名の項目取得
-
昔Winnyってありましたけど、あ...
-
コンテキストメニュークリック...
-
ルート要素ノードが2個ある場合?
-
マスターノード
-
複数のマックPCによる数値計算...
-
あるノードリストに、特定の名...
-
TreeView の初期表示について
-
TreeViewの再表示のちらつきを...
-
ツリービューのノードをダブル...
-
C# TreeView 効率良いノード追...
-
ノード数とは?
-
XML文書の指定した属性値を持つ...
-
C#のツリービューでツリーノー...
-
VB6.0でDOMを使用して...
-
TreeViewで複数ノードの選択は...
-
ノードとは
-
VisualBasic.net(2008) ツリー...
おすすめ情報