java中的onresume_java – 直接onResume()调用的替代方法

java中的onresume_java – 直接onResume()调用的替代方法我正在重写我的Android应用以消除对onResume()的直接调用.我的应用程序目前在onResume()内部完成大部分工作,然后发布显示,这是onResume()的结束.@OverridepublicvoidonResume(){super.onResume();//getcurrentdateandtime,//anddetermineifdaylightsav…

大家好,又见面了,我是你们的朋友全栈君。

我正在重写我的Android应用以消除对onResume()的直接调用.

我的应用程序目前在onResume()内部完成大部分工作,然后发布显示,这是onResume()的结束.

@Override

public void onResume() {

super.onResume();

// get current date and time,

// and determine if daylight savings time is in effect.

//…600 lines of code

// output both the chart and report

//

image.setImageBitmap(heightChart);

report.setImageBitmap(reportBitmap);

}

下一步是收集用户输入,告诉我对其进行了哪些更改

报告用户的意愿. (它可能是新位置,新日期或新显示样式等).这样做如下:

@Override

public boolean onOptionsItemSelected(MenuItem item) {

final int STATION_REQUEST = 1;

int test = 1;

switch (item.getItemId()) {

case R.id.refresh: {

userDateSet = false;

onResume();

return true;

} // come to the present.

//…200 lines of code

default:

return super.onOptionsItemSelected(item);

}

}

如示例所示,在确定新用户命令后,通过调用onResume()重新生成输出.这是不好的做法,我已经知道了!!然而,就我所确定的而言,它运作良好,老实说我不明白它的问题.

我的解决方案是将600行代码收集到一个单独的例程中,并从onResume()内部和onOptionsItemSelected()中的多个点调用它.

@Override

public void onResume() {

super.onResume();

myOnResumeCode();

}

在onOptionsItemSelected()内部执行此操作

@Override

public boolean onOptionsItemSelected(MenuItem item) {

final int STATION_REQUEST = 1;

int test = 1;

switch (item.getItemId()) {

case R.id.refresh: {

userDateSet = false;

myOnResumeCode();

return true;

} // come to the present.

… // Other statements

}

这种方法可以接受吗?如果没有,任何缺少“重写整个事情”的建议对我都非常有帮助.我已经广泛搜索了一个干净的解决方案,但找不到我能理解的解决方案.谢谢.

解决方法:

I honestly do not understand the problem with it.

你的onResume()方法实现本身是无害的.但是调用它的超级方法是super.onResume();会让系统认为它是恢复事件的另一种情况.这将导致刷新视图和类似内部工作的不必要的资源使用.因此,在任何情况下都必须避免显式调用生命周期回调方法.

Is this method acceptable?

代码行数不会使其可接受.这是一个你需要问自己的问题.如果您认为整个代码将在该事件中执行,那么您应该这样做.否则你可以节省一些资源.

如果你正在做这样的事情

public boolean onOptionsItemSelected(MenuItem item) {

switch (item.getItemId()) {

case R.id.mnuEnableSomething:

{

refreshTheWholeUi();

return true;

}

case R.id.mnuClearList:

{

refreshTheWholeUi();

return true;

}

}

}

public void onResume() {

super.onResume();

refreshTheWholeUi();

}

然后将其更改为此值得.

public boolean onOptionsItemSelected(MenuItem item) {

switch (item.getItemId()) {

case R.id.mnuEnableSomething:

{

enableIt();

return true;

}

case R.id.mnuClearList:

{

justClearTheList();

return true;

}

}

}

public void onResume() {

super.onResume();

refreshTheWholeUi();

}

现在,以该主题为核心

回答后,我仔细看了一下你的问题,这让我大吃一惊.

My plan is to move those 600 lines to a separate class file. That will

keep them away from damage while I work on the command decoder in the

activity source file

并不是.但你真的很亲密.忘掉活动生命周期,方法,类等所有复杂性,只关注计算机程序的最基本执行级别.

程序总是逐行执行.如何安排代码没有任何区别.将程序正确地构造成方法,类等是为了程序员的方便.对于系统来说,它始终是一系列的线条.因此,在执行繁重的任务时,UI可能变得没有响应,因为它必须等到轮到它.

那么如何并行工作呢?

多线程…!

它听起来并不那么复杂.

您必须找到代码中最关键的部分,它更多地使用资源并将其移动到不同的线程.

我已经说明了如何在这里进行多线程.

public boolean onOptionsItemSelected(MenuItem item) {

switch (item.getItemId()) {

case R.id.mnuProceessImageAction:

{

//Let user know that a background operation is running

//with a progressbar or something

processImage(mImage);

return true;

}

}

}

private void processImage(Object image) {

new Thread(new Runnable(){

public void run() {

//Doing all the heavy duty here.

//………………………..

//Now you have the result. Use it to update the UI.

//(UI can be updated only from the UI thread)

runOnUiThread(new Runnable(){

public void run() {

updateTheUiWithTheImage(proccessedImage);

}

});

}

}).start();

}

private void updateTheUiWithTheImage(Object image) {

try {

//Hide progressbar if you have one

//Now it wont make the UI to struggle to use it.

} catch(NullPointerException e) {

e.printStackTrace;

}

}

这是最基本的形式.当然还有其他选择(如AsyncTask).您可以在线轻松找到更多相关信息(尝试搜索“Android中的多线程”).随意问更多.

标签:onresume,android,java,android-activity,android-lifecycle

来源: https://codeday.me/bug/20190910/1798329.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/137231.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 易语言执行mysql命令_易语言执行sql进度条 易语言mysql

    易语言执行mysql命令_易语言执行sql进度条 易语言mysql易语言的进度条怎么使用?我就让进度条每秒进一格,一百秒进度条满!用了一个时钟组件。.版本2.程序集窗口程序集3.子程序__启动窗口_创建完毕.子程序_按钮1_被单击.如果(编辑框1.内容≠“”或编辑框2.内容≠“”)时钟1.时钟周期=1000.否则信息框(“请输入内容”,0,).如果结束.子程序_时钟1_周期事件.如果(进度条1.位置<进度条…

  • xsync集群分发脚本的改良[通俗易懂]

    xsync集群分发脚本的改良[通俗易懂]集群分发脚本xsync带多参数1.0增强了一下带参个数xsync1.0#!/bin/bash#校验参数pcount=$#if(($pcount==0))then exitfi#获取用户名user=`whoami`#获取文件名,路径for((i=1;i<=$#;i++))#对多个传参进行分析dob=${!i} #这里用到了“间接变量”语法fname=`basename$b`dname=`dirname$b`dir=`cd$dname;pwd`

  • 人力资源管理系统详细设计说明书[通俗易懂]

    人力资源管理系统详细设计说明书[通俗易懂]人力资源管理系统详细设计说明书组名 : K2组员 : 罗猛、丘佩茵2021年1月12日目录1引言 31.1编写目的 31.2背景说明 31.3定义 31.4参考资料 32系统结构 42.1总系统结构图 42.2管理员登录注册模块结构图 42.3部门管理模块结构图 52.4员工管理模块结构图 52.5培训管理模块结构图 62.6招聘管理模块结构图 62.7奖惩管理模块结构图 72.8薪资管理模块结构图 72.9系统管理模块结构图 81.10查看消息模块结构图 83系

  • srvctl start_局部视图的配置规定是

    srvctl start_局部视图的配置规定是SRVCTL概述SRVCTL是ORACLERAC集群配置管理的工具,可以管理Database、Instance、ASM、Service、Listener和NodeApplication,NodeApplication包括GSD,ONS,VIP。srvctl的命令格式为srvctl<command><target>[options]srvctlUs…

  • github下载文件很慢(github打开慢)

    方法:更改hosts文件第一步:查询ip地址使用https://www.ipaddress.com/查询下面3个网站的ip地址github.comgithub.global.ssl.fastly.netcodeload.github.com2020.8.21查询结果如下(请勿直接复制):140.82.112.4github.com199.232.69.194github.global.ssl.fastly.net140.82.113.10codeload.github.com第二步

  • JAVA解析xml的五种方式比较

    JAVA解析xml的五种方式比较1)DOM解析 DOM是html和xml的应用程序接口(API),以层次结构(类似于树型)来组织节点和信息片段,映射XML文档的结构,允许获取 和操作文档的任意部分,是W3C的官方标准 【优点】 ①允许应用程序对数据和结构做出更改。 ②访问是双向的,可以在任何时候在树中上下导航,获取和操作任意部分的数据。 【缺点】 ①通常需要加载整个XML文档来构造层次结构,消耗资源大。…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号