反射获取指定类型

package dao;

import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import javax.annotation.Resource;

import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
/**
 * BaseDaoImpl不能在类型未确定前直接实例化
 * @author zh
 * @param <T>
 */
public class BaseDaoImpl<T extends Serializable> extends HibernateDaoSupport implements IbaseDao<T> {
	
	@Resource(name="sessionFactory")
	public void setSupperSessionFactory(SessionFactory sessionFactory){
			super.setSessionFactory(sessionFactory);
	}
	

	@SuppressWarnings("rawtypes")
	private Class Tclass;
	@SuppressWarnings("rawtypes")
	public BaseDaoImpl(){
		 Type type = this.getClass().getGenericSuperclass();  
	        if (type.toString().indexOf("BaseDao") != -1) {  
	            ParameterizedType type1 = (ParameterizedType) type;  
	            Type[] types = type1.getActualTypeArguments();  
	            setTclass((Class) types[0]);  
	        }else{  
	            type = ((Class)type).getGenericSuperclass();  
	            ParameterizedType type1 = (ParameterizedType) type;  
	            Type[] types = type1.getActualTypeArguments();  
	            setTclass((Class) types[0]);  
	        } 
	 }
	
	/**
	 * 保存对象
	 * 
	 * @param Object
	 */

	public void save(T t) {
		//this.getHibernateTemplate().save(t)
		getSession().save(t);
		
	}

	/**
	 * 更新对象内容
	 * 
	 * @param Object
	 */
	public void update(T t) {
		//this.getHibernateTemplate().update(t);
		getSession().update(t);
	}
	
	/**
	 * 删除对象
	 * @param t
	 */
	public void delete(T t){
		//this.getHibernateTemplate().delete(t);
		getSession().delete(t);
	}
	
	public void deleteById(String hql, Object[] params){
		Query query = this.getSession().createQuery(hql);
		for (int i = 0; i < params.length; i++) {
			query.setParameter(i, params[i]);
		}
		query.executeUpdate();
	}
	
	/**
	 * ͨ通过ID 得到对象
	 * @param Serializable
	 */
	@SuppressWarnings("unchecked")
	public T get(Serializable id) {
		//return (T) this.getHibernateTemplate().get(getTclass(), id);
		return (T)getSession().get(getTclass(), id);
	}
	
	

	/**
	 * 取得所有对象
	 * 
	 */
	@SuppressWarnings("unchecked")
	public List<T> listAll() {
		String hql = "from "+getTclass().getSimpleName();
		return this.getSession().createQuery(hql).list();
	}

	

	/**
	 * hql解决方案
	 * 
	 * @param String hql
	 *          
	 * @param Object[] params
	 *           参数列表  顺序不能颠倒
	 */

	@SuppressWarnings("unchecked")
	public List<T> listByHql(String hql, Object[] params) {
		Query query = this.getSession().createQuery(hql);
		if(null == params || params.length == 0){
			return query.list();
		}else{
			for (int i = 0; i < params.length; i++) {
				query.setParameter(i, params[i]);
			}
		}
		return query.list();
	}

	/**
	 * 同类分页
	 * 
	 * @param int firstResult
	 *           从第几条开始
	 * @param int maxResults
	 *           要取几条
	 */
	@SuppressWarnings({ "unchecked" })
	public List<T> listFenYe(int firstResult, int maxResults) {
		String hql = "from "+getTclass().getSimpleName();
		Query query = this.getSession().createQuery(hql).setMaxResults(maxResults).setFirstResult(firstResult);
		return query.list();
	}
	
	/**
	 * 取得行数
	 */

	public long getCount() {
		String hql = "select count(*) from "+getTclass().getSimpleName();
		return (Long) this.getSession().createQuery(hql).uniqueResult();
	}
	/**
	 * 懒加载load
	 */
	@SuppressWarnings("unchecked")
	public T load(Serializable id) {
		//return (T) this.getHibernateTemplate().load(this.getClass(), id);
		return (T) getSession().load(this.getClass(), id);
	}

	@SuppressWarnings("rawtypes")
	public Class getTclass() {
		return Tclass;
	}
	@SuppressWarnings("rawtypes")
	public void setTclass(Class tclass) {
		Tclass = tclass;
	}

	@SuppressWarnings("unchecked")
	public T getByHql(String hql, Object[] params) {
		Query query = this.getSession().createQuery(hql);
		for (int i = 0; i < params.length; i++) {
			query.setParameter(i, params[i]);
		}
		return (T) query.uniqueResult();
	}
	
	@SuppressWarnings("unchecked")
	public List<T> getByHqlNotIn(String hql, Object[] params) {
		System.out.println("Tclass:"+Tclass);
		Query query = this.getSession().createSQLQuery(hql).addEntity(Tclass);
		List<T> list = null ;
		for (int i = 0; i < params.length; i++) {
			query.setParameter(i, params[i]);
		}
		list = query.list();
		return list;
	}

	@SuppressWarnings("unchecked")
	public List<T> listFenYeAddparams(int firstResult, int maxResults,
			String hql, Object[] params) {
		Query query = this.getSession().createQuery(hql);
		List<T> list = null ;
		if(null == params || params.length == 0){
			list = query.setMaxResults(maxResults).setFirstResult(firstResult).list();
		}
		if(null != params || params.length != 0){
			for (int i = 0; i < params.length; i++) {
				System.out.println("params:"+params[i]);
				query.setParameter(i, params[i]);
			}
			list = query.setMaxResults(maxResults).setFirstResult(firstResult).list();
		}
		return list;
	}

	@SuppressWarnings("unchecked")
	public List<T> listFenYeNotIn(int firstResult, int maxResults,
			String hql, Object[] params) {
		Query query = this.getSession().createSQLQuery(hql).addEntity(Tclass);
		List<T> list = null ;
		if(null == params || params.length == 0){
			list = query.setMaxResults(maxResults).setFirstResult(firstResult).list();
		}
		if(null != params || params.length != 0){
			for (int i = 0; i < params.length; i++) {
				System.out.println("params:"+params[i]);
				query.setParameter(i, params[i]);
			}
			list = query.setMaxResults(maxResults).setFirstResult(firstResult).list();
		}
		return list;
	}
	
	@SuppressWarnings("unchecked")
	public List<T> listNotIn(String hql, Object[] params) {
		Query query = this.getSession().createSQLQuery(hql).addEntity(Tclass);
		List<T> list = null ;
		if(null != params || params.length != 0){
			for (int i = 0; i < params.length; i++) {
				System.out.println("params:"+params[i]);
				query.setParameter(i, params[i]);
			}
		}
		list = query.list();
		return list;
	}
	
	
	
	public long getCount(String hql, Object[] params) {
		Query query = this.getSession().createQuery(hql);
		if(null != params || params.length != 0){
			for (int i = 0; i < params.length; i++) {
				query.setParameter(i, params[i]);
			}
		}
		return (Long) query.uniqueResult();
	}
	@SuppressWarnings("unchecked")
	public List<T> queryPage(Map map,int firstResult, int maxResults,
			String hql) {
		StringBuffer buffer = new StringBuffer(hql);
		StringBuffer wherestring = new StringBuffer();
		Iterator paramnames  = map.keySet().iterator();
		while(paramnames .hasNext())
		{
			String paramname = (String) paramnames.next();
			String value = null;
			value = String.valueOf(map.get(paramname));
			if(value!=null)
			{
				value = value.trim();
				if(value.equals(""))
				{
					continue;
				}
			}
			if(wherestring.length()==0)
			{
				wherestring.append(" where ");
			}else{
				wherestring.append(" and ");
			}
			wherestring.append(paramname).append("=").append(value);
			buffer.append(wherestring);
		}
		Query query = this.getSession().createQuery(buffer.toString());
		System.out.println(buffer.toString());
		List<T> list = query.setMaxResults(maxResults).setFirstResult(firstResult).list();
		return list;
	}
	public long getCount(String hql, Map map) {
		StringBuffer buffer = new StringBuffer(hql);
		StringBuffer wherestring = new StringBuffer();
		Iterator paramnames  = map.keySet().iterator();
		while(paramnames .hasNext())
		{
			String paramname = (String) paramnames.next();
			String value = null;
			//value = (String) map.get(paramname);
			value = String.valueOf(map.get(paramname));
			if(value!=null)
			{
				value = value.trim();
				if(value.equals(""))
				{
					continue;
				}
			}
			if(wherestring.length()==0)
			{
				wherestring.append(" where ");
			}else{
				wherestring.append(" and ");
			}
			wherestring.append(paramname).append("=").append(value);
			buffer.append(wherestring);
		}
		System.out.println(buffer.toString());
		Query query = this.getSession().createQuery(buffer.toString());
		return (Long) query.uniqueResult();
	}

	public int update(String hql, Object[] params) {
		Query query = this.getSession().createQuery(hql);
		if(params == null){
			return query.executeUpdate();
		}
		for (int i = 0; i < params.length; i++) {
			query.setParameter(i, params[i]);
		}
		return query.executeUpdate();
	}

	public void save(String hql, Object[] params) {
		Query query = this.getSession().createQuery(hql);
		for (int i = 0; i < params.length; i++) {
			query.setParameter(i, params[i]);
		}
		query.executeUpdate();
	}

}

  

<think>嗯,用户想知道如何使用C#反射获取成员类型,并且需要方法或示例代码。首先,我得回忆一下C#反射相关的知识。反射主要涉及System.Reflection命名空间下的类,比如Type、PropertyInfo、FieldInfo、MethodInfo等。用户的问题集中在获取成员类型,所以需要分别考虑属性、字段、方法这些不同的成员类型。 首先,获取类型的信息是关键。用户可能需要先获取到某个类的Type对象,然后通过这个Type对象来获取成员。例如,使用typeof(类名)或者实例对象的GetType()方法。接着,针对不同的成员类型,使用不同的方法来获取。比如,属性用GetProperties,字段用GetFields,方法用GetMethods。不过要注意的是,默认情况下这些方法可能只能获取到公共成员,如果需要非公共的或者静态的,可能需要指定BindingFlags参数。 然后,具体到每个成员,比如属性,PropertyInfo对象有一个PropertyType属性,可以获取属性的类型。字段的话,FieldInfo有FieldType。方法的返回类型则是在MethodInfo的ReturnType属性里,而参数类型可以通过GetParameters()方法获取每个参数的ParameterType。这些应该都是基本的操作,但用户可能需要示例代码来具体展示如何实现。 接下来,我需要检查提供的引用内容。引用[3]提到获取类型的属性信息,引用[4]展示了如何获取属性的值,并且提到了使用BindingFlags来获取非公共或静态成员。这些引用内容可以用来支持示例的正确性,确保代码符合用户的需求。例如,在示例中使用BindingFlags.NonPublic | BindingFlags.Instance来获取私有实例字段,或者在获取属性时指定静态和非公共的绑定标志。 另外,用户可能需要处理不同成员的访问权限问题,比如私有成员或者静态成员。这时候,正确设置BindingFlags参数就很重要了。例如,如果要获取私有字段,需要包括BindingFlags.NonPublic和BindingFlags.Instance(如果是实例成员)或BindingFlags.Static(如果是静态成员)。不过,组合这些标志的时候可能会有些容易出错的地方,比如是否需要同时指定Public或NonPublic,或者Instance和Static的组合是否正确。 然后,考虑用户可能的实际应用场景。比如,他们可能在开发一个序列化工具,需要动态地读取对象的各个成员类型,或者在进行自动化测试时,需要验证类的结构是否符合预期。这时候,能够准确获取成员类型的信息就非常重要了。因此,示例代码需要覆盖不同的成员类型,并展示如何获取它们的类型信息,包括属性和字段的类型,方法的返回类型和参数类型。 还有可能的错误情况,比如尝试获取不存在的成员,或者访问权限不足导致的异常。这时候,在示例中可能需要加入异常处理,或者提醒用户注意这些情况。不过用户的问题主要是获取类型的方法和示例,可能暂时不需要处理错误情况,但可以适当提及注意事项,比如访问私有成员需要适当的权限。 最后,整理这些思路,形成一个结构清晰的回答。先介绍反射的基本概念,然后分步骤讲解如何获取不同类型的成员类型,并附上示例代码。确保代码中使用了正确的BindingFlags,并且每个示例都有注释说明。同时,引用提供的参考文献来支持代码的正确性,比如引用[3]和[4]中的内容。 可能还需要考虑用户是否了解反射的基本使用,因此需要简要说明必要的步骤,比如获取Type对象,然后通过Type对象获取成员信息。另外,对于每个示例,说明输出结果,这样用户可以更直观地理解代码的作用。例如,在获取属性类型的示例中,输出属性名和对应的类型名称,如“属性名: Name, 类型: String”。 总结起来,回答的结构应该是: 1. 获取Type对象的方法。 2. 分别获取属性、字段、方法的类型信息,每个部分给出示例代码。 3. 注意事项,比如BindingFlags的使用。 4. 引用相关的参考文献来支持示例的正确性。 这样用户能够一步步按照示例代码进行操作,理解每个步骤的作用,并且知道如何应用到实际开发中。</think>### C#反射获取成员类型的方法与示例 --- #### 一、获取成员类型的基本步骤 1. **获取类型信息**:通过`typeof(类名)`或实例对象的`GetType()`方法获取`Type`对象。 2. **提取成员信息**:使用`Type`类的方法获取属性、字段或方法等成员信息。 3. **访问成员类型**:通过`MemberInfo`的子类(如`PropertyInfo`、`FieldInfo`)访问成员的具体类型。 --- #### 二、具体实现与示例代码 ##### 1. 获取属性类型 通过`PropertyInfo.PropertyType`获取属性的类型: ```csharp using System; using System.Reflection; public class Person { public string Name { get; set; } private int Age { get; set; } } Type type = typeof(Person); // 获取所有公共属性 PropertyInfo[] properties = type.GetProperties(); foreach (PropertyInfo prop in properties) { Console.WriteLine($"属性名: {prop.Name}, 类型: {prop.PropertyType.Name}"); // 输出: 属性名: Name, 类型: String } // 获取私有属性(需指定BindingFlags) PropertyInfo privateProp = type.GetProperty("Age", BindingFlags.NonPublic | BindingFlags.Instance); Console.WriteLine($"私有属性类型: {privateProp?.PropertyType.Name}"); // 输出: 私有属性类型: Int32 ``` [^3][^4] --- ##### 2. 获取字段类型 通过`FieldInfo.FieldType`获取字段的类型: ```csharp public class Student { public int Id; private static string School = "ABC School"; } Type studentType = typeof(Student); // 获取公共字段 FieldInfo[] fields = studentType.GetFields(); foreach (FieldInfo field in fields) { Console.WriteLine($"字段名: {field.Name}, 类型: {field.FieldType.Name}"); // 输出: 字段名: Id, 类型: Int32 } // 获取私有静态字段 FieldInfo privateField = studentType.GetField("School", BindingFlags.NonPublic | BindingFlags.Static); Console.WriteLine($"私有字段类型: {privateField?.FieldType.Name}"); // 输出: 私有字段类型: String ``` [^3][^4] --- ##### 3. 获取方法返回类型与参数类型 通过`MethodInfo.ReturnType`和`MethodInfo.GetParameters()`: ```csharp public class Calculator { public int Add(int a, int b) => a + b; } Type calcType = typeof(Calculator); MethodInfo method = calcType.GetMethod("Add"); // 获取方法返回类型 Console.WriteLine($"方法返回类型: {method.ReturnType.Name}"); // 输出: Int32 // 获取方法参数类型 ParameterInfo[] parameters = method.GetParameters(); foreach (ParameterInfo param in parameters) { Console.WriteLine($"参数名: {param.Name}, 类型: {param.ParameterType.Name}"); // 输出: 参数名: a, 类型: Int32; 参数名: b, 类型: Int32 } ``` [^2][^3] --- #### 三、关键注意事项 1. **绑定标志(BindingFlags)**:获取非公共成员需指定`BindingFlags.NonPublic`,并结合`Instance`或`Static`标志。 2. **访问限制**:反射可以访问私有成员,但需注意安全性问题[^3][^4]。 3. **性能影响**:反射操作较直接调用效率低,建议缓存结果[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值