博客
关于我
反射跳转页面
阅读量: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主从同步及清除信息
查看>>
MySQL主从同步相关-主从多久的延迟?
查看>>
mysql主从同步配置方法和原理
查看>>
mysql主从复制 master和slave配置的参数大全
查看>>
MySQL主从复制几个重要的启动选项
查看>>
MySQL主从复制及排错
查看>>
mysql主从复制及故障修复
查看>>
MySQL主从复制的原理和实践操作
查看>>
webpack loader配置全流程详解
查看>>
mysql主从复制,读写分离,半同步复制实现
查看>>
MySQL主从失败 错误Got fatal error 1236解决方法
查看>>
MySQL主从架构与读写分离实战
查看>>
MySQL主从篇:死磕主从复制中数据同步原理与优化
查看>>
mysql主从配置
查看>>
MySQL之2003-Can‘t connect to MySQL server on ‘localhost‘(10038)的解决办法
查看>>
MySQL之CRUD
查看>>
MySQL之DML
查看>>
Mysql之IN 和 Exists 用法
查看>>
MYSQL之REPLACE INTO和INSERT … ON DUPLICATE KEY UPDATE用法
查看>>
MySQL之SQL语句优化步骤
查看>>