zoukankan      html  css  js  c++  java
  • winform批量更新数据_长时间的执行会导致界面卡死

      前言:使用winform触发一个事件后执行的代码,如果耗时非常长,则会导致窗口界面假死!  本人最近通过winform窗体执行一项:需要批量更新一批数据库的数据的操作的任务时,由于数据量达到百万级别,非常耗时,只能慢慢更新,慢慢执行。   

    但是,在执行的过程遇到了一个奇葩的问题:窗体在调试状态下,代码可以慢慢循环执行,没出现异常。  但是我单独运行EXE程序时,就必现:程序假死,未响应状态。  

    后台百度虽然没有找到直接的答案,但是也发现了原因:是因为在操作非常耗时时,程序会出现假死,解决方法也很简单:在你的耗时方法里,加上异步处理,不要让程序一直等待你的执行结果。

    如下代码:

    通过,异步Task.Run方法,让方法快速结束,不用登台中间即为耗时的操作更新过程,通过这样改造后,界面再也不卡死了,完美解决。

    /// <summary>
            /// 临时方法-用于刷用户地址手机号数据
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void btnUpdateUserAddressPhone_Click(object sender, EventArgs e)
            {
                this.txtActionInfomation.Text = $"方法开始";
                this.txtActionInfomation.Update();
                Task.Run(() => {
                    //耗时代码
                    do
                    {
                        //我的更新代码,需要分页获取并更新数据库,耗时长
                        //...
                        //...
                        this.txtActionInfomation.Text = $"已更新X条数据";
                        this.txtActionInfomation.Update();
    
                    } while (true);
                });
                this.txtActionInfomation.Text = $"方法结束";
                this.txtActionInfomation.Update();
    
            }
  • 相关阅读:
    a标签 不触发 目标链接
    java Byte[] to String(hex)
    error C2664: 'BOOL (PCERT_SELECT_STRUCT_A)' : cannot convert parameter 1 from 'CERT_SELECT_STRUCT *' to 'PCERT_SELECT_STRUCT_A'
    java jni c++ 例子
    Java.io.DataInputStream.readInt()
    sso demo mysql ( cas )
    sso demo 取消https (cas)
    poj 1422 Air Raid (二分匹配)
    poj 1274 The Perfect Stall (二分匹配)
    hdu 1392 Surround the Trees (凸包)
  • 原文地址:https://www.cnblogs.com/lxhbky/p/11097679.html
Copyright © 2011-2022 走看看