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# 利用反射查看类的信息的更多相关文章
-
java利用反射访问类的私有(private)属性及方法
Java语言中,在一个类中,为了不让外界访问到有的属性和方法,通常将其设置为private,用正常的方式(对象名.属性名,对象名.方法名)将无法访问此属性与方法,但有没有其他方法可以访问呢?答案是有的 ...
-
Java利用反射取得类的所有信息
Java中可以利用反射获取类的名称.构造函数.属性.方法.也就是说可以通过反射可以取得类的所有信息(不管该成员是否封装为private). 如有下面的Dept类定义: package org.lyk. ...
-
java利用反射获取类的属性及类型
java利用反射获取类的属性及类型. import java.lang.reflect.Field; import java.math.BigDecimal; import java.util.Map ...
-
利用CMD查看系统硬件信息
利用CMD查看系统硬件信息对于在windows下查看系统信息大家一定不陌生了,我现在说几个最常用的方法,对命令感兴趣的朋友看看,(给菜鸟看的,老手就不要笑话我了,大家都是从那个时候过来的,^_^).一 ...
-
JAVA基础知识之JVM-——通过反射查看类信息
Class实例 当类被加载之后,JVM中就会生成一个Class实例,通过这个实例就可以访问JVM中的这个类.有三种方式可以获取Class对象 使用Class的静态方法forName(完整包名) 调用类 ...
-
.Net 中的反射(查看基本类型信息) - Part.2
反射概述 和Type类 1.反射的作用 简单来说,反射提供这样几个能力:1.查看和遍历类型(及其成员)的基本信息和程序集元数据(metadata):2.迟绑定(Late-Binding)方法和属性.3 ...
-
.Net 中的反射(查看基本类型信息)
反射概述 和Type类 1.反射的作用 简单来说,反射提供这样几个能力:1.查看和遍历类型(及其成员)的基本信息和程序集元数据(metadata):2.迟绑定(Late-Binding)方法和属性.3 ...
-
.NET C#利用反射获取类文件以及其中的方法&;属性 并获取类及方法上的特性
了解C#特性类并声明我们自己的特性类[AttributeTest]代码如下 using System; namespace AttributeTest { /* 特性说明 特性本质是一个继承和使用了系 ...
-
java利用反射调用类的某个方法
java利用反射机制 可以动态调用某个类的某个方法,在 扩展系统功能或提供对外接口时经常用的到. 代码如下: 打印类Print.java package com.test.reflct; /** * ...
随机推荐
-
iOS10 - 访问系统通讯录新方法
所需框架 #import <ContactsUI/ContactsUI.h> 遵循代理 CNContactPickerDelegate 调用通讯录 如果在iOS10的机器上调用以前的ABP ...
-
JSBinding + SharpKit / 需要注意及不支持的列表
1) 序列化不支持 public List<T>,其余都支持(JSBinding+Bridge无此功能) 2015年11月5日 补充:序列化只处理 Field.目前发现 Animation ...
-
K2制作流程
K2流程制作注意事项 1:分析需求 2:实施 步骤1:绘制流程图 步骤2:添加datafield[必备:ActJumped IsPass] 步骤3:添加线规则(如下图所示,在添加完毕规则之后,再给同 ...
-
搭建SpringBoot+dubbo+zookeeper+maven框架(四)
今天我们完成框架的thymeleaf模板显示页面功能,页面的用户登陆,密码的AES加密解密,输错3次进行验证码验证功能,东西可能比较多,这个是我这两天在网上结合各种资源整合出来的,基本功能都已经实现, ...
-
PAT甲级1052 Linked List Sorting
题目:https://pintia.cn/problem-sets/994805342720868352/problems/994805425780670464 题意: 给定一些内存中的节点的地址,值 ...
-
ElasticSearch 2 (12) - Shard数调优(ElasticSearch性能)
ElasticSearch 2 (12) - Shard数调优(ElasticSearch性能) 摘要 当创建一个索引的时候,我们经常会面对一个问题:要为索引分配多少个shard?多少个replica ...
- ijcai statistics
-
在 :after/ :before 使用 font awesome web Icon
.element { position: relative; } /*replace the content value with the corresponding value from the l ...
-
C#中Form的Paint事件响应方法与重载虚方法OnPaint()的区别
Form_Paint()方法是Paint事件的响应方法,OnPaint是可重载的虚方法,OnPaint方法是调用Paint事件的,用哪一个,效果是一样,就看那一个方便了内部是这样实现的: protec ...
-
Spring技术内幕:Spring AOP的实现原理(三)
生成SingleTon代理对象在getSingleTonInstance方法中完毕,这种方法时ProxyFactoryBean生成AopProxy对象的入口.代理对象会封装对target目标对象的调用 ...