博客
关于我
反射跳转页面
阅读量:387 次
发布时间:2019-03-04

本文共 1267 字,大约阅读时间需要 4 分钟。

Intent intent2 = new Intent();                try {                    Class
clazz = Class.forName("com.example.liuan.test.TestActivity"); intent2.setClass(this, clazz); } catch(Exception e){ e.printStackTrace(); } startActivity(intent2);

【背景介绍】

  最近在进行公司项目开发时遇到这样一个需求:后台配置一个字段用于通知App跳转到相应的Activity。这个字段其实就是一个字符串用来表示是哪一个Activity。在实现初期,采用switch case的匹配机制,在Intent中设置对应的跳转二级页。这种实现方式的效果如下:

Intent intent = new Intent();switch (val) {    case "Acticity1":        intent.setClass(context, Acticity1.class);        break;    case "Acticity2":        intent.setClass(context, Acticity2.class);        break;    case "Acticity3":        intent.setClass(context, Acticity3.class);        break;    case "Acticity4":        intent.setClass(context, Acticity4.class);        break;    default:        break;}

  这里为了能够跳转到不同的二级页,增加了很多case判断,而且每次增加一个二级页,都需要改动原来的代码,显得非常不灵活。经过公司一位资深同事的指点,发现可以利用Java的反射机制高效解决这种问题,实现方案也异常优雅。

【解决方案】

Intent intent = new Intent();try {    Class
clazz = Class.ForName(val); intent.setClass(context, clazz);} catch(Exception e){ e.printStackTrace();}

  利用Java的反射机制,通过用户设置的跳转二级页类型的字符串类名,直接生成对应的class,用作Intent跳转的参数,这样可以有效优化代码逻辑,同时后续增加新的二级页也不用修改源代码直接进行跳转,显得异常灵活。 

转载地址:http://vnvr.baihongyu.com/

你可能感兴趣的文章
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>