博客
关于我
反射跳转页面
阅读量: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 DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>
MuseTalk如何生成高质量视频(使用技巧)
查看>>
mutiplemap 总结
查看>>
MySQL DELETE 表别名问题
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>