当构建一个图形化的Windows Form桌面应用程序并且需要执行在应用程序主UI线程之外的线程中长时间的任务时,BackgroundWorker类就很有用了。
要使用BackgroundWorker,我们只需要告诉它希望在后台执行那个方法并且调用RunWorkerAsync()即可
public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { int a = int.Parse(textBox1.Text.Trim()); int b = int.Parse(textBox2.Text.Trim()); Add ad = new Add(a,b); backgroundWorker1.RunWorkerAsync(ad); } private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e) { Add args=(Add)e.Argument; for (int i = 0; i < 11; i++) { Thread.Sleep(200); backgroundWorker1.ReportProgress(i*10); } e.Result = args.a + args.b; } private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e) { label1.Text = e.Result.ToString(); } private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e) { progressBar1.Value = e.ProgressPercentage; } } public class Add { public int a; public int b; public Add(int a, int b) { this.a = a; this.b = b; } }
以上就是c# BackgroundWorker组件的作用的详细内容,更多关于c# BackgroundWorker组件的资料请关注小牛知识库其它相关文章!
我对C#中的backgroundworker有一个问题。我正在编码一个dll文件。 这是我在VS2019中的类库(.NET Framework)类型项目中的代码: 当我使用即时窗口调用方法时,后台工作者的方法中的命令不会运行。逐行对问题进行解块显示方法正在运行,但它没有以某种方式调用RunworkerAsync。 *Update1:启动线程也不起作用:
本文向大家介绍C# BackgroundWorker使用教程,包括了C# BackgroundWorker使用教程的使用技巧和注意事项,需要的朋友参考一下 查询了一下MSDN文档,其中微软就BackgroundWorker类的功能有这么一个描述(英文的,根据个人理解翻译):BackgroundWorker类允许您在单独的线程上执行某个可能导致用户界面(UI)停止响应的耗时操作(比如文件下载数据库事
模板模式 模式定义 定义一个操作中的算法的骨架 (稳定),而将一些步骤延迟(变化)到子类中。 Template Method使得子类可以不改变(复用)一个算法的结构即可重定义(override 重写)该算法的某些特定步骤。 //程序库开发人员 class Library { public: void Run() { Step1(); if (Step2()) { //支持变化 ==> 虚
我有一个包含HTML组件,如下所示: 此组件的CSS(或部分CSS)为: 其基本思想是,当通过页面上的某个click事件应用时,中的div会发生一些动画。因此该组件中的divs类似于: 使用CSS: 我的问题是,上面的页面(带有)是发生事件的地方,因此它也是应用类的地方。但是,实际的组件,它只是包含一堆div(应该是动画的),嗯,它们根本没有动画。 我可以看到类是在单击按钮时应用的,但我猜当类应用
C++中的模块称为函数(function)和类(class)。C++程序一般是将程序员编写的新函数与C++标准库(standard library)中提供的预装函数组合而成的,通常是将程序员编写的新类与各种类库中提供的预装类组合而成的。本章主要介绍函数,第6章开始将详细介绍类。 C++标准库提供了丰富的函数集合,可以进行常用数学计算、字符串操作、字符操作、输人/输出、错误检查和许多其他有用的操作。
英文原文:http://emberjs.com/guides/components/sending-actions-from-components-to-your-application/ 当组件被用于一个模板中时,其能够发送操作(action)给模板的控制器和路由。这样可以允许组件在一些重要的事件发生时通知应用。比如一个用户点击了组件中的一个特定的元素,可以触发此操作。 就像{{action}}
问题内容: 说我有一个功能组件: 直接将其作为函数调用有什么区别: 与将其称为组件相比: 我对性能影响最感兴趣,React如何在内部对它们进行区别对待,也许对React Fiber中的情况可能有所不同,我听说功能组件的性能得到了提升。 问题答案: 调用它作为函数要快得多,事实上,几个月前就已经有讨论了。在这一点上,功能性反应组件不能是PureComponents,因此没有真正适用于它们的额外优化。
我目前正在开发一个JComboBox组件,我希望在其中的组合框中有一个JTable用于下拉选择。我扩展了ListCellRenderer,并且在弹出窗口中有一个表。 我想用两种不同的方式来呈现。第一个作为所选行的绑定列的标签,当弹出窗口不可见时。第二种是在弹出窗口可见时用JScrollPane显示表。 不幸的是,当我这样做时,弹出窗口被缩小到列表的行高,这只为表的列留下了空间。 如果我只是使用滚动