日本好好热aⅴ|国产99视频精品免费观看|日本成人aV在线|久热香蕉国产在线

  • <cite id="ikgdy"><table id="ikgdy"></table></cite>
    1. 西西軟件園多重安全檢測(cè)下載網(wǎng)站、值得信賴的軟件下載站!
      軟件
      軟件
      文章
      搜索

      首頁(yè)編程開(kāi)發(fā)C#.NET → WinForm中如何使用多線程操作控件

      WinForm中如何使用多線程操作控件

      相關(guān)軟件相關(guān)文章發(fā)表評(píng)論 來(lái)源:本站整理時(shí)間:2010/11/15 14:55:04字體大。A-A+

      作者:佚名點(diǎn)擊:436次評(píng)論:0次標(biāo)簽: C#.net

      • 類型:源碼相關(guān)大。426KB語(yǔ)言:中文 評(píng)分:7.5
      • 標(biāo)簽:
      立即下載
      我們?cè)谧鰓inform應(yīng)用的時(shí)候,大部分情況下都會(huì)碰到使用多線程控制界面上控件信息的問(wèn)題。然而我們并不能用傳統(tǒng)方法來(lái)做這個(gè)問(wèn)題,下面我將詳細(xì)的介紹。

      首先來(lái)看傳統(tǒng)方法:

      publicpartialclass Form1 : Form
      ...{
      public Form1()
      ...{
      InitializeComponent();
      }
      privatevoid Form1_Load(object sender, EventArgs e)
      ...{
      Thread thread =new Thread(ThreadFuntion);
      thread.IsBackground =true;
      thread.Start();
      }
      privatevoid ThreadFuntion()
      ...{
      while (true)
      ...{
      this.textBox1.Text = DateTime.Now.ToString();
      Thread.Sleep(1000);
      }
      }
      }

      運(yùn)行這段代碼,我們會(huì)看到系統(tǒng)拋出一個(gè)異常:Cross-thread operation not valid:Control 'textBox1' accessed from a thread other than the thread it was created on . 這是因?yàn)?net 2.0以后加強(qiáng)了安全機(jī)制,不允許在winform中直接跨線程訪問(wèn)控件的屬性。那么怎么解決這個(gè)問(wèn)題呢,下面提供幾種方案。

      第一種方案,我們?cè)贔orm1_Load()方法中加一句代碼:


      privatevoid Form1_Load(object sender, EventArgs e)
      ...{
      Control.CheckForIllegalCrossThreadCalls =false;
      Thread thread =new Thread(ThreadFuntion);
      thread.IsBackground =true;
      thread.Start();
      }

      加入這句代碼以后發(fā)現(xiàn)程序可以正常運(yùn)行了。這句代碼就是說(shuō)在這個(gè)類中我們不檢查跨線程的調(diào)用是否合法(如果沒(méi)有加這句話運(yùn)行也沒(méi)有異常,那么說(shuō)明系統(tǒng)以及默認(rèn)的采用了不檢查的方式)。然而,這種方法不可取。我們查看CheckForIllegalCrossThreadCalls 這個(gè)屬性的定義,就會(huì)發(fā)現(xiàn)它是一個(gè)static的,也就是說(shuō)無(wú)論我們?cè)陧?xiàng)目的什么地方修改了這個(gè)值,他就會(huì)在全局起作用。而且像這種跨線程訪問(wèn)是否存在異常,我們通常都會(huì)去檢查。如果項(xiàng)目中其他人修改了這個(gè)屬性,那么我們的方案就失敗了,我們要采取另外的方案。

      下面來(lái)看第二種方案,就是使用delegate和invoke來(lái)從其他線程中控制控件信息。網(wǎng)上有很多人寫(xiě)了這種控制方式,然而我看了很多這種帖子,表明上看來(lái)是沒(méi)有什么問(wèn)題的,但是實(shí)際上并沒(méi)有解決這個(gè)問(wèn)題,首先來(lái)看網(wǎng)絡(luò)上的那種不完善的方式:

      publicpartialclass Form1 : Form
      ...{
      privatedelegatevoid FlushClient();//代理
      public Form1()
      ...{
      InitializeComponent();
      }
      privatevoid Form1_Load(object sender, EventArgs e)
      ...{
      Thread thread =new Thread(CrossThreadFlush);

      thread.IsBackground=true;
      thread.Start();
      }

      privatevoid CrossThreadFlush()
      ...{
      //將代理綁定到方法
      FlushClient fc =new FlushClient(ThreadFuntion);
      this.BeginInvoke(fc);//調(diào)用代理
      }
      privatevoid ThreadFuntion()
      ...{
      while (true)
      ...{
      this.textBox1.Text = DateTime.Now.ToString();
      Thread.Sleep(1000);
      }
      }
      }

        相關(guān)評(píng)論

        閱讀本文后您有什么感想? 已有人給出評(píng)價(jià)!

        • 8 喜歡喜歡
        • 3 頂
        • 1 難過(guò)難過(guò)
        • 5 囧
        • 3 圍觀圍觀
        • 2 無(wú)聊無(wú)聊

        熱門評(píng)論

        最新評(píng)論

        發(fā)表評(píng)論 查看所有評(píng)論(0)

        昵稱:
        表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
        字?jǐn)?shù): 0/500 (您的評(píng)論需要經(jīng)過(guò)審核才能顯示)