- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在 android 中,为什么我们应该使用 asyntask 和服务,而不是使用 new thread() 并编写必要的后台功能?
我知道我们不应该在主线程或 UI 线程上运行长时间运行的操作,例如从服务器下载文件。并且应该使用异步任务或服务。
但是为什么我们不能创建一个新的线程(){它最终是一个新线程而不是主线程}并在该线程中编写必要的长时间运行的操作。
为什么谷歌创建了 AsyncTask 和服务而不建议使用常规的 New Thread()???
提前致谢
编辑1:可能是我在我的问题中不清楚或者不确定,如果我是,即使是现在。帮帮我。
我明白了,整点从
开始Do not block the UI thread
Do not access the Android UI toolkit from outside the UI thread
为什么?1.UI线程能处理多少?我们如何确定断点? ANR点是如何确定的?我们可以跟踪吗?
2. 当服务组件处理长时间运行的操作时,为什么 Activity 组件不能处理?
请记住,如果您确实使用服务,默认情况下它仍会在应用程序的主线程中运行,因此如果它执行密集或阻塞操作,您仍应在服务中创建一个新线程 http://developer.android.com/guide/components/services.html以上声明来自android文档。
3.如果我们如此关心主线程,为什么不能立即在新线程中启动服务?不要在问题 3 中误会我的意思,我试图了解在主线程中启动服务的优势。默认情况下。
在上面的语句中,它是否暗示了主线程启动和处理服务的长时间运行操作负载的能力?如果是,是否与问题 1 矛盾。
最佳答案
好吧,让我们看看如何使用线程执行简单任务。
第一步是使用 Runnable 创建线程。像这样:
private void fetchResultsAsync() {
Runnable runner = new Runnable() {
@Override
public void run() {
List<String> results = fetchResultsFromWebServer();
}
};
new Thread(runner).run();
}
问题是,我们需要显示结果,所以它实际上更像这样:
private void fetchResultsAsync() {
Runnable runner = new Runnable() {
@Override
public void run() {
List<String> results = fetchResultsFromWebServer();
workFinished(results);
}
};
new Thread(runner).run();
}
private void workFinished(List<String> results) {
// show the results on the UI
}
看起来不错,但是有问题;回调方法 (workFinished) 必须更新 UI。如果我们从任何非主线程执行此操作,都会出现大问题。我们需要一种线程安全的方式来调用该方法,这就是 Handlers 的用途。我们还引入了一个更新进度的方法,这很常见。代码现在看起来像这样:
private final Handler myHandler = new Handler();
private void fetchResultsAsync() {
Runnable runner = new Runnable() {
@Override
public void run() {
List<String> results = fetchResultsFromWebServer();
workFinished(results);
}
};
new Thread(runner).run();
}
private void showProgress(int result) {
myHandler.post(new Runnable() {
@Override
public void run() {
// update a progress bar here
}
});
}
private void workFinished(final List<String> results) {
myHandler.post(new Runnable() {
@Override
public void run() {
// show the results on the UI
}
});
}
将此与使用 AsyncTask 的实现进行比较:
private void fetchWithTask() {
new AsyncTask<Void, Integer, List<String>>() {
@Override
protected List<String> doInBackground(Void... params) {
return fetchResultsFromWebServer();
}
@Override
protected void onPostExecute(List<String> strings) {
// show the results on the UI
}
@Override
protected void onProgressUpdate(Integer... values) {
// update a progress bar here
}
}.execute();
}
它在代码行数上没有太大区别,但是需要发生什么以及发生在哪里更加明显。它可以防止您犯下令人讨厌的错误,例如忘记将接触 UI 的代码包装在必须发布到 UI 线程拥有的处理程序的 Runnable 中。
现在假设您有几种不同类型的小型后台任务需要执行。从错误的后台线程调用错误的 showProgress 或 workFinished 方法非常容易,因为您必须自己将所有这些部分连接在一起。
还有一个非常讨厌的错误潜伏在 Handler 的默认构造函数的使用中。如果包含类在运行时首先被非 UI 线程引用,则处理程序将属于该线程。 AsyncTask 隐藏总是在正确的线程上做事。这很难捕捉!
乍一看,AsyncTasks 似乎没什么用,但回调管道是它们真正大有作为的地方。
关于android - 为什么我们应该使用 aysntask 或 service 而不是新线程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20205763/
我正在使用 choronos,它建议使用 start/stop 命令开始停止,如下所示 开始计时 停止计时 但是,我正在编写 puppet manifest,它只适用于下面的服务命令。 服务计时开始
来历及作用 services.exe进程程序文件是由微软公司为其发布的Windows操作系统定义的一个系统进程,常见于Windows 2000/XP/Vista/2007等系统中,被描述为服务和控
我一直在尝试使用installutil:installutil /u GSIS.FileMoverService.exe安装Windows服务。 我得到的输出是: Uninstalling assem
如果一个域有多个团队和多个 Web 应用程序,那么注册 Service Worker 来管理整个站点的最佳建议是什么?具有范围的顶级服务 worker /或子域中的多个服务 worker ?由于一个域
我已经在 eclipse 中创建了企业项目。动态web项目和ejb项目对企业项目有借鉴意义。当我运行管理员(企业项目)运行时选择 wildfly 服务器 18。我收到以下错误。谁能告诉我我错过了什么。
我已经使用 apache-cxf-2.7.4 创建了一个 Web 服务。我进入了我的项目中制作的类(class)。我的项目中的库是: math3-commons-3.2.jar XStream-1.4
我在域中的 Virtual Box 中运行集群计算机,默认情况下服务在 Network 服务下运行,服务一直停止,事件日志中出现以下错误。 请从下面的错误日志中查找错误详细信息。任何帮助都会很棒。 L
在我的应用程序中,用户可以在 map 上发布事件。应用程序的入口点是一个无状态的 web api 服务。为了在内部代表用户,我想要一个用户服务。我应该何时使用 Reliable Stateful Ac
当我尝试运行在WIX中创建的安装程序时,出现以下错误消息: “服务'Report Generator Service'(报告生成器服务)无法启动。请验证您是否具有启动系统服务的足够特权”。 我已经在这
尝试使用 cloudformation 创建 ECS 服务(在 Fargate 上)但出现错误: Invalid service in ARN (Service: AmazonECS; Status
我正在编写一个简单的Windows服务,该服务每个月向所有员工发送一封电子邮件。我的问题是,完成后如何停止自我?我是该领域的新手,请帮帮我。非常感谢。 它将部署在服务器上以每月运行。我没有开始做这件事
有谁知道是否有办法在 service worker 中获取此号码或日期: 将我的服务 worker 缓存命名为 cache-1182 会很方便或 cache-20171127171448 我想在安装事
我想开始使用 Azure Service Fabric 技术。 我按照this document工作并安装最新的SDK。安装后,我打开 PowerShell(“以管理员身份运行”)命令行窗口并写入这些
我在使用 whenever gem 时遇到了一些问题。我创建了一个 rake 任务,当我自己启动它时它工作得很好但是当我在日志中收到以下消息时尝试自动执行它: ActiveRecord::Statem
我想在 service fabric 集群中为两个不同的 web 应用程序(webpi/website)共享 http/80 端口,应用程序必须有 2 个不同的主机名: mywebapi.com 和
我创建了一个使用 MongoDB 实现 hibernate OGM 的应用程序。它在 Eclipse 中运行得很好,但是,当我构建一个 fat jar 并尝试运行它时,出现以下错误: Exceptio
我有一个 Selenium Python 测试套件。它开始运行,但几分钟后抛出以下错误: Exception AttributeError: "'Service' object has no attr
我按照此链接的说明进行操作:https://www.thegeekdiary.com/centos-rhel-7-how-to-make-custom-script-to-run-automatica
我在 ubuntu 下的 jboss 上部署了简单的“HelloWorld”Web 服务。 我创建了简单的客户端,但我无法让它工作。每次运行客户端时,我都会收到 NullPointerExceptio
我正在尝试为我的网站使用后台定期同步。我正在使用 localhost 并在 1*1000 毫秒时注册 periodicsync 事件,但这根本不会触发。 我看过这个demo ,但即使我将该网站安装为应
我是一名优秀的程序员,十分优秀!