回答:
次のように開始します。
int value = 123;
bgw1.RunWorkerAsync(argument: value); // the int will be boxed
その後
private void worker_DoWork(object sender, DoWorkEventArgs e)
{
int value = (int) e.Argument; // the 'argument' parameter resurfaces here
...
// and to transport a result back to the main thread
double result = 0.1 * value;
e.Result = result;
}
// the Completed handler should follow this pattern
// for Error and (optionally) Cancellation handling
private void worker_Completed(object sender, RunWorkerCompletedEventArgs e)
{
// check error, check cancel, then use result
if (e.Error != null)
{
// handle the error
}
else if (e.Cancelled)
{
// handle cancellation
}
else
{
double result = (double) e.Result;
// use it on the UI thread
}
// general cleanup code, runs when there was an error or not.
}
Tuple<A,B>
(C#4 +)を使用します(編集:はい、オブジェクトを使用してすべてをパックします。たとえば、DoWorkEventArgsセルフを参照してください)。
label1.Text = e.Result.ToString();
どこでも安全だとマークしました。
これは既に回答済みの質問ですが、IMOの方が読みやすいという別のオプションを残しておきます。
BackgroundWorker worker = new BackgroundWorker();
worker.DoWork += (obj, e) => WorkerDoWork(value, text);
worker.RunWorkerAsync();
そして、ハンドラメソッドで:
private void WorkerDoWork(int value, string text) {
...
}
... => WorkerDoWork(a, b, c);
、メソッドのシグネチャと一致している限り、私が間違っていない場合は、必要なパラメーターを追加できます ... WorkerDoWork(int a, string b, string c) {...
このように複数の引数を渡すことができます。
List<object> arguments = new List<object>();
arguments.Add(argument 1);
arguments.Add(argument 1);
arguments.Add(argument n);
backgroundWorker2.RunWorkerAsync(arguments);
private void worker_DoWork(object sender, DoWorkEventArgs e) {
List<object> genericlist = e.Argument as List<object>;
extract your multiple arguments from this list and cast them and use them.
}
Tuple
むしろ汎用オブジェクトのリストよりも(または特殊クラス)
DoWorkEventArgs.Argument
プロパティを使用できます。
完全な例(int引数を使用している場合でも)は、Microsoftのサイトにあります。
DoWorkEventArgs.Argumentプロパティを確認してください。
...
backgroundWorker1.RunWorkerAsync(yourInt);
...
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
// Do not access the form's BackgroundWorker reference directly.
// Instead, use the reference provided by the sender parameter.
BackgroundWorker bw = sender as BackgroundWorker;
// Extract the argument.
int arg = (int)e.Argument;
// Start the time-consuming operation.
e.Result = TimeConsumingOperation(bw, arg);
// If the operation was canceled by the user,
// set the DoWorkEventArgs.Cancel property to true.
if (bw.CancellationPending)
{
e.Cancel = true;
}
}
複数のタイプの引数を渡したい場合は、これを試して、最初にすべてをObject型の配列に追加し、そのオブジェクトをRunWorkerAsync()に渡すことができます。次に例を示します。
some_Method(){
List<string> excludeList = new List<string>(); // list of strings
string newPath ="some path"; // normal string
Object[] args = {newPath,excludeList };
backgroundAnalyzer.RunWorkerAsync(args);
}
バックグラウンドワーカーのdoWorkメソッドで
backgroundAnalyzer_DoWork(object sender, DoWorkEventArgs e)
{
backgroundAnalyzer.ReportProgress(50);
Object[] arg = e.Argument as Object[];
string path= (string)arg[0];
List<string> lst = (List<string>) arg[1];
.......
// do something......
//.....
}
RunWorkerAsync(object)メソッドとDoWorkEventArgs.Argumentプロパティが必要です。
worker.RunWorkerAsync(5);
private void worker_DoWork(object sender, DoWorkEventArgs e) {
int argument = (int)e.Argument; //5
}
オブジェクトタイプのリストではなく、(複合デザインパターンを使用して)具体的なタイプの複合オブジェクトを常に使用するようにしてください。これらのオブジェクトのそれぞれが一体何であるかを誰が覚えているでしょうか?後でコードのメンテナンスについて考えてください...代わりに、次のようなことを試してください:
Public (Class or Structure) MyPerson
public string FirstName { get; set; }
public string LastName { get; set; }
public string Address { get; set; }
public int ZipCode { get; set; }
End Class
その後:
Dim person as new MyPerson With { .FirstName = “Joe”,
.LastName = "Smith”,
...
}
backgroundWorker1.RunWorkerAsync(person)
その後:
private void backgroundWorker1_DoWork (object sender, DoWorkEventArgs e)
{
MyPerson person = e.Argument as MyPerson
string firstname = person.FirstName;
string lastname = person.LastName;
int zipcode = person.ZipCode;
}