• C#中线程间操作无效: 从不是创建控件 txtBOX 的线程访问它。


    delegate void 委托名(方法名);

    void 方法名()

    if(txtBox.invokeRequered)

    {

    委托名 d=new 委托名();

    txtBox.invoke(d);

    }

    else

    {

    具体的执行语句

    }

    原来是存在跨线程调用控件的问题

    解决方法有两种:第一是加一句话,第二是用委托。因为一句话成功了 我就没有用委托了~  

    1.解决方法就加了一句话

    private void mycomm_DataReceived(object sender, System.IO.Ports.SerialDataReceivedEventArgs e)

            {

                ////////////////////线程开始的时候加这么一句

                Control.CheckForIllegalCrossThreadCalls = false;

            

                string str = mycomm.ReadExisting().ToString();

                txtreceive.Text = txtreceive.Text + str;

            }

    ok 程序就运行成功了~


    第二:
    用委托,在05里,每个控件都有个InvokeRequired的属性~
    判断一下是不是true,是的话进行Invoke操作的,完事了~

     

    //建立个委托
            private delegate void ShowDelegate(string strshow);


            public void Show(string strshow)

            {


                if (this.txtreceive.InvokeRequired)

                {

                 //   this.txtreceive.BeginInvoke(new ShowDelegate(Show), strshow);//这个也可以

                    this.txtreceive.Invoke(new ShowDelegate(Show), strshow);

                }

                else

                {

                        this.txtreceive.Text += strshow;


                }

            }

    第一种方法只是简单的将错误提示禁用了,仍然存在跨线程调用控件的问题。为此可能造成两个线程同时或者循环改变该控件的状态导致线程死锁。 

    Invoke方法是同步的方法,所以执行过程是有先后顺序的,所以就不会出现那个异常了 最好是用第二种方法


  • 相关阅读:
    《C#从现象到本质》读书笔记(八)第10章反射
    《C#从现象到本质》读书笔记(七)第9章 泛型
    《C#从现象到本质》读书笔记(六)第8章委托和事件
    《C#从现象到本质》读书笔记(五)第5章字符串第6章垃圾回收第7章异常与异常处理
    求1+2+……+n的和
    回溯法的应用举例
    回溯法
    翻转单词顺序列
    左旋转字符串
    和为S的两个数字
  • 原文地址:https://www.cnblogs.com/haxianhe/p/9271271.html
Copyright © 2020-2023  润新知