Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >正确使用AsyncTasks和处理视图和活动所需的对象

正确使用AsyncTasks和处理视图和活动所需的对象
EN

Stack Overflow用户
提问于 2014-04-01 07:17:13
回答 1查看 104关注 0票数 0

因此,我目前正在编写一个应用程序,并有一些关于如何处理AsyncTasks的问题。我尽可能详细地描述我的问题。我有以下课程:

  1. CustomLocationListener. MainActivity -此活动只执行setContentView(R.layout.myLayout)并创建my MainActivity的对象。布局包含一个自定义视图和一个ProgressBar
  2. CustomLocationListener --这基本上只是一个实现LocationListener并具有默认LocationListener方法的类。此外,我还编写了一种方法,以检查哪些提供者能够优先使用NETWORK_PROVIDER
  3. Display --这只是一个辅助类。我只使用它来获得显示指标来计算一些东西。
  4. MyCustomView -这个类扩展了View类。它还有一个类型为Display (我自己的类)的属性。

现在你应该知道对我的代码很重要的一切。那么,我现在的问题是,如何处理AsyncTasks,因为这是应用程序应该通过的步骤:

  1. 获取用户设备的当前位置。
  2. 对数据库服务器(mysql)执行一些查询,并将它们保存为非持久性(数据由城市名称组成)
  3. 计算数据库中用户位置与城市之间的距离。
  4. 做一些其他的计算,找出在屏幕上画的位置。
  5. 画出一切

最重要的是,我想实现一个进度条,它应该是有效的,直到所有的计算和绘图阶段开始。所以,我有点搞不懂该在哪里编码什么。我是说,这两种计算(第3和第4步)。一定要了解对方。步骤4的计算需要步骤3的计算结果,而且我的活动类也应该知道计算的状态,因为当我开始绘图时,必须使ProgressBar不可见。

我希望我足够详细,感谢你的帮助!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-04-01 07:45:33

那么,您可以从AsyncTask文档中收集到以下内容:

执行异步任务时,该任务将经历4个步骤:

  1. onPreExecute(),在执行任务之前在UI线程上调用。此步骤通常用于设置任务,例如,通过在用户界面中显示进度条。
  2. doInBackground(Params.),在onPreExecute()完成执行后立即在后台线程上调用。此步骤用于执行可能需要很长时间的背景计算。异步任务的参数将传递到此步骤。此步骤必须返回计算结果,并将其传递回最后一步。此步骤也可以使用publishProgress(进度.)发布一个或多个进度单位。这些值被发布在UI线程上,在onProgressUpdate中(进度.)走一步。
  3. onProgressUpdate(进步.),在调用publishProgress(进度.)后在UI线程上调用。执行的时间未定义。此方法用于在后台计算仍在执行时显示用户界面中的任何形式的进度。例如,它可以用于在文本字段中动画进度条或显示日志。
  4. onPostExecute(结果),在后台计算完成后在UI线程上调用。背景计算的结果作为参数传递到此步骤。

因此,我建议您使用两个AsyncTasks在doInBackground(Params...)方法中完成geo和服务器(各一个)的工作,并将值返回给onPostExecute(Result)方法中的MainActivity。另外,通过使用MainActivity方法,让您的onProgressUpdate(Progress..)知道进度。

当它们完成后,您可以选择使用另一个AsyncTask来执行计算,如果它们明显地拖住了UI线程。对它使用相同的执行方法。

当这一切完成后,你就可以画一个视图了.(我想你就是这么说的)

在开始“加载.”计算之前,先加载一个默认视图。或者别的什么。拥有另一个不可见的视图,当您准备显示计算出来的东西时,准备就绪,并且在准备要绘制的时候将其设置为可见。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22790021

复制
相关文章
BIT类型在SQL Server中的存储大小
对于一般的INT、CHAR、tinyint等数据类型,他们占用的存储空间都是以Byte字节为单位的,但是BIT类型由于只有0和1或者说false和true,这种情况只需要一个Bit位就可以表示了,那么在SQL Server中BIT类型到底占用了多少空间?是不是由一个Bit位来存储的?或者可能是使用一个字节来存储的?
深蓝studyzy
2022/06/16
3.5K0
Java 查找 List 中的最大值、最小值Java 查找 List 中的最大值、最小值
Java 查找 List 中的最大值、最小值 java> List<Long> list = new ArrayList(); java.util.List<java.lang.Long> list = [] java> list.add(1L) java.lang.Boolean res1 = true java> list.add(2L) java.lang.Boolean res2 = true java> Collections.max(list) java.lang.Long res3 = 2 j
一个会写诗的程序员
2018/08/17
3.9K0
怎样在SQL Server数据库执行sql脚本?
注意:在操作前需要先把数据库的数据进行备份,以防数据出错,导致数据库损坏!(找到数据库,右键备份,选择备份输出的位置即可。)
管家婆软件
2022/11/21
18K0
怎样在SQL Server数据库执行sql脚本?
01:查找特定的值
01:查找特定的值 查看 提交 统计 1 #include<iostream> 2 using namespace std; 3 int a[10001]; 4 int main() 5 { 6 int n; 7 int ans; 8 cin>>n; 9 for(int i=1;i<=n;i++) 10 { 11 cin>>a[i]; 12 } 13 cin>>ans; 14 for(int j=1;j<
attack
2018/04/03
1.8K0
SQL Server中的GUID
GUID(Global unique identifier)全局唯一标识符,它是由网卡上的标识数字(每个网卡都有唯一的标识号)以及 CPU 时钟的唯一数字生成的的一个 16 字节的二进制值。
全栈程序员站长
2022/07/15
5.2K0
在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误
在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管道提供程序, error: 40 - 无法打开到 SQL Server 的连接)
星哥玩云
2022/08/16
5.5K0
在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误
Sql Server 中 根据具体的值 查找该值所在的表和字段
在我们的工作中经常遇到这样一个问题,在页面中保存一条数据,有个字段值为“张三”,但是,不知道这条数据保存在了哪个表中,现在我们想要追踪该值是存储到了那个表的那个字段中,具体要怎么操作呢?下面我们可以借助存储过程来解决这一问题
jamesjiang
2022/11/20
6.4K0
Sql Server 中 根据具体的值 查找该值所在的表和字段
管理sql server表数据_sql server如何使用
表是SQL Server中最基本的数据库对象,用于存储数据的一种逻辑结构,由行和列组成, 它又称为二维表。 例如,在学生成绩管理系统中,表1–是一个学生表(student)。
全栈程序员站长
2022/09/23
1.8K0
管理sql server表数据_sql server如何使用
SQL Server 2008中的hierarchyid
本人转载:http://www.cnblogs.com/chenxizhang/archive/2009/04/26/1444016.html
跟着阿笨一起玩NET
2018/09/18
1.7K0
在IIS中为SQL Server 2008配置报表服务
不知道是不是SQL Server 2008的Bug,我在安装了SQL2008后(选择了安装报表服务的),但是在IIS中根本没有报表服务的虚拟目录。只是这么一个问题,其他BI设计器、报表服务等都还算正常。
深蓝studyzy
2022/06/16
2K0
在IIS中为SQL Server 2008配置报表服务
SQL Server 数据恢复
--创建测试数据库 CREATE DATABASE Db GO --对数据库进行备份 BACKUP DATABASE Db TO DISK='c:\db.bak' WITH FORMAT GO --创建测试表 CREATE TABLE Db.dbo.TB_test(ID int) --延时1秒钟,再进行后面的操作(这是由于SQL Server的时间精度最大为百分之三秒,不延时的话,可能会导致还原到时间点的操作失败) WAITFOR DELAY '00:00:01' GO --假设我们现在误操作删除了 Db.dbo.TB_test 这个表 DROP TABLE Db.dbo.TB_test --保存删除表的时间 SELECT dt=GETDATE() INTO # GO --在删除操作后,发现不应该删除表 Db.dbo.TB_test --下面演示了如何恢复这个误删除的表 Db.dbo.TB_test --首先,备份事务日志(使用事务日志才能还原到指定的时间点) BACKUP LOG Db TO DISK='c:\db_log.bak' WITH FORMAT GO --接下来,我们要先还原完全备份(还原日志必须在还原完全备份的基础上进行) RESTORE DATABASE Db FROM DISK='c:\db.bak' WITH REPLACE,NORECOVERY GO --将事务日志还原到删除操作前(这里的时间对应上面的删除时间,并比删除时间略早 DECLARE @dt datetime SELECT @dt=DATEADD(ms,-20,dt) FROM # --获取比表被删除的时间略早的时间 RESTORE LOG Db FROM DISK='c:\db_log.bak' WITH RECOVERY,STOPAT=@dt GO --查询一下,看表是否恢复 SELECT * FROM Db.dbo.TB_test /*--结果: ID ----------- (所影响的行数为 0 行) --*/ --测试成功 GO --最后删除我们做的测试环境 DROP DATABASE Db DROP TABLE #
_一级菜鸟
2020/08/02
1.3K0
在scala中使用spark sql解决特定需求
Spark sql on hive的一个强大之处就是能够嵌在编程语言内执行,比如在Java或者Scala,Python里面,正是因为这样的特性,使得spark sql开发变得更加有趣。 比如我们想做一个简单的交互式查询,我们可以直接在Linux终端直接执行spark sql查询Hive来分析,也可以开发一个jar来完成特定的任务。 有些时候单纯的使用sql开发可能功能有限,比如我有下面的一个功能: 一张大的hive表里面有许多带有日期的数据,现在一个需求是能够把不同天的数据分离导入到不同天的es索引里面,方
我是攻城师
2018/05/14
1.3K0
(简单、可靠的安装方法)在Windows Server2016中安装SQL Server2016
WinServer2016的安装参见:  在虚拟机中安装Windows Server2016
跟着阿笨一起玩NET
2020/06/15
6.5K0
1 - SQL Server 2008 之 使用SQL语句创建具有约束条件的表
本文介绍了SQL Server 2008中创建具有约束条件的表的方法。文章首先介绍了约束条件的六种类型,然后通过实例演示了如何使用这些约束条件来确保数据的完整性和唯一性。最后,文章介绍了如何创建具有约束条件的表,并使用检查约束来确保数据的完整性。
CNXY
2017/12/25
2.9K0
1 - SQL Server 2008 之 使用SQL语句创建具有约束条件的表
Excel公式技巧54: 在多个工作表中查找最大值/最小值
要在Excel工作表中获取最大值或最小值,我们马上就会想到使用MAX/MIN函数。例如,下图1所示的工作表,使用公式:
fanjy
2020/09/17
11.7K0
Excel公式技巧54: 在多个工作表中查找最大值/最小值
SQL SERVER的数据类型
    数据类弄是数据的一种属性,表示数据所表示信息的类型。任何一种计算机语言都定义了自己的数据类型。当然,不同的程序语言都具有不同的特点,所定义的数据类型的各类和名称都或多或少有些不同。SQLServer 提供了 25 种数据类型:   ·Binary [(n)]   ·Varbinary [(n)]   ·Char [(n)]   ·Varchar[(n)]   ·Nchar[(n)]   ·Nvarchar[(n)]   ·Datetime   ·Smalldatetime   ·Decimal[(p[,s])]   ·Numeric[(p[,s])]   ·Float[(n)]   ·Real   ·Int   ·Smallint   ·Tinyint   ·Money   ·Smallmoney   ·Bit   ·Cursor   ·Sysname   ·Timestamp   ·Uniqueidentifier   ·Text   ·Image   ·Ntext
Tony老师
2020/03/05
1.6K0
SQL 找出分组中具有极值的行
你可能也遇到过这种需求:找出每个部门入职最早的员工的信息;获取每个科目最高分的学生信息;获取用户最近一次的完整登录信息。
白日梦想家
2020/07/20
1.8K0
SQL 找出分组中具有极值的行
为什么SQL语句Where 1=1 and在SQL Server中不影响性能
    最近一个朋友和我探讨关于Where 1=1 and这种形式的语句会不会影响性能。最后结论是不影响。
_一级菜鸟
2022/11/16
2K0
为什么SQL语句Where 1=1 and在SQL Server中不影响性能
在windows系统下的SQL Server 创建数据库方法
SQL Server创建数据库的方法有两种:一种是通过运行 SQL 脚本;另一种是直接使用 SQL Server 管理套件即可创建数据库,在本节中我们使用的是后一种方法。
用户8965210
2021/08/31
1.4K0
在Docker中快速使用SQL Server 2022环境
docker hub地址:https://hub.docker.com/_/microsoft-mssql-server
AiDBA宝典
2023/04/27
4.5K0
在Docker中快速使用SQL Server 2022环境

相似问题

在SQL Server中查找最大值的时间

10

在SQL中查找具有最大值的记录

30

SQL Server :在结果集中查找最大值

20

在sql server中查找具有重复数据的多个表。

22

在sql server中查找特定日期的值。

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文