• <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>

            天下

            記錄修行的印記

            C# invoke,BeginInvoke,EndInvoke

             

            C# invoke,BeginInvoke,EndInvoke
            在多線程編程中,我們經常要在工作線程中去更新界面顯示,而在多線程中直接調用界面控件的方法是錯誤的做法,Invoke 和 BeginInvoke 就是為了解決這個問題而出現的,使你在多線程中安全的更新界面顯示。
            正確的做法是將工作線程中涉及更新界面的代碼封裝為一個方法,通過 Invoke 或者 BeginInvoke 去調用,兩者的區別就是一個導致工作線程等待,而另外一個則不會。
            再舉個簡單例子說明下使用方法,比如你在啟動一個線程,在線程的方法中想更新窗體中的一個TextBox.. 

            using System.Threading;
            //啟動一個線程 
            Thread thread=new Thread(new ThreadStart(DoWork)); 
            thread.Start(); 
            //線程方法 
            private void DoWork() 

                
            this.TextBox1.Text="我是一個文本框"

            如果你像上面操作,在VS2005或2008里是會有異常的 


            正確的做法是用Invoke\BeginInvoke
            using System.Threading;
            namespace test
            {
                
            public partial class Form1 : Form
                {
                    
            public delegate void MyInvoke(string str1,string str2);
                    
            public Form1()
                    {
                        InitializeComponent();
                    }
                    
            public void DoWork()
                    {
                        MyInvoke mi 
            = new MyInvoke(UpdateForm);
                        
            this.BeginInvoke(mi, new Object[] {"我是文本框","haha"});
                    }
                    
            public void UpdateForm(string param1,string parm2)
                    {
                        
            this.textBox1.Text = param1+parm2;
                    }
                    
            private void button1_Click(object sender, EventArgs e)
                    {
                        Thread thread 
            = new Thread(new ThreadStart(DoWork));
                        thread.Start();
                    }
                }
            }


            相關資料:Invoke 和 BeginInvoke 的真正涵義 、在多線程中如何調用Winform
            Control.BeginInvoke 方法  Visual Studio 2010Visual Studio 
            2010 
            在創建控件的基礎句柄所在線程上異步執行委托。
            公共方法 BeginInvoke(Delegate) 在創建控件的基礎句柄所在線程上異步執行指定委托。 
            公共方法 BeginInvoke(Delegate,Object[])  在創建控件的基礎句柄所在線程上,用指定的參數異步執行指定委托。 
            public Object EndInvoke(IAsyncResult asyncResult)
            參數:asyncResult 類型:System.IAsyncResult 
            IAsyncResult,表示特定的調用異步操作,在調用 BeginInvoke 時返回。 

             

            posted on 2016-09-08 10:16 天下 閱讀(1039) 評論(0)  編輯 收藏 引用 所屬分類: C#

            <2010年12月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            久久久国产亚洲精品| 91精品观看91久久久久久| 亚洲v国产v天堂a无码久久| 久久久久女教师免费一区| 久久久久亚洲精品无码网址| 久久se精品一区精品二区国产 | 亚洲国产精品无码久久久不卡| 青青草原精品99久久精品66| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久亚洲av无码精品浪潮| 无遮挡粉嫩小泬久久久久久久| 99精品久久久久久久婷婷| 国内高清久久久久久| 久久久久久青草大香综合精品| 久久精品aⅴ无码中文字字幕不卡| 精品国产青草久久久久福利| 久久久久国产精品熟女影院 | 国产69精品久久久久9999| 一本一道久久综合狠狠老| 国产精品久久久久乳精品爆| 久久精品夜夜夜夜夜久久| 午夜精品久久影院蜜桃| 精品久久久久久无码中文野结衣| 97热久久免费频精品99| 亚洲中文字幕久久精品无码喷水 | 一本久久知道综合久久| 要久久爱在线免费观看| 久久久受www免费人成| 91精品国产91久久久久久蜜臀| 久久精品天天中文字幕人妻| 亚洲精品乱码久久久久久中文字幕| 久久久中文字幕日本| 亚洲国产精品无码久久青草 | 狠狠色丁香久久婷婷综合| 欧美麻豆久久久久久中文| 久久亚洲电影| 久久久高清免费视频| 久久久精品国产免大香伊| 亚洲国产精品无码久久SM | 久久青青草原国产精品免费| 国产精品一区二区久久精品|