c# 之 System.Type.GetType()与Object.GetType()与typeof比较
2024-10-10 11:15:16
Object.GetType()与typeof的区别
//运算符,获得某一类型的 System.Type 对象。
Type t = typeof(int); //方法,获取当前实例的类型。
int i = ;
Console.WriteLine(i.GetType());
//区别
Typeof()是运算符而GetType是方法
GetType()是基类System.Object的方法,因此只有建立一个实例之后才能被调用(也就是创建实例)
Typeof()的参数只能是lint,string,类,且不能是实例
得到结果的区别
(1)Typeof():得到一个class的Type
(2)GetType():得到一个class实例的Type
System.Type.GetType()的使用
Type type = System.Type.GetType("ConsoleApplication1.child");
Type type1 = System.Type.GetType("System.Int32");
Object.GetType()的小案例
public class Student
{
public Student()
{ }
public virtual string Id { get; set; }
public virtual string StudentNo { get; set; }
public virtual string Address { get; set; }
} public class StudentDTO
{
public StudentDTO()
{ }
public virtual string Id { get; set; }
public virtual string StudentNo { get; set; }
public virtual int TeacherId { get; set; }
}
//对student对象赋值
Student student = new Student();
student.Id = Guid.NewGuid().ToString();
student.Name = "张三";
student.Address = "福建";
//将student的值赋予studentdto
StudentDTO studentDTO = new StudentDTO();
studentDTO.Id = student.Id;
studentDTO.Name = student.Name; 改进:若是student的属性过多,那么可以通过此方法减少许多代码
foreach (var item in student.GetType().GetProperties()) //返回Student的所有公共属性
{
var value = item.GetValue(student, null); //返回属性值
var setobj = studentDTO.GetType().GetProperty(item.Name); //搜索具有指定属性名称的公共属性
if (value != null && setobj != null)
{
setobj.SetValue(studentDTO, value, null);
}
}
最新文章
- Dynamics CRM 2011-RootComponent Type
- 前端工具HBuilder安装Sass插件
- PHP内核(一)内存管理
- MySQL应用的异常记录
- bzoj3594: [Scoi2014]方伯伯的玉米田--树状数组优化DP
- ios之AFN上传下载详细步骤(2)
- 说说Java中的代理模式
- 使用layer显示弹出框笔记
- [每日一题] 11gOCP 1z0-052 :2013-09-4 block header grows............................................A33
- 在高德地图应用api,和api展出的标记小的应用程序
- ZOJ 3913 Bob wants to pour water
- Angular页面选项卡切换要注意的toggleClass
- zetcode :: First programs in PyQt5
- THEPYTHONCHALLENG闯关记录
- jackson json转对象 对象转json
- MAC ACL、RACL和VACL
- HBuilder离线打包启用Chrome Inspect调试
- 01 Hello World!
- 1L - ASCII码排序
- sqlserver 添加服务器链接 跨服务器访问数据库