当前位置: 首页 > wzjs >正文

网站开发前端技术5g影讯5g天线在线观看免费视频

网站开发前端技术,5g影讯5g天线在线观看免费视频,wordpress简化评论,网站icp备案地C#winform主线程刷新UI时竟抛异常"从不是创建控件的线程访问它" 1 软件抛出示意图2 使用场景说明2.1 日志刷新模块2.2 查看线程号2.2.1 添加变量法2.2.2 构造函数加载资源方式 3 总结 1 软件抛出示意图 2 使用场景说明 在Form2中添加了richTextBox1,用来…

C#winform主线程刷新UI时竟抛异常"从不是创建控件的线程访问它"

  • 1 软件抛出示意图
  • 2 使用场景说明
    • 2.1 日志刷新模块
    • 2.2 查看线程号
      • 2.2.1 添加变量法
      • 2.2.2 构造函数加载资源方式
  • 3 总结

1 软件抛出示意图

在这里插入图片描述

2 使用场景说明

  1. 在Form2中添加了richTextBox1,用来临时刷新日志信息;
  2. 软件启动主窗体(Form1),并实例化了Form2;
  3. 有一条线程调用了Form2的实例化对象,刷新了richTextBox1信息
  4. 后续在(主线程)使用Form1打开(Show)Form2时,软件提示“System.InvalidOperationException:“线程间操作无效: 从不是创建控件“richTextBox1”的线程访问它。”
  5. 获取了调用时DisplayLog和Form2.Show()的线程号,发现刷新UI时,竟然不在主线程刷新,并且没有报错。

2.1 日志刷新模块

  • 此时我是比较疑惑的,为什么主线程打开Form2时,还会报出这个异常?刷新控件信息时使用了主线程去刷新(如下图),怎么还会出现这个问题?
  • 这不是拿着自己家的钥匙开自己家的门,邻居报警了“这个人是个贼,竟然想偷他自己家的东西!”
    在这里插入图片描述

2.2 查看线程号

public void DisplayLog(string log)
{if (this.InvokeRequired){this.Invoke(new EventHandler(delegate { DisplayLog(log); }));return;}try{LogUtil.Instance.Debug($"Form2.DisplayLog线程号:{Thread.CurrentThread.ManagedThreadId}");richTextBox1.AppendText(log + Environment.NewLine);richTextBox1.ScrollToCaret();}catch (Exception ex){LogUtil.Instance.Error("", ex);}
}Time:2025-04-17 13:40:46,612 
Thread ID:[1] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:初始化Form2线程号:1 Time:2025-04-17 13:40:47,493 
Thread ID:[4] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:Form2.DisplayLog线程号:4 Time:2025-04-17 13:40:47,968 
Thread ID:[1] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:承载Form2线程号:1 
  • 果然线程号是有问题的,虽然我进行了两种处理方式。

2.2.1 添加变量法

随后,我定义了一个bool字段,在窗体的Load事件中将该值设置为true,在刷新日志的方法中判断是否该值的状态,若窗体未调用Load,接受到日志信息则不进行刷新。当Load加载了之后,再去刷新在这里插入图片描述

  • 测试结果,未抛异常
  • 但是按照上面的方法去做,虽然解决了抛出异常的问题,但是,显而易见的是如果未打开Form2,那日志信息就不会记录,当打开Form2时,只能看到Load之后的日志信息,这样肯定是不能接受的。
  • 所以另想他法。

2.2.2 构造函数加载资源方式

  • 在构造函数中调用一次DisplayLog
public Form1()
{InitializeComponent();DisplayLog("模块启动成功");
}public void DisplayLog(string log)
{if (this.InvokeRequired){this.Invoke(new EventHandler(delegate { DisplayLog(log); }));return;}try{richTextBox1.AppendText(log + Environment.NewLine);richTextBox1.ScrollToCaret();}catch (Exception ex){LogUtil.Instance.Error("", ex);}
}

这时测试的时候发现也没有报错,但是缺点是多了一条日志信息,这样我们是能接受。并且UI是在主线程刷新的。


Time:2025-04-17 13:42:43,633 
Thread ID:[1] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:初始化Form2线程号:1 Time:2025-04-17 13:42:44,203 
Thread ID:[1] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:Form2.DisplayLog线程号:1 Time:2025-04-17 13:42:45,674 
Thread ID:[1] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:承载Form2线程号:1 Time:2025-04-17 13:42:46,372 
Thread ID:[1] 
Log Level:  DEBUG 
Class:Log4net.Logger.LogUtil property: [(null)] - 
Description:Form2.DisplayLog线程号:1 

3 总结

无论是处理方式1还是处理方式2,仅解决了抛出异常的问题,但是并未搞清楚第一次界面使用的是子线程,为何软件竟然能够通过,并且主线程刷新UI竟然会异常。

> 希望有懂的大神,可以帮忙解惑下。

http://www.dtcms.com/wzjs/379744.html

相关文章:

  • 开州区城乡建设委员会官方网站特色产品推广方案
  • 做个手机网站多少钱搜索排名优化
  • 关于实施公司网站建设的请示广告公司名称
  • 如何做微信ppt模板下载网站网络软营销
  • 汉字logo标志设计名词解释搜索引擎优化
  • 阿里云备案网站负责人百度图片搜索引擎入口
  • 网站建设项目执行进度表百度网站排名优化
  • 网站建设云解析dns有什么用cps广告联盟平台
  • 武汉做网站公司排名seo网上课程
  • 苏州公司注册代办seo公司关键词
  • 百度百科让做网站的超链接吗北京seo公司华网白帽
  • 网站规划与网站建设数据分析师培训机构
  • 珠海市公司网站建设百度搜索风云榜小说排行榜
  • 毕业设计可以做网站不淘宝指数入口
  • 网络营销的特征包括seo学校培训班
  • 东莞公司网站策划站外推广免费网站
  • 12380网站的建设情况广州网站快速排名优化
  • 男女生做内个的网站八百客crm系统登录入口
  • net做公司网站是否适合百度指数怎么刷指数方法
  • 免费做微网站企业文化标语
  • 哪个网站做的win10比较干净重庆百度推广排名
  • 教做宝宝辅食的网站最新重大新闻
  • 周浦网站建设公司最新的全国疫情数据
  • 潮汕17网站一起做网店官网seo查询工具有哪些
  • 数据中心托管济南seo小黑seo
  • 本溪建网站seo建站技巧
  • 无锡公司网站建设服务百度推广关键词质量度
  • 做婚庆网站的功能定位青岛网络科技公司排名
  • 公司自有网站工信备案杭州优化公司哪家好
  • 做什么网站比较受欢迎app平台搭建