2.6.1    知晓当前是在哪一个活动

这个技巧将教会你,如何根据程序当前的界面就能判断出这是哪一个活动。可能你会觉 得挺纳闷的,我自己写的代码怎么会不知道这是哪一个活动呢?很不幸的是,在你真正进入 到企业之后,更有可能的是接手一份别人写的代码,因为你刚进公司就正好有一个新项目启 动的概率并不高。阅读别人的代码时有一个很头疼的问题,就是你需要在某个界面上修改一 些非常简单的东西,但是你半天找不到这个界面对应的活动是哪一个。学会了本节的技巧之 后,这对你来说就再也不是难题了。

我们还是在 ActivityTest 项目的基础上修改。首先需要新建一个 BaseActivity 继承自Activity,然后在 BaseActivity 中重写 onCreate()方法,如下所示:

public class BaseActivity extends Activity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d("BaseActivity", getClass().getSimpleName());

}

}

我们在 onCreate()方法中获取了当前实例的类名,并通过 Log 打印了出来。 接 下 来 我 们 需 要 让 BaseActivity 成 为 ActivityTest 项 目 中 所 有 活 动 的 父 类 。 修 改FirstActivity、SecondActivity 和 ThirdActivity 的继承结构,让它们不再继承自 Activity,而是 继承自 BaseActivity。虽然项目中的活动不再直接继承自 Activity 了,但是它们仍然完全继 承了 Activity 中的所有特性。

现在重新运行程序,然后通过点击按钮分别进入到 FirstActivity 、SecondActivity 和ThirdActivity 的界面,这时观察 LogCat 中的打印信息,如图 2.39 所示。

图   2.39

现在每当我们进入到一个活动的界面,该活动的类名就会被打印出来,这样我们就可以 时时刻刻知晓当前界面对应的是哪一个活动了。

2.6.2   随时随地退出程序

如果目前你手机的界面还停留在 ThirdActivity,你会发现当前想退出程序是非常不方便 的,需要连按三次 Back 键才行。按 Home 键只是把程序挂起,并没有退出程序。其实这个 问题就足以引起你的思考,如果我们的程序需要一个注销或者退出的功能该怎么办呢?必须 要有一个随时随地都能退出程序的方案才行。

其实解决思路也很简单,只需要用一个专门的集合类对所有的活动进行管理就可以了, 下面我们就来实现一下。

新建一个 ActivityCollector 类作为活动管理器,代码如下所示:

public class ActivityCollector {

public static List<Activity> activities = new
ArrayList<Activity>();

public static void addActivity(Activity activity) {

activities.add(activity);

}

public static void removeActivity(Activity activity) {

activities.remove(activity);

}

public static void finishAll() {

for (Activity activity :
activities) {

if
(!activity.isFinishing()) {

activity.finish();

}

}

}

}

在活动管理器中,我们通过一个 List 来暂存活动,然后提供了一个 addActivity()方法用 于向 List 中添加一个活动,提供了一个 removeActivity()方法用于从 List 中移除活动,最后 提供了一个 finishAll()方法用于将 List 中存储的活动全部都销毁掉。

接下来修改 BaseActivity 中的代码,如下所示:

public class BaseActivity extends Activity {

@Override

protected void onCreate(Bundle
savedInstanceState) {

super.onCreate(savedInstanceState);

Log.d("BaseActivity", getClass().getSimpleName());

ActivityCollector.addActivity(this);

}

@Override

protected void onDestroy() {

super.onDestroy();

ActivityCollector.removeActivity(this);

}

}

在 BaseActivity 的 onCreate()方法中调用了 ActivityCollector 的 addActivity()方法,表明 将当前正在创建的活动添加到活动管理器里。然后在 BaseActivity 中重写 onDestroy()方法, 并调用了 ActivityCollector 的 removeActivity()方法,表明将一个马上要销毁的活动从活动管
理器里移除。

从此以后,不管你想在什么地方退出程序,只需要调用 ActivityCollector.finishAll()方法就可以了。例如在 ThirdActivity 界面想通过点击按钮直接退出程序,只需将代码改成如下 所示:

public class ThirdActivity extends BaseActivity {

@Override

protected void
onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);
Log.d("ThirdActivity", "Task id is " + getTaskId());
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.third_layout);

Button button3 = (Button) findViewById(R.id.button_3);

button3.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {
ActivityCollector.finishAll();

}

});

}

}

当然你还可以在销毁所有活动的代码后面再加上杀掉当前进程的代码,以保证程序完全
退出。

2.6.3    启动活动的最佳写法

启动活动的方法相信你已经非常熟悉了,首先通过 Intent 构建出当前的“意图”,然后 调用 startActivity()或 startActivityForResult()方法将活动启动起来,如果有数据需要从一个活
动传递到另一个活动,也可以借助 Intent 来完成。

假设 SecondActivity 中需要用到两个非常重要的字符串参数,在启动 SecondActivity 的 时候必须要传递过来,那么我们很容易会写出如下代码:

Intent intent
= new Intent(FirstActivity.this, SecondActivity.class);

intent.putExtra("param1",
"data1"); intent.putExtra("param2", "data2");
startActivity(intent);

这样写是完全正确的,不管是从语法上还是规范上,只是在真正的项目开发中经常会有
对接的问题出现。比如 SecondActivity 并不是由你开发的,但现在你负责的部分需要有启动SecondActivity 这个功能,而你却不清楚启动这个活动需要传递哪些数据。这时无非就有两种办法,一个是你自己去阅读 SecondActivity 中的代码,二是询问负责编写 SecondActivity

的同事。你会不会觉得很麻烦呢?其实只需要换一种写法,就可以轻松解决掉上面的窘境。 修改 SecondActivity 中的代码,如下所示:

public class
SecondActivity extends BaseActivity {

public static void actionStart(Context context, String data1, String data2) { Intent intent = new Intent(context,
SecondActivity.class); intent.putExtra("param1", data1);

intent.putExtra("param2", data2);

context.startActivity(intent);

}

……

}

我们在 SecondActivity 中添加了一个 actionStart()方法,在这个方法中完成了 Intent 的构 建,另外所有 SecondActivity 中需要的数据都是通过 actionStart()方法的参数传递过来的,然 后把它们存储到 Intent 中,最后调用 startActivity()方法启动 SecondActivity。

这样写的好处在哪里呢?最重要的一点就是一目了然,SecondActivity 所需要的数据全 部都在方法参数中体现出来了,这样即使不用阅读 SecondActivity 中的代码,或者询问负责 编写 SecondActivity 的同事,你也可以非常清晰地知道启动 SecondActivity 需要传递哪些数 据。另外,这样写还简化了启动活动的代码,现在只需要一行代码就可以启动 SecondActivity, 如下所示:

button1.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

SecondActivity.actionStart(FirstActivity.this, "data1",
"data2");

}

});

android:活动的最佳实践的更多相关文章

  1. (Android第一行代码实验一)活动的最佳实践

    活动的最佳实践    1.知晓当前是在哪一个活动         这个技巧将教会你,如何根据程序当前的界面就能判断出这是哪一个活动.  首先需要新建一个 BaseActivity 继承自 Activi ...

  2. Android学习之活动的最佳实践

    •问题的起源 先来模拟一个场景:打开一个 App,最先映入眼帘的是主活动(MainActivity),在该活动中给用户提供了一个 Button, 用户点击该 Button 实现由 MainActivi ...

  3. Android中活动的最佳实践(如何很快的看懂别人的代码activity)

    这种方法主要在你拿到别人的代码时候很多activity一时半会儿看不懂,用了这个方法以后就可以边实践操作就能够知道具体哪个activity是干什么用的 1.新建一个BaseActivity的类,让他继 ...

  4. (转)Android开发:性能最佳实践-管理应用内存

    翻自:http://developer.android.com/training/articles/memory.html 在任何软件开发环境中,RAM都是宝贵的资源,但在移动操作系统中更加珍贵.尽管 ...

  5. Android+PHP开发最佳实践

    本书以一个完整的微博应用项目实例为主线,由浅入深地讲解了Android客户端开发和PHP服务端开发的思路和技巧.从前期的产品设计.架构设计,到客户端和服务器的编码实现,再到性能测试和系统优化,以及最后 ...

  6. Android UX & UI 最佳实践: 设计有效的导航

    Best Practices for User Experience & UI Designing Effective Navigation 导航:帮助用户有效直观地使用你的应用. Plann ...

  7. 执行Android后台任务的最佳实践

    灵活执行后台任务可以帮助提升应用性能,并最小化电量损耗. Android后台任务主题包含以下三个子主题: 1. 在IntentService中执行后台任务: 2. 使用CursorLoader在后台加 ...

  8. Android后台处理最佳实践(Best Practices for Background Jobs)

    本课将告诉你如何通过后台加载来加速应用启动和降低应用耗电. 后台跑服务 除非你做了特殊指定,否则在应用中的大部分前台操作都是在一个特殊的UI线程里面进行的.这有可能会导致一些问题,因为长时间运行的操作 ...

  9. Hush Framework框架配置(续) 转自《Android和PHP最佳实践》官方站

    图书资源下载 Xampp 开发环境下载:http://pan.baidu.com/share/link?shareid=531771&uk=773037279 微博实例完整源码包下载:http ...

随机推荐

  1. OpenLayers 3 之 地图图层数据来源(ol.source)详解

    原文地址 source 是 Layer 的重要组成部分,表示图层的来源,也就是服务地址.除了在构造函数中制定外,可以使用 layer.setSource(source) 稍后指定.一.包含的类型 ol ...

  2. MySQL乱码问题以及utf8mb4字符集

    MySQL乱码问题以及utf8mb4字符集 1.乱码 推荐大家看 深入MySQL字符集设置 ,区分检查client端.server端的编码:最简单暴力的方式,是在所有的环节都显式明确的指定相同的编码, ...

  3. Promise初探

    在JavaScript的世界中,所有代码都是单线程执行的. 由于这个“缺陷”,导致JavaScript的所有网络操作,浏览器事件,都必须是异步执行.异步执行可以用回调函数实现: function ru ...

  4. java iterator(迭代器)

    任何容器类,都必须有某种方式可以插入元素并将它们再次取出,毕竟持有事物是容器最基本的工作,对于List,add()插入fang,get()取出,如果从更高层的角度思考,会发现这里有个确定:要用容器,必 ...

  5. jQuery.lazyload详解(转)

    转自:http://www.cnblogs.com/wenbo/archive/2011/07/15/2107579.html <script type="text/javascrip ...

  6. Java编程的逻辑 (2) - 赋值

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  7. AWS 使用经验

    掐指一算,自己第一次使用 AWS 已经是两年前的事情了,这也是云计算和大数据等技术迅猛发展的两年.这期间,大抵间间断断地使用着,FreeTier Instance 也运行快一年了,马上进入收费周期.虽 ...

  8. .NetCore下 Exceptionless 分布式日志的个性化处理

    Event Type 在Exceptionless中有 Exception .LogMessage.Broken Links .Feature Usages 接下来就这几种类型分别添加日志记录 Exc ...

  9. 历数依赖注入的N种玩法

    历数依赖注入的N种玩法 在对ASP.NET Core管道中关于依赖注入的两个核心对象(ServiceCollection和ServiceProvider)有了足够的认识之后,我们将关注的目光转移到编程 ...

  10. js文件的版本控制

    使用grunt完成requirejs的合并压缩和js文件的版本控制   最近有一个项目使用了 requirejs 来解决前端的模块化,但是随着页面和模块的越来越多,我发现我快要hold不住这些可爱的j ...