博客
关于我
反射跳转页面
阅读量: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优化系列-优化版造数据(存储过程+函数+修改存储引擎)-2
查看>>
MySql优化系列-进阶版造数据(load data statment)-3
查看>>
MySql优化系列-造数据(存储过程+函数)-1
查看>>
MySQL优化配置详解
查看>>
Mysql优化高级篇(全)
查看>>
mysql会员求积分_MySql-统计所有会员的最高前10次的积分和
查看>>
mysql会对联合索性排序优化_MySQL索引优化实战
查看>>
MySQL作为服务端的配置过程与实际案例
查看>>