首页
学习
活动
专区
圈层
工具
发布

WPF 解决 ObservableCollection 提示 Cannot change ObservableCollection during a CollectionChanged event 异

本文告诉大家在使用 ObservableCollection 时,抛出 InvalidOperationException 异常,提示 Cannot change ObservableCollection...这个异常是 ObservableCollection 类型抛出的,而 ObservableCollection 类型是在 dotnet runtime 定义的,放在 System.ObjectModel...里,而且此异常可以在除 WPF 的其他框架,比如控制台或者 UWP 上复现 想要解决此问题,还请先了解一下此异常抛出的原因 在 ObservableCollection 的设计上,是可以了解列表的变更...这就让 ObservableCollection 存在一个设计上需要解决的问题,那就是如果事件 CollectionChanged 被加等两次,意味着有两次方法的调用。...要么就是继承 ObservableCollection 类型,重写 OnCollectionChanged 方法,不要修改 _blockReentrancyCount 字段。

1.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    WPF 多线程下跨线程处理 ObservableCollection 数据

    具体来说就是 ObservableCollection 是可以在任意线程创建和修改的,但是由于 ObservableCollection 是非线程安全的,因此推荐是单一的时刻,仅有单个线程进行处理。...如果 ObservableCollection 被 UI 元素捕获,例如加入到 ItemsSource 里面,那么此时的 ObservableCollection 不仅只能被单一线程处理,还要求这个线程是...UI 线程 根据以上描述,可以了解到,在 WPF 里面,如果有较多数据量,想要多线程处理 ObservableCollection 集合,可以采用在非 UI 的后台线程创建 ObservableCollection...上面代码先是后台线程创建和处理 ObservableCollection 对象,接下来后台线程执行完成,通过 await 自动依靠同步上下文调度到主线程,将后台线程创建的 ObservableCollection...列表的能力,必须从业务上确保只有后台线程在访问,而 UI 线程不会对 ObservableCollection 列表进行任何的改动 在确保 UI 线程不会改动到 ObservableCollection

    5.1K10

    UWP 和 WPF 不同,ListView 中绑定的集合修改顺序时,UI 的刷新规则

    UWP 和 WPF 不同,ListView 中绑定的集合修改顺序时,UI 的刷新规则 2017-10-20 00:14 ObservableCollection...由于 ObservableCollection 主要用于绑定,涉及到 UI 更新,而 UI 更新普遍比普通的集合修改慢了不止一个数量级,所以可以大胆猜想,Move 的存在是为了提升 UI 刷新性能...---- 试验 将 ObservableCollection 用于 UI 绑定的目前只有 UWP 和 WPF,于是我写了两个 App 来验证这个问题。...猜想 UWP 真的对 ObservableCollection 的 Move 操作有优化,根本就没有将移动数据的元素移除视觉树。...WPF 似乎并没有对 ObservableCollection 的 Move 操作进行优化,因为 Hash 值都变了,直接就是创建了个新的。

    3.2K10

    Power BI 异步刷新-查询刷新历史与手动停止刷新

    上文提到过,异步刷新进程可以手动进行停止: PowerBI API异步刷新教程 Power BI 异步刷新-手动取消刷新进程 有朋友在评论区提出,如果是手动刷新或者计划刷新,是否知道了requestid...然而,除了异步刷新, 其他的刷新方式都不提供requestid: 那么,我们是不是就没有办法测试了呢? 办法还是有的。...对应中文 Scheduled 计划刷新 OnDemand 按需刷新 ViaApi api刷新 ReliableProcessing 异步刷新 而且每一种refreshtype都有一个固定的requestid...这样,我们就可以在手动刷新后通过获取历史刷新数据来获取最后一次刷新的requestid,再用delete来终止这个request(按照上文的方式): 手动点击刷新按钮,ondemand刷新模式: 405...不过,除了以上的4中刷新方式,Power BI还提供了一种刷新方式: 那这种刷新是否也能被获取呢?

    5.2K20

    UI 刷新

    屏幕刷新机制 与屏幕刷新相关的有很多,比如刷新流程,屏幕缓存,周期刷新,vsync信号,SurfaceFlinger。...可以申请两个缓存,如果要显示下一个缓存,可以进行缓存交换 屏幕周期刷新 屏幕周期刷新,根据vsync信号,每次根据信号,收到信号从缓存区中获取图像绘制,vsync信号是脉冲信号。...,屏幕图像缓存,周期性刷新都讨论过了,还剩下vsync信号与SurfaceFlinger,剩下的在下面讨论,这时候针对之前的屏幕刷新机制,在来讨论几个问题 丢帧一般什么原因引起的 耗时操作,耽误view...屏幕并不会立即刷新,需要等到下次vsync信号来的时候才会进行刷新 如果界面没有重绘,还会每隔16ms刷新屏幕吗 如果界面没有进行重绘,并不会收到vsync信号进行重绘,但是屏幕还会每隔16ms进行重绘...分开分发避免同时抢占CPU资源 总结 学习完以上内容,我们对整个UI刷新流程,及刷新涉及的相关知识点,有了一定的了解,以上内容只是大致给出了结论,我们再通过阅读相关源码,将会对整个UI刷新有了更深的认识

    2.5K30

    5.5 PowerBI技巧-定时刷新与增量刷新

    给发布后的报告设置定时刷新,是PowerBI报告自动化的最后一步,这样整个报告发布过程就是全自动了。操作步骤STEP 1 在工作区中找到模型,点击安排刷新时间按钮。...STEP 4 设置刷新时间和频次。增量刷新是当PowerBI模型已经大几百M,刷新需要数小时,在PowerBI线上版中,为了提高刷新效率,保证报告刷新及时,同时也是节省资源,开始使用增量刷新。...这两个参数是本地模型加载的起止时间,报告发布后,这两个参数会按照增量刷新设置被自动覆盖。如果想让本地模型小一些,可以把这两个时间点间隔设置短一些。...STEP 3 点击关闭并应用后,在数据窗格下,在增量刷新的表上点击鼠标右键,选择增量刷新,设置数据的时间起点和增量刷新的时间起点,然后在4.审阅并应用中,可以直观地查看数据的已存档时间段及增量刷新时间段...设置增量刷新后,第一次发布后随带的自动刷新需要较长的时间,之后的刷新就比较快了。拓展使用增量刷新的模型,在PowerBI线上版将不支持下载,因此需要保存好本地文件。

    1.3K10

    WPF 已知问题 在 ObservableCollection 的 CollectionChanged 修改集合内容将让 UI 显示错误

    本文记录一个 WPF 已知问题,在 ObservableCollection 的 CollectionChanged 事件里面,绕过 ObservableCollection 的异常判断逻辑,强行修改集合内容...本文将告诉大家此问题的复现方法和修复方法 在 UI 绑定的 ObservableCollection 修改时,给此集合列表添加新的项目,此时 UI 绑定的数据是对的但是界面显示错误。...ToString() => Name; } 接着在 MainWindow 里添加一个 ObservableCollection 属性用于让 XAML 绑定,这里不加入一个 ViewModel...只是为了让代码简单 public ObservableCollection List { get; } = new ObservableCollection();...监听 Loaded 用来模拟删除 ObservableCollection 的内容,用来触发 CollectionChanged 事件 先不要实现 List_CollectionChanged 和 MainWindow_Loaded

    4.1K30

    Vue 实现前进刷新,后退不刷新的效果

    点击某个列表项,跳到详情页,再从详情页后退回到列表页时,不刷新。 也就是说从其他页面进到列表页,需要刷新获取数据,从详情页返回到列表页时不要刷新。...然后在列表页的 created 函数里添加 ajax请求,这样只有第一次进入到列表页的时候才会请求数据,当从列表页跳到详情页,再从详情页回来的时候,列表页就不会刷新。 这样就可以解决问题了。...需求二: 在需求一的基础上,再加一个要求:可以在详情页中删除对应的列表项,这时返回到列表页时需要刷新重新获取数据。 我们可以在路由配置文件上对 detail.vue 增加一个 meta 属性。...这时再返回到列表页,页面会重新刷新。 解决方案二 对于需求二其实还有一个更简洁的方案,那就是使用 router-view 的 key 属性。...例如从列表页进入了详情页,然后在详情页中删除了列表页中的某个选项,此时从详情页退回列表页时就要刷新,我们可以这样跳转: this.

    3.7K40
    领券