zoukankan      html  css  js  c++  java
  • 浅谈多线程中数据的绑定和赋值

    我们知道,微软的.NET控件做了大量的工作,用起来还是不错的,一般的数据绑定或者赋值比较简单。如下所示

    文本赋值: txtTest.Text = "abc";

    控件禁用: txtTest.Enable = false;

    复杂的控件,如DataGridView的数据绑定,也是比较简单,只要数据源支持IListDataSource接口就可以了,如下所示

    dataGridView1.DataSource=list;//list为DataTable或者ArrayList或者List<T>等

    在一般的单线程程序中,我们的数据绑定和UI的线程是一起的,那么绑定很正常,很OK,但是在多线程里面,如果你需要绑定这些数据,那么就要费一点周章了,呵呵。

    如果你在不同于UI的另外一个线程里处理数据,当处理完毕,想绑定数据,那么应该如何呢,下面介绍几个方法给大家,一起分享一下,多线程控件中的数据绑定或者赋值等操作。

    先介绍一个文本属性的操作:

    this.Invoke(new MethodInvoker(delegate()
    {
        
    this.Text = message;
    }));
    this.Invoke(new MethodInvoker(delegate()
    {
        
    this.Enable= false;
    }));

    其他的控件也一样了,这样就可以搞定多线程的属性操作了,这种方法机会可以用于各种控件的操作,如DataGridView的数据绑定操作代码如下

     dataGridView1.Invoke(new MethodInvoker(delegate()
     {
           dataGridView1.DataSource 
    = list;
     }));

    这样,但我们在多线程中使用的时候,如下面的操作中,就可以用这种跨线程的数据绑定了

    private void btnUpdate_Click(object sender, EventArgs e)
    {
        WaitCallback async 
    = new WaitCallback(AddData);
        ThreadPool.QueueUserWorkItem(async, 
    "");
    }


    private void AddData(object state)
    {
         dataGridView1.Invoke(
    new MethodInvoker(delegate()
         {
               dataGridView1.DataSource 
    = list;
         }));
    }

     另外,我为了方便,封装了一般控件的跨线程访问的公共类,操作控件的代码可以变化为另外一种情况(和上面不同的方式)

    CallCtrlWithThreadSafety.SetText(this"您要显示的文本"this);

    //禁用按钮
    CallCtrlWithThreadSafety.SetEnable(this.btnUpdate, falsethis);

    辅助类的地址为:https://files.cnblogs.com/wuhuacong/CallCtrlWithThreadSafety.rar ,供下载交流使用。

    主要研究技术:代码生成工具、会员管理系统、客户关系管理软件、病人资料管理软件、Visio二次开发、酒店管理系统、仓库管理系统等共享软件开发
    专注于Winform开发框架/混合式开发框架Web开发框架Bootstrap开发框架微信门户开发框架的研究及应用
      转载请注明出处:
    撰写人:伍华聪  http://www.iqidi.com 
        
  • 相关阅读:
    芯片测试
    【转】悬浮的对话框
    imagebutton 设置点击和按压效果
    imagebutton 设置了src属性的图片更换
    侧滑实现
    使用自定义的AlertDialog。
    [转]Dialog
    【转】webview的几个问题
    webview 播放H5视频问题 黑屏 只有声音没有画面
    【转】Android HTML5 Video视频标签自动播放与自动全屏问题解决
  • 原文地址:https://www.cnblogs.com/wuhuacong/p/1512110.html
Copyright © 2011-2022 走看看