• Invoke和BeginInvoke 在Winform 中更新控件的用法说明


    WPF 程序出现:

    参数计数不匹配,未处理System.Reflection.TargetParameterCountException
    解决方法引用http://www.cnblogs.com/wene/p/4668830.html
    根据调试的实际情况显示,委托出现问题,此异常是在使用Invoke调用时,没有正确匹配参数数量,因为Invoke或BeginInvoke方法的参数数量是可变的,所以在编译阶段根本不会出现编译错误,但在程序正式执行时,又要求目标调用方法与Delegate的方法定义必须一致,如不一致,则会出现如上异常信息。
    最后检查的确是委托参数传入个数不对!!!
     
     
    WPF 委托用法:
    在DelegateState类声明
    public delegate void ChartCallBack(object cht, List data);
    public static ChartCallBack ChtInfo;
     
    在调用地方:
    1.初始化:DelegateState.ChtInfo = chtShow;
     
    2.编写函数实体:private void chtShow(object ch, List data)
            {
                Chart cht = ch as Chart;
     
                this.Dispatcher.Invoke(new DelegateState.ChartCallBack(delegate
                {
                    //函数实现在这
                    }
                }), new object[] { ch, data});
            }
    3.要用的地方调用:DelegateState.ChtInfo ((object)chart, (List)data);
    需要注意的地方:WFP 里面委托调用时,控件只能以object形式传进去,所以先强制转换为object,然后在委托函数实体部分再强制转换为所需要的控件。
     
    Winform 委托方法:
    声明一致,在调用方面有不同。
    在调用地方:
    1.初始化:DelegateState.ChtInfo = chtShow;
     
    2.编写函数实体:
            void chtShow(object chart ,List data)
            {
                
                    this.Invoke(new ThreadStart(delegate
                    {
                       //函数实现在这
                        }
                    }));
    或者下面一种写法也是可以的
    this.Invoke(new DelegateState.ChartCallBack(delegate
                {
                    //函数实现在这
                    }
                }), new object[] { ch, data});
            }
    3.要用的地方调用:DelegateState.ChtInfo ((object)chart, (List)data);
    在winform里面用的是 this.Invoke,而WPF是 this.Dispatcher.Invoke,调用传入参数可以直接是控件
  • 相关阅读:
    骑行318、 2016.7.22
    骑行318、 2016.7.21
    自定义的cell上面有图片时,如果产生了重用,图片可能会错乱问题
    当前View的坐标相对其他View的位置坐标
    自定义UIButton 实现图片和文字 之间距离和不同样式
    自定义导航栏 标题视图 返回按钮
    IOS 隐藏tabBar
    ShareSDK集成遇到问题
    导航栏相关设置
    根据字符内容计算宽高度
  • 原文地址:https://www.cnblogs.com/JianGuoWan/p/9148129.html
Copyright © 2020-2023  润新知