Android下关于泛型class类型的获取

本文记录了Android开发中MVP模式下,优化Presenter类创建过程的方法。总结了老的实现方式和改进后的实现,探讨了如何在公共父类中处理可变参数类型的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 目的

在Android开发中,MVP模式的开发为大多数人所使用,在MVP模式中,一般需要在Activity中创建与之对应的Presenter类。之前项目中实现的方法比较繁琐,通过查资料以后,进行了部分优化,特此记录。

2. 老的实现方式

不废话,直接上代码。


    public abstract class BaseActivity<T extends BasePresenter> extends Activity{
        protected T mPresenter;
        @Override
        protected void onCreate(@Nullable Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            mPresenter = createPresenter();
         }   
        /**
        * 定义一个抽象方法,由继承BaseActivity的子类去实现
        */
         protected abstract T createPresenter();

    }

    class TestActivity extends BaseActivity<TestPresenter> {
        /**
        *   在每个继承BaseActivity的子Activity去实现createPresenter方法
        */
        @Override
        protected TestPresenter createPresenter() {
            return new TestPresenter(this);
        }
    }

3. 改进以后的实现方式

/*
* 这里在base内部实现了createPresenter方法,当然还有可能有其他的抽象方法,所以这里的类暂时还是用一个抽象类
* 来表示
*/
public abstract class BaseActivity<T extends BasePresenter> extends Activity{
        protected T mPresenter;
        @Override
        protected void onCreate(@Nullable Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            mPresenter = createPresenter();
         }   
        /**
        *  直接在createPresenter中拿到当前类的泛型的class,利用反射制造一个对象并返回
        */
         protected T createPresenter(){
             //这里获得到的是类的泛型的类型
            ParameterizedType type = (ParameterizedType) getClass().getGenericSuperclass();
            if (type != null) {
            Type[] actualTypeArguments = type.getActualTypeArguments();
            Class<T> tClass = (Class<T>) actualTypeArguments[0];
            mPresenter = PresenterFactory.creatPresenter(tClass);
        }
};

/**
*  presenter 的工厂类
*/
public class PresenterFactory {

    public static <T extends BasePresenter> T creatPresenter(Class<T> tClass) {
        T t = null;
        try {
            t = tClass.newInstance();
        } catch (InstantiationException e) {
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        }
        return t;
    }
}
/*
*  继承了BaseActivity的子类,不再需要实现createPresenter方法,可以直接使用mPresenter进行操作
*/
class TestActivity extends BaseActivity<TestPresenter> {

        @Override
        protected void onCreate(@Nullable Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            //直接使用presenter类(不再需要通过实现createPresenter方法来得到presenter的对象)
            mPresenter.doSth();
         }
    }

3. 总结

这里拿Activity和Presenter类来举例,其实在开发中还有其他的场景,需要在一个公共的父类下,有一个可变的参数类型的对象,在具体的子类中去指定这个可变参数类型的类型的场景。当然了,以上只是个人的一些体会与经验,如果有错误之处,还望读者予以指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值