多线程下异常:某个ItemsControl与它的项源不一致

这两天写一个WPF的客户端,为DataGrid绑定一个ObservableCollection的数据源,但是就这么简单一个玩意,写完后执行却发生bug,bug页面如下:

通过Google,找到问题和解决方案。问题就是多线程的环境下,对数据源集合的更新操作会和UI线程的显示产生冲突。如何解决?看下面

void UpdateItems()
{
    //retrievedItems is the data you received from the service
    foreach(object item in retrievedItems)
        Dispatcher.BeginInvoke(DispatcherPriority.Background, new ParameterizedThreadStart(AddItem), item);
}

void AddItem(object item)
{
    observableCollection.Add(item);
}

就用这个异步更新,好了,bug搞定了。

源链接在此:http://stackoverflow.com/questions/2505492/wpf-update-binding-in-a-background-thread

最后感叹一句,中文的资源真是少啊,Google问题还是要用英文,上面这个问题用下面这句进行搜索

An ItemsControl is inconsistent with its items source,就能在stackoverflow上搜到一堆解决方案。

时间: 2024-10-09 14:57:55

多线程下异常:某个ItemsControl与它的项源不一致的相关文章

wpf异常:某个ItemsControl与它的项源不一致

把一个 dic绑定到了listview上,有时候下拉列表会报这个异常.因为直接使用了itemssource = dic,而dic在另一个线程上不定期更新,这样如果直接绑定的话就会报这个错误,原因是直接绑定的话会把itemssource的内存地址直接指向dic的内存地址,当dic更新后,会导致内存地址变动,使程序无法正常读取内存中的数据而报错.最简单的解决方法是new一个dictionary ,把dic传过去,然后再赋值给itemssource,这样new出来的dic就会有另一块专用的内存空间,无

一个多线程下的单实例实现故障

最近在asp.net项目中碰到的一个问题. 一个编码器模块使用单实例实现,结果碰到了编码ID重复的异常. public class IdGenerator { private static IdGenerator single; public static IdGenerator Single { get { if (null == single) { single = new IdGenerator(); } return single; } } protected IdGenerator()

多线程下的资源同步访问

在一个应用程序中使用多线程 好处是每一个线程异步地执行. 对于Winform程序,可以在后台执行耗时操作的同时,保持前台UI正常地响应用户操作. 对于Service.对于客户端的每一个请求,可以使用一个单独的线程来进行处理.而不是等到前一个用户的请求被完全处理完毕后,才能接着处理下一个用户的请求. 同时,异步带来的问题是,必须协调对资源(文件,网络,磁盘)的访问. 否则,会造成在同一时间两个以上的线程访问同一资源,并且这些线程间相互未知,导致不可预测的数据问题. Lock/Monitor:防止线

多线程下的进程同步(线程同步问题总结篇)

之前写过两篇关于线程同步问题的文章(一,二),这篇中将对相关话题进行总结,本文中也对.NET 4.0中新增的一些同步机制进行了介绍. 首先需要说明的是为什么需要线程功能同步.MSDN中有这样一段话很好的解释了这个问题: 当多个线程可以调用单个对象的属性和方法时,对这些调用进行同步处理是非常重要的.否则,一个线程可能会中断另一个线程正在执行的任务,使该对象处于一种无效状态. 也就说在默认无同步的情况下,任何线程都可以随时访问任何方法或字段,但一次只能有一个线程访问这些对象.另外,MSDN中也给出定

多线程下的集合安全

在多线程内使用集合,如果未对集合做任何安全处理,就非常容易出现系统崩溃或各种错误.最近的项目里,使用的是socket通信后再改变了某个集合,结果导致系统直接崩溃,且无任何错误系统弹出. 经排查,发现问题是执行某集合后,系统就会在一定时间内退出,最后发现是使用的一个字典集合出了问题.稍微思考后,就认定了是线程安全问题.因为此集合在其它几个地方都有线程做循环读取. 下面是我模拟的一个示例,没有进行任何的安全处理: 1 class Program 2 { 3 static MyCollection m

从头认识java-18.2 基本的线程机制(8)多线程的异常捕捉

这一章节我们来讨论一下多线程的异常捕捉. 1.普通情况的异常 package com.ray.ch17; public class Test { public static void main(String[] args) { try { new ThreadA().run(); } catch (Exception e) { System.out.println("捕捉到异常"); } } } class ThreadA implements Runnable { @Override

Java多线程——<七>多线程的异常捕捉

一.概述 为什么要单独讲多线程的异常捕捉呢?先看个例子: public class ThreadException implements Runnable{ @Override public void run() { throw new RuntimeException(); } //现象:控制台打印出异常信息,并运行一段时间后才停止 public static void main(String[] args){ //就算把线程的执行语句放到try-catch块中也无济于事 try{ Execu

由“Qt程序运行一段时间后崩溃”引发的“opancv库中Mat::clone()函数”在多线程下的注意事项

问题描述 过程1:从相机中获取图像数据,然后存放到一个cv::Mat对象中(该对象是全局变量,用来交换数据).由相机的回调函数自动调用. 过程2:将上述的全局变量拷贝并转换qimg,放到Qt界面上显示.该过程由定时器调用. 然后程序会在运行一段时间后,出现"程序异常结束.The process was ended forcefully.".运行的时间长短不一. 问题解决与分析 由于QtCreator的编译器选的是MSVC,而调试器选只有GDB(查了下好像需要CDB).所以无法debug

Java多线程21:多线程下的其他组件之CyclicBarrier、Callable、Future和FutureTask

CyclicBarrier 接着讲多线程下的其他组件,第一个要讲的就是CyclicBarrier.CyclicBarrier从字面理解是指循环屏障,它可以协同多个线程,让多个线程在这个屏障前等待,直到所有线程都达到了这个屏障时,再一起继续执行后面的动作.看一下CyclicBarrier的使用实例: public static class CyclicBarrierThread extends Thread { private CyclicBarrier cb; private int sleep