• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            cc

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks

            BeginInvoke 方法真的是新開一個線程進行異步調(diào)用嗎?
            參考以下代碼:

            public delegate void treeinvoke();

            private void UpdateTreeView()

            {

            ??? MessageBox.Show(System.Threading.Thread.CurrentThread.Name);

            }

            private void button1_Click(object sender, System.EventArgs e)

            {

            ??? System.Threading.Thread.CurrentThread.Name = "UIThread";

            ??? treeView1.BeginInvoke(new treeinvoke(UpdateTreeView));

            }

            看看運行結(jié)果,彈出的對話框中顯示的是 UIThread ,這說明 BeginInvoke 所調(diào)用的委托根本就是在 UI 線程中執(zhí)行的。

            既然是在 UI 線程中執(zhí)行,又何來 異步執(zhí)行 一說呢?

            我們再看看下面的代碼:

            public delegate void treeinvoke();

            private void UpdateTreeView()

            {

            ??? MessageBox.Show(Thread.CurrentThread.Name);

            }

            private void button1_Click(object sender, System.EventArgs e)

            {

            ??? Thread.CurrentThread.Name = "UIThread";

            ??? Thread th = new Thread(new ThreadStart(StartThread));

            ??? th.Start();

            }

            private void StartThread()

            {

            ??? Thread.CurrentThread.Name = "Work Thread";

            ??? treeView1.BeginInvoke(new treeinvoke(UpdateTreeView));

            }

            再看看運行結(jié)果,彈出的對話框中顯示的還是 UIThread ,這說明什么?這說明 BeginInvoke 方法所調(diào)用的委托無論如何都是在 UI 線程中執(zhí)行的。

            BeginInvoke 究竟有什么用呢?

            在多線程編程中,我們經(jīng)常要在工作線程中去更新界面顯示,而在多線程中直接調(diào)用界面控件的方法是錯誤的做法,具體的原因可以在看完我的這篇之后看看這篇: 在多線程中如何調(diào)用 Winform ,如果你是大牛的話就不要看我這篇了,直接看那篇吧,反正那篇文章我沒怎么看懂。

            Invoke BeginInvoke 就是為了解決這個問題而出現(xiàn)的,使你在多線程中安全的更新界面顯示。

            正確的做法是將工作線程中涉及更新界面的代碼封裝為一個方法,通過 Invoke 或者 BeginInvoke 去調(diào)用,兩者的區(qū)別就是一個導(dǎo)致工作線程等待,而另外一個則不會。

            而所謂的 一面響應(yīng)操作,一面添加節(jié)點 永遠(yuǎn)只能是相對的,使 UI 線程的負(fù)擔(dān)不至于太大而以,因為界面的正確更新始終要通過 UI 線程去做,我們要做的事情是在工作線程中包攬大部分的運算,而將對純粹的界面更新放到 UI 線程中去做,這樣也就達(dá)到了減輕 UI 線程負(fù)擔(dān)的目的了。

            而在那段更新樹節(jié)點的代碼中,其實唯一起作用的代碼是: System.Threading.Thread.Sleep(100); ,它使 UI 線程有了處理界面消息的機會,其實 數(shù)碼幽靈 將問題復(fù)雜化了,只要以下的代碼就可以很好的工作了。

            private void button1_Click_(object sender, System.EventArgs e)

            {

            ??? TreeNode tn;

            ??? for(int i=0;i<100000;i++)

            ??? {

            ??????? tn=new TreeNode (i.ToString());

            ??????? this.treeView1.Nodes[0].Nodes.Add(tn);

            ??????? if (i%100 == 0) Application.DoEvents();

            ??? }

            }

            posted on 2006-12-07 14:52 醒目西西 閱讀(233) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            中文无码久久精品| 国内精品久久久久国产盗摄| 久久WWW免费人成一看片| 亚洲中文字幕无码久久综合网| 国产亚洲欧美精品久久久| 久久国产热这里只有精品| 亚洲伊人久久精品影院| 91精品观看91久久久久久| 波多野结衣AV无码久久一区| 国产精品久久久久久福利漫画 | 久久婷婷五月综合成人D啪| 久久综合国产乱子伦精品免费| 99久久精品国产一区二区蜜芽| 久久久久久精品免费看SSS| 99久久综合狠狠综合久久| 亚洲国产精品无码久久久蜜芽| 久久精品国产99久久丝袜| 99国产欧美精品久久久蜜芽| 久久久亚洲裙底偷窥综合| 久久免费大片| 久久本道久久综合伊人| 99久久精品国产高清一区二区| 国产色综合久久无码有码| 久久九九久精品国产| 亚洲国产精品久久久久网站| 国产成人精品免费久久久久| 伊人久久精品无码av一区| 久久午夜无码鲁丝片秋霞| 中文字幕无码av激情不卡久久| 精品久久国产一区二区三区香蕉| 成人妇女免费播放久久久| 亚洲国产精品无码久久| 精品熟女少妇AV免费久久| 狠狠色婷婷久久一区二区| 狠狠色丁香久久婷婷综合| 中文字幕日本人妻久久久免费| 久久精品国产男包| 久久久久久九九99精品| 久久精品国产亚洲AV无码娇色| 日产精品久久久久久久| 国产精品岛国久久久久|