C# 使委托可供类使用
我想为全班派一名代表。这样做的目的是允许从外部类的backgroundWorker调用的方法不断地报告它的所有方法(ExternalClass.Run();调用ExternalClass.Method2();ExternalClass.Method3();等等,它们都需要发送多个进度报告似乎效率很低,
我已经尝试全局初始化委托实例并将其设置为等于 Run() 中传递的实例,然后才能使用它。但我收到一个错误,无法隐式转换空对象,
谢谢!
我无法显示我正在使用的代码,因为我目前没有它(它在我的笔记本电脑上),但我现在会尝试更好地解释。伪代码:
class form1 : form {
backgroundWorker_doWork()
{
Class2.Run();
}
backgroundWorker_OnProgressChange()
{
// do this
}
}
class class2{
Run(){
OtherMethod();ThirdMethod();
}
OtherMethod(){ //need to call backgroundWorker.ReportProcess(int, string)}
ThirdMethod(){ //need to call backgroundWorker.ReportProcess(int, string)}
}
我真的不想每次都通过它,这是重点,我想以某种方式将它传递给 class2
I would like to make a delegate available to an entire class. The point of this is to allow a called method from an external class' backgroundWorker to continually report back through all of it's methods (ExternalClass.Run(); calls ExternalClass.Method2(); ExternalClass.Method3(); etc and they all need to send several progress reports. It seems inefficient to have to continually pass the delegate.
I've tried initializing an instance of the delegate globally and setting it to equal the passed instance in Run(); for each method to then have available to it but I am given an error that a null object cannot be implicitly converted.
thanks!
I cannot show the code I am working with as I do not currently have it with me (it's on my laptop) but I will try to better explain now. PSEUDO-CODE:
class form1 : form {
backgroundWorker_doWork()
{
Class2.Run();
}
backgroundWorker_OnProgressChange()
{
// do this
}
}
class class2{
Run(){
OtherMethod();ThirdMethod();
}
OtherMethod(){ //need to call backgroundWorker.ReportProcess(int, string)}
ThirdMethod(){ //need to call backgroundWorker.ReportProcess(int, string)}
}
I really don't want to have to pass it every time is the point, i'd like to somehow pass it to class2
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您应该显示无法运行的代码以及确切的错误消息。应该没问题 - 这是一个例子:
You should show your code that isn't working and the exact error message. It should be fine - here's an example:
您可以使用 backgroundWorker 中的 InvokeMethod 函数来允许工作线程执行任何委托,如下所示(还等待调用完成,您可能不需要):
BackgroundWorker 函数 (C++.net)
You can use the InvokeMethod function from a backgroundWorker to allow the worker to execute any delegate, example below (also waits for the invoke to finish, which you may not need):
BackgroundWorker Function (C++.net)