using System;
using System.Collections;
using System.Collections.Generic;
using System.Reflection;
using System.Text; public class RefPrint
{
public static PrintLog PrintTool; private static StringBuilder sb = new StringBuilder(); public static void PrintClassInfo<T>(T obj) where T : class
{
if (obj == null)
{
PrintTool.WriteLine("print class of null");
return;
}
sb = new StringBuilder();
sb = sb.AppendLine(obj.GetType().Name);
Type t = obj.GetType();
PrintFields(t, obj);
PrintTool.WriteLine(sb.ToString());
} public static void PrintClassInfo(object obj)
{
if (obj == null)
{
PrintTool.WriteLine("print class of null");
return;
} sb = new StringBuilder();
sb = sb.AppendLine(obj.GetType().Name);
Type t = obj.GetType();
PrintFields(t, obj);
PrintTool.WriteLine(sb.ToString());
} public static void PrintList(object listValue)
{
IEnumerable e = listValue as IEnumerable;
FieldInfo[] fList = null;
foreach (var c in e)
{
fList = c.GetType().GetFields(BindingFlags.Instance | BindingFlags.Public);
foreach (var item in fList)
{
sb = sb.AppendLine(item.FieldType.Name + "\t" + item.Name + "\t" + item.GetValue(c).ToString());
}
}
} public static void PrintAry(object aryValue)
{
IEnumerable e = aryValue as IEnumerable;
FieldInfo[] fList = null;
foreach (var c in e)
{
if (c.GetType().Name.Contains("String"))
{
sb = sb.AppendLine(c.GetType().Name + "\t" + c);
}
else if (!c.GetType().Name.Contains("String") && c.GetType().IsClass)
{
fList = c.GetType().GetFields(BindingFlags.Instance | BindingFlags.Public);
foreach (var item in fList)
{
sb = sb.AppendLine(item.FieldType.Name + "\t" + item.Name + "\t" + item.GetValue(c));
}
}
else
{
sb.AppendLine(c.GetType().Name + "\t" + c + "\t");
}
}
} public static void PrintMemebers(Type t, object value)
{
var mList = t.GetMembers(); foreach (var item in mList)
{
sb = sb.AppendLine("method: " + item.Name);
}
} public static void PrintFields(Type t, object value)
{
var fList = t.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic);
foreach (var item in fList)
{
if (!item.FieldType.IsClass || (item.FieldType.Name == "String"))
sb = sb.AppendLine(item.FieldType.Name + "\t" + item.Name + "\t" + item.GetValue(value)); if (item.FieldType.Name.Contains("List"))
{
sb = sb.AppendLine("集合" + item.Name + ":");
Object listValue = item.GetValue(value);
PrintList(listValue);
} if (item.FieldType.Name.Contains("[]"))
{
sb = sb.AppendLine("数组" + item.Name + ":");
Object aryValue = item.GetValue(value);
PrintAry(aryValue);
}
}
} public static void PrintProperties(Type t, object value)
{
var pList = t.GetProperties(); foreach (var item in pList)
{
sb = sb.AppendLine(item.Name + " " + item.GetValue(value, new object[] { }));
}
}
} public interface PrintLog
{
void WriteLine(string text);
}

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Reflection;
using System.Collections; namespace 反射查看类的信息
{
class Program
{
static void Main(string[] args)
{ PlateFace f = new PlateFace();
f.Add(new PlateFaceSon()); RefPrint.PrintTool = new MyPrint();
RefPrint.PrintClassInfo<PlateFace>(f);
Console.ReadLine();
}
} public class MyPrint : PrintLog
{ public void WriteLine(string text)
{
Console.WriteLine(text);
}
} public class PlateFace
{
private int a = 1;
private double b = 2;
private string c = "c";
private int[] d = { 1, 2, 3, 4 };
private string[] e = { "A", "b", "c", "1" }; private List<PlateFaceSon> f = new List<PlateFaceSon>();
private Dictionary<int, PlateFaceSon> j = new Dictionary<int, PlateFaceSon>(); public void Test() { }
public void Add(PlateFaceSon t)
{
f.Add(t);
}
} public class PlateFaceSon
{
public string Name = "盘子脸的儿子";
public int Age = 10; public override string ToString()
{
return "Name: " + Name + "Age: " + Age;
}
}
}

 

C# 利用反射查看类的信息的更多相关文章

  1. java利用反射访问类的私有(private)属性及方法

    Java语言中,在一个类中,为了不让外界访问到有的属性和方法,通常将其设置为private,用正常的方式(对象名.属性名,对象名.方法名)将无法访问此属性与方法,但有没有其他方法可以访问呢?答案是有的 ...

  2. Java利用反射取得类的所有信息

    Java中可以利用反射获取类的名称.构造函数.属性.方法.也就是说可以通过反射可以取得类的所有信息(不管该成员是否封装为private). 如有下面的Dept类定义: package org.lyk. ...

  3. java利用反射获取类的属性及类型

    java利用反射获取类的属性及类型. import java.lang.reflect.Field; import java.math.BigDecimal; import java.util.Map ...

  4. 利用CMD查看系统硬件信息

    利用CMD查看系统硬件信息对于在windows下查看系统信息大家一定不陌生了,我现在说几个最常用的方法,对命令感兴趣的朋友看看,(给菜鸟看的,老手就不要笑话我了,大家都是从那个时候过来的,^_^).一 ...

  5. JAVA基础知识之JVM-——通过反射查看类信息

    Class实例 当类被加载之后,JVM中就会生成一个Class实例,通过这个实例就可以访问JVM中的这个类.有三种方式可以获取Class对象 使用Class的静态方法forName(完整包名) 调用类 ...

  6. .Net 中的反射(查看基本类型信息) - Part.2

    反射概述 和Type类 1.反射的作用 简单来说,反射提供这样几个能力:1.查看和遍历类型(及其成员)的基本信息和程序集元数据(metadata):2.迟绑定(Late-Binding)方法和属性.3 ...

  7. .Net 中的反射(查看基本类型信息)

    反射概述 和Type类 1.反射的作用 简单来说,反射提供这样几个能力:1.查看和遍历类型(及其成员)的基本信息和程序集元数据(metadata):2.迟绑定(Late-Binding)方法和属性.3 ...

  8. .NET C#利用反射获取类文件以及其中的方法&属性 并获取类及方法上的特性

    了解C#特性类并声明我们自己的特性类[AttributeTest]代码如下 using System; namespace AttributeTest { /* 特性说明 特性本质是一个继承和使用了系 ...

  9. java利用反射调用类的某个方法

    java利用反射机制 可以动态调用某个类的某个方法,在 扩展系统功能或提供对外接口时经常用的到. 代码如下: 打印类Print.java package com.test.reflct; /** * ...

随机推荐

  1. DBMS_STATS常用方法(收集oracle信息)

    –收集数据库信息EXEC DBMS_STATS.gather_database_stats;EXEC DBMS_STATS.gather_database_stats(estimate_percent ...

  2. python Sina微博自动转发带抽奖字样的微博,添加关注,取消关注

    项目地址:https://github.com/chengshuyi/SinaWeibo 具有的功能 转发带抽奖字样的微博并可以@相应数量的好友 提取关注并添加关注 取消关注 获取粉丝列表

  3. 简单dp ---HDU3485 Count 101

    题目大意:让求长度为n的0 和 1 构成的串中不包含101子串的个数有多少. 这个题当时想了好久,以为是一个规律题,一直在推规律,最后还是wa了,上网一看原来是dp问题, 不过确实递推式挺巧妙的. 递 ...

  4. 类名.this与类名.class

    1..当在内部类中使用this指的就是内部类的对象, 为了访问外层类对象,就可以使用外层类名.this来访问. 2.在java中,每个class都有一个相应的Class对象,当编写好一个类,编译完成后 ...

  5. WARNING OGG-01223 TCP/IP error 111 (Connection refused)

    一:问题描述 GGSCI (source_pc) 64> info all Program     Status      Group       Lag at Chkpt  Time Sinc ...

  6. 几种破解MySQL root密码的几种方法:

    几种破解MySQL root密码的几种方法: 方法一 使用phpmyadmin,这是最简单的了,修改mysql库的user表,不过别忘了使用PASSWord函数. 方法二 使用mysqladmin,这 ...

  7. JQuery 表单验证--jquery validation

    jquery validation,表单验证控件 官方地址 :http://jqueryvalidation.org/ jquery表单验证 默认值校验规则 jquery表单验证 默认的提示 < ...

  8. sql查询每门课程成绩最高的学生

    给出数据库(sco)如下图: 查出每门课程成绩最高的学生 select b.id,b.kemu,b.name,b.chengji from (select kemu,max(chengji) maxc ...

  9. oracle数据泵之解决方案(用户)导入导出。

    看到网上有这样的介绍而且很多,但觉得都是大神才能一下子看的懂.自己总结下菜鸟能看懂的. 1.导出. 首先第一步: 操作系统—开始—运行输入“cmd”进入dos界面输入“sqlplus/nolog”按回 ...

  10. js只能输入数字

    $("#SeatCount, #Charge").on("keyup", function () { if (this.value.replace(/^0|\D ...