質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

2回答

10636閲覧

複数フォルダを監視する場合のfilesystemwatcherの使い方は?

cancat

総合スコア313

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

0クリップ

投稿2017/03/30 03:22

こんにちは。
Windows10でWPFのアプリケーションを開発しています。
Visual Studio 2015 Communityを使っています。

###前提・実現したいこと
filesystemwatcherの使い方で悩んでいます。

複数のfilesystemwatcherを使い、相互に状態を見たいです。
複数のwatcherはいくつ使うかわからないので、動的に追加しています。

###試したこと
下記のようにwatcherを設定すると、それぞれのwatcherはfieldでないので参照できません。
こういうときはどのようにするものでしょう。

(1)rootを監視対象にして、すべてのサブフォルダを監視する。今回ならC:\。使うfilesystemwatcherはひとつ。パフォーマンスが心配。

(2)fieldにする。List<FileSystemWatcher>とか?
Createdでforeachする。

(3)その他。

###該当のソースコード

C#

1 2 private void button1Click(object sender, EventArgs e) { 3 string folder = @"c:\tmp1"; 4 var watcher1 = new FileSystemWatcher(); 5 watcher1.Path = folder; 6 watcher1.Created += Watcher1_Created; 7 watcher1.EnableRaisingEvents = true; 8 } 9 10 private void button2Click(object sender, EventArgs e) { 11 string folder = @"c:\tmp2"; 12 var watcher2 = new FileSystemWatcher(); 13 watcher2.Path = folder; 14 watcher2.Created += Watcher2_Created; 15 watcher2.EnableRaisingEvents = true; 16 } 17 18 private void Watcher1_Created(object sender, FileSystemEventArgs e) { 19 string createdfilepath = e.FullPath; 20 //ここでbutton2で作ったwatcher2を表示したい。 21 MessageBox.Show(watcher2.Path);//<private methodなのでない。 22 }

###補足情報(言語/FW/ツール等のバージョンなど)
Microsoft Visual Studio Community 2015
Version 14.0.25424.00 Update 3
Microsoft .NET Framework
Version 4.6.01038

インストールしているバージョン:Community

Visual C# 2015 00322-20000-00000-AA575
Microsoft Visual C# 2015

です。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

目的がよくわかりませんが("c:\tmp1"にファイルかフォルダが生成されたときに"c:\tmp2"のFileSystemWatcherを参照する目的)、とりあえず field にしたら良いのではないでしょうか。

インスタンスを生成するタイミング(この場合だとボタンのクリック時?)で field の List に Add するとかで。

ちなみに「button1_Click」じゃなくて「button1Click」なのは意味がありますか?
イベントハンドラではなくてただのメソッドとか。

投稿2017/03/30 04:38

workaholist

総合スコア559

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cancat

2017/03/30 08:04

コメントありがとうございます。 目的はうまく説明できません。すみません。 button1Clickには意味はありません。まあ、おっしゃるとおり、ただのMethodと考えていただいてよいと思います。それは(うまくいえませんが)質問の本質とは無関係な細部です。_がないことなんて、いままで気づいていませんでした。 とりあえずfieldですか。 watcher1, 2をフィールドとして宣言することはできません。 watcherの数は2個ではない(いくつかわからない)ためです。 宣言するとしたら、List<FileSystemWatcher> watchers = new List<FileSystemWatcher>();となります。 foreach使うのかと思うと気乗りしないです。 コードが少なそうなので、(1)のinclude subdrectoriesに魅力を感じてます。
guest

0

アプリの設計を少し変更したほうがよさそうです。

現状の設計だと、button1やbutton2がクリックされるたびに FileSystemWatcher のインスタンスが無限に作られて行ってしまいます。
以下のように修正されてはいかがでしょう。

  1. watcher1 と watcher2 をフォームのフィールドとして宣言する。
  2. watcher1 と watcher2 の初期化とイベントハンドラの登録処理は、フォームのコンストラクタ内で行うようにする。
  3. イベントハンドラ内でwatcher1とwatcher2を対象とした処理を行う。

こんな感じにすると整理できるのではないでしょうか。
ご参考になれば。

投稿2017/03/30 04:30

編集2017/03/30 04:31
tkanda

総合スコア2425

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cancat

2017/03/30 07:57

コメントありがとうございます。 変更は必須と考えています。 button1,2は1回しか押さないのでインスタンスは無限にはできません。 watcher1, 2をフィールドとして宣言することはできません。 watcherの数は2個ではない(いくつかわからない)ためです。 宣言するとしたら、List<FileSystemWatcher> watchers = new List<FileSystemWatcher>();となります。 なので、設計変更については同意できるものの、細部の方向性はちがっているようでした。 わたしの質問も悪いのかなと思います。ご容赦ください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問