国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

使用Control.Invoke處理多線程應用程序界面

2024-07-21 02:16:04
字體:
來源:轉載
供稿:網友


使用control.invoke處理多線程應用程序界面


使用單一線程,在進行大計算量或耗時的操作時,會使界面失去響應。control.invoke 提供了一個在工作線程中更新見面的簡單辦法。該函數會把作為參數的回調函數提交給應用程序的界面進程(一般是主線程)的隊列中,等待處理。這樣,對界面的操作便無須擔心同步、互鎖等問題。

以下例子摘自一個局域網資源搜索程序

       可以看到,線程池中的工作線程通過調用treeview的invoke方法,并提供一個回調函數,來實現對treeview的更新。

       在frameworks 1.1 中,部分簡單的多線程更新界面并不需要這種操作,如修改一些靜態文本框中的文本等。但在frameworks 2.0,所有的操作都必須要以此方式完成。
private void searchnet()


{
     //清除所有根節點下的字節點

     treeview1.nodes[0].nodes.clear();

     for (uint i = ipstart; i <= ipend; i++)


     {


         //把整數轉化ip地址,添加任務到線程池

         threadpool.queueuserworkitem(new waitcallback(search),

              ("http:////" + (i >> 24).tostring() + '.' +


              (((int) i & 0x00ff0000) >> 16).tostring() + '.' +


              (((int) i & 0x0000ff00u) >> 8).tostring() + '.' + (i%256).tostring()));

     }

}

delegate void updater(treenode parent, treenode child);
public void updatetreeview(treenode parent, treenode child)
{

     parent.nodes.add(child);
     treeview1.nodes[0].expand();
     foreach (treenode n in treeview1.nodes[0].nodes)

     {
         n.expand();
     }


}
private void search(object host)

{

     wksta_info_100 stainfo;

     //嘗試連接
     if(connect(host,out stainfo))

     {

         treenode nodecomputer = new treenode(stainfo.wki100_computername);

         //搜索共享
         searchserver(nodecomputer,stainfo, (string)host);
     }
}

private void searchserver(treenode nodecomputer,wksta_info_100 stainfo, string host)
{    

     /*其它代碼*/

     treeview1.invoke(new updater(updatetreeview), new object[] {nodecomputer, node});

     /*其它代碼*/

}


private void searchnet()

{

     //清除所有根節點下的字節點
     treeview1.nodes[0].nodes.clear();
     for (uint i = ipstart; i <= ipend; i++)
     {
         //把整數轉化ip地址,添加任務到線程池
         threadpool.queueuserworkitem(new waitcallback(search),
              ("http:////" + (i >> 24).tostring() + '.' +
              (((int) i & 0x00ff0000) >> 16).tostring() + '.' +
              (((int) i & 0x0000ff00u) >> 8).tostring() + '.' + (i%256).tostring()));
     }
}

delegate void updater(treenode parent, treenode child);

public void updatetreeview(treenode parent, treenode child)

{

     parent.nodes.add(child);
     treeview1.nodes[0].expand();
     foreach (treenode n in treeview1.nodes[0].nodes)

     {
         n.expand();
     }
}

private void search(object host)
{
     wksta_info_100 stainfo;
     //嘗試連接

     if(connect(host,out stainfo))

     {
         treenode nodecomputer = new treenode(stainfo.wki100_computername);

         //搜索共享
         searchserver(nodecomputer,stainfo, (string)host);
     }

}

private void searchserver(treenode nodecomputer,wksta_info_100 stainfo, string host)


{    
     /*其它代碼*/
     treeview1.invoke(new updater(updatetreeview), new object[] {nodecomputer, node});

     /*其它代碼*/

}

private void searchnet()
{

     //清除所有根節點下的字節點

     treeview1.nodes[0].nodes.clear();

     for (uint i = ipstart; i <= ipend; i++)

     {
         //把整數轉化ip地址,添加任務到線程池
         threadpool.queueuserworkitem(new waitcallback(search),

              ("http:////" + (i >> 24).tostring() + '.' +
              (((int) i & 0x00ff0000) >> 16).tostring() + '.' +

              (((int) i & 0x0000ff00u) >> 8).tostring() + '.' + (i%256).tostring()));
     }
}

delegate void updater(treenode parent, treenode child);
public void updatetreeview(treenode parent, treenode child)
{
     parent.nodes.add(child);
     treeview1.nodes[0].expand();
     foreach (treenode n in treeview1.nodes[0].nodes)
     {
         n.expand();
     }

}

private void search(object host)
{
     wksta_info_100 stainfo;

     //嘗試連接
     if(connect(host,out stainfo))
     {
         treenode nodecomputer = new treenode(stainfo.wki100_computername);

         //搜索共享
         searchserver(nodecomputer,stainfo, (string)host);

     }
}

private void searchserver(treenode nodecomputer,wksta_info_100 stainfo, string host)

{    
     /*其它代碼*/

     treeview1.invoke(new updater(updatetreeview), new object[] {nodecomputer, node});

     /*其它代碼*/
}

       總結如下:

1、  定義委托

2、  定義回調函數

3、  調用control.invoke()



個人感覺語法較麻煩,尤其是對每種界面修改都必須定義一種委托(因為參數不同),有辦法改進么?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玉山县| 上蔡县| 鹤山市| 靖宇县| 开原市| 台安县| 锡林浩特市| 松阳县| 泽州县| 锡林浩特市| 蒙山县| 佳木斯市| 新和县| 饶平县| 临漳县| 卫辉市| 长武县| 遂宁市| 东阳市| 北票市| 攀枝花市| 安宁市| 屏边| 克什克腾旗| 鄂温| 都兰县| 扎兰屯市| 安阳市| 武安市| 阳西县| 沂水县| 黄大仙区| 荔浦县| 哈密市| 保定市| 琼海市| 蓬安县| 泾川县| 浠水县| 湛江市| 二连浩特市|