博客
关于我
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留疑问:left join时选on还是where?
查看>>
mysql登陆慢问题解决
查看>>
Mysql百万级数据查询优化
查看>>
MySQL的 DDL和DML和DQL的基本语法
查看>>
mysql的 if else , case when then, IFNULL
查看>>
MySQL的10种常用数据类型
查看>>
MySQL的btree索引和hash索引的区别
查看>>
mysql的cast函数
查看>>
MySql的CRUD(增、删、改、查)操作
查看>>
MySQL的DATE_FORMAT()函数将Date转为字符串
查看>>
mysql的decimal与Java的BigDecimal用法
查看>>
MySql的Delete、Truncate、Drop分析
查看>>
MySQL的Geometry数据处理之WKB方案
查看>>
MySQL的Geometry数据处理之WKT方案
查看>>
mysql的grant用法
查看>>
Mysql的InnoDB引擎的表锁与行锁
查看>>
mysql的InnoDB引擎索引为什么使用B+Tree
查看>>
MySQL的InnoDB默认隔离级别为 Repeatable read(可重复读)为啥能解决幻读问题?
查看>>
MySQL的insert-on-duplicate语句详解
查看>>
mysql的logrotate脚本
查看>>