zoukankan      html  css  js  c++  java
  • winform下提高control在UI中的响应速度

    其实有很多种办法,先列出第一种性能最差,也是我们经常写的代码:
    private int count = 10000;
            
    private void button1_Click(object sender, System.EventArgs e)
            
    {
                
    long l1 = System.DateTime.Now.Ticks;
                listBox1.Items.Clear();
                
    for(int i=0;i<count;i++)listBox1.Items.Add(i);
                
    long l2 = System.DateTime.Now.Ticks;
                MessageBox.Show((l2
    -l1).ToString());
            }
    这是我以前在cbuilder中经常使用的方式:
    long l1 = System.DateTime.Now.Ticks;
                listBox1.Enabled 
    = false;
                listBox1.Visible 
    = false;
                listBox1.Items.Clear();
                
    for(int i=0;i<count;i++)listBox1.Items.Add(i);        
                listBox1.Enabled 
    = true;
                listBox1.Visible 
    = true;
                
    long l2 = System.DateTime.Now.Ticks;
                MessageBox.Show((l2
    -l1).ToString());        

    这种方式,值得注意的是,如果你没有设置Visible=false,效率和第一种差不多。
    这是.net下推荐的方式:
    long l1 = System.DateTime.Now.Ticks;
                listBox1.BeginUpdate();
                listBox1.Items.Clear();
                
    for(int i=0;i<count;i++)listBox1.Items.Add(i);        
                listBox1.EndUpdate();
                
    long l2 = System.DateTime.Now.Ticks;
                MessageBox.Show((l2
    -l1).ToString());

    对于如上面简单的control,大家可以测试一下,第一和最后一种,差2、3倍的时间是没有问题的。而如果我们使用诸如datagrid这种control,再如果我们的每个cell中作了不少事件的handle,那么,效率是非常低的。常见的现象,你看见datagrid上的cell光标,四处乱跑。
    而BeginUpdate/EndUpdate,在这个范围段内,不响应任何事件(此处我也存疑,呵呵)。如果没有event的handle,那么慢的唯一原因是UI需要不停的刷新。所以第二种的方式下,让它disable/invisible,也是可以解决这个问题的。

    本来不想写的,看见灵感老大的第17(还是18了?)感悟,呵呵,我就不嫌这玩意土了。
    希望对大家有所帮助。
  • 相关阅读:
    不参加IT培训,如何通过自学的方式成功转行?(蜗牛学院)
    惠普电脑win10关闭自动调节亮度
    原生Ajax发送get、post请求每一步
    HTML5的web 存储localStorage、sessionStorage
    node + multer存储element-ui上传的图片
    html块级元素的水平垂、直居中的方式
    vuex之Mutation(三)
    mint ui的tabBar监听路由变化实现tabBar切换
    Vue使用better-scroll左右菜单联动
    vuex之getter(二)
  • 原文地址:https://www.cnblogs.com/juqiang/p/41871.html
Copyright © 2011-2022 走看看