博客
关于我
Wpf 多线程修改UI示例:
阅读量:661 次
发布时间:2019-03-15

本文共 564 字,大约阅读时间需要 1 分钟。

1.Wpf 多线程修改UI示例:

//启动线程修改UI,抛出异常ThreadPool.QueueUserWorkItem((q) =>{    button.Content = "张三";}, null);

解决方案:使用Dispatcher.BeginInvoke+委托方式,修改UI

将修改UI的代码封装在委托中

//启动线程处理Thread thread1 = new Thread(UpdateBtn);thread1.IsBackground = true;//设置为后台线程,当主线程结束后,后台线程自动退出,否则不会退出程序不能结束thread1.Start();

复制代码

//线程方法,修改Button内容private void UpdateBtn(){    int i = 0;    while (true)    {        i++;        Action action1 = () =>        {            button.Content = i;        };        button.Dispatcher.BeginInvoke(action1);        // 如果不设置等待,整个程序死循环        Thread.Sleep(500);    }}

复制代码

转载地址:http://qxxmz.baihongyu.com/

你可能感兴趣的文章
mysql并发死锁案例
查看>>
MySQL幻读:大家好,我是幻读,我今天又被解决了
查看>>
MySQL底层概述—1.InnoDB内存结构
查看>>
MySQL底层概述—2.InnoDB磁盘结构
查看>>
MySQL底层概述—3.InnoDB线程模型
查看>>
MySQL底层概述—4.InnoDB数据文件
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
mysql建立索引的几大原则
查看>>
Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
mysql开启bin-log日志,用于canal同步
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>