C#如何取出非公共成员

https://blog.csdn.net/yueguangzhiyuan/article/details/8926131

 

一般而言,非公共成员是受保护的,不能被外部访问的,这些都是基于安全性考虑。可是有时,我们很想取到非公共成员的某个对象。那我们就得用到两个方法:

GetType().GetField();

GetType().GetProperty();

GetField()用来获取字段,GetProperty()用来获取属性。
————————————————
版权声明:本文为CSDN博主「Hi-Jimmy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yueguangzhiyuan/article/details/8926131

 


示例:
如图,我要获取_row和Row的值。


        protected void GV_Event_RowCommand(object sender, GridViewCommandEventArgs e)
            {
                if (e.CommandName == "gvwEventLinkButton")
                {
                    //_row  前面蓝色小图标,是变量(字段),  他是私有成员  
                    //Row  前面白色小图标,是属性 ,他是保护乘员(白色图标上有个H的区域)  
                    //是字段还是属性,根据命名也能看出来  
     
                    //根据调试时查看,Row类型是GridViewRow  
                    GridViewRow row = null;
                    System.Reflection.FieldInfo fRow = e.GetType().GetField("_row", BindingFlags.Instance | BindingFlags.NonPublic);
                    row = fRow.GetValue(e) as GridViewRow;
                    int rowIndex = row.RowIndex;
                    GridViewRow row2 = null;
                    System.Reflection.PropertyInfo pRow = e.GetType().GetProperty("Row", BindingFlags.Instance | BindingFlags.NonPublic);
                    row2 = pRow.GetValue(e, null) as GridViewRow;
                    int rowIndex2 = row2.RowIndex;
     
                    //如果RowIndex仍然是非公成员,可以同理对row进行反射操作  
                }
            }

 
 
深入:
如图,两者都有相似的参数类型,可以只输入要搜索的Name参数,也可以额外加入负责搜索执行方式的参数BindingAttr。
      BindingAttr的参数大体如下(来自MSDN):
      指定 BindingFlags.Public 可在搜索中包含公共字段。
      指定 BindingFlags.NonPublic 可在搜索中包含非公共字段(即私有字段、内部字段和受保护的字段)。
      指定 BindingFlags.FlattenHierarchy 以便沿层次结构向上包括public 和protected 静态成员;不包括继承类中的private 静态成员。
      BindingFlags.IgnoreCase,表示忽略name 的大小写。

      BindingFlags.DeclaredOnly,表示仅搜索在Type 上声明的字段,而不搜索简单继承的字段。
————————————————
版权声明:本文为CSDN博主「Hi-Jimmy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yueguangzhiyuan/article/details/8926131

posted @ 2022-06-21 10:19  LuoCore  阅读(309)  评论(0编辑  收藏  举报