- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我正在开发一款在 Android NDK 中运行大部分原生代码的社交游戏。游戏有 3 个主要的 ndk pthreads:
除此之外,在 java 端,我们使用 AdWhirl,它通过自己的 ScheduledExecutorService
生成自己的线程,但我们已经包装了对“schedule”、“submit”、“post”的每个调用, "start"等使用 try-catch block 来捕获 RejectedExecutionException
。然而,可怕的 RejectedExecutionException
仍然出现在我们提交的每个新版本上。
Android Market 的堆栈跟踪几乎没有给我留下任何线索,我们的 QA 部门也发现很难查明问题,因为它在测试期间几乎没有发生(只有我们的用户报告了崩溃)。它只影响我们的一小部分用户,但每周仍有超过 7,000 次崩溃(与大量安装基数相比,这是一小部分)
java.util.concurrent.RejectedExecutionException
at java.util.concurrent.ThreadPoolExecutor$AbortPolicy.rejectedExecution(ThreadPoolExecutor.java:1876)
at java.util.concurrent.ThreadPoolExecutor.reject(ThreadPoolExecutor.java:774)
at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1295)
at android.os.AsyncTask.execute(AsyncTask.java:394)
at c.onProgressUpdate(Unknown Source)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:432)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4632)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
at dalvik.system.NativeStart.main(Native Method)
java.util.concurrent.RejectedExecutionException: pool=128/128, queue=10/10
at java.util.concurrent.ThreadPoolExecutor$AbortPolicy.rejectedExecution(ThreadPoolExecutor.java:1961)
at java.util.concurrent.ThreadPoolExecutor.reject(ThreadPoolExecutor.java:794)
at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1315)
at android.os.AsyncTask.execute(AsyncTask.java:394)
at c.onProgressUpdate(Unknown Source)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:432)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:3691)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
at dalvik.system.NativeStart.main(Native Method)
java.util.concurrent.RejectedExecutionException
at java.util.concurrent.ThreadPoolExecutor$AbortPolicy.rejectedExecution(ThreadPoolExecutor.java:1876)
at java.util.concurrent.ThreadPoolExecutor.reject(ThreadPoolExecutor.java:774)
at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1295)
at android.os.AsyncTask.execute(AsyncTask.java:394)
at c.onProgressUpdate(Unknown Source)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:432)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
at dalvik.system.NativeStart.main(Native Method)
最佳答案
虽然您当然应该尽量保持效率,但“允许”运行的线程数没有任意限制,这完全取决于您如何构建代码。
ThreadPoolExecutor
类非常有据可查,是您看到的问题的根源。我会recommend reading through it , 看看
首先我猜你是用 Ant 构建的,并且没有在你的 javac 节点上使用这些参数:
<javac debug="true" debuglevel="lines,vars,source" />
无论是那个还是您显然使用的混淆器都是堆栈跟踪中通常最重要的部分只是简单地输出的原因:
c.onProgressUpdate(Unknown Source)
这是 ThreadPoolExecutor.AbortPolicy 的当前 ICS 4.0.4 源代码,您可以看到它基本上是一个总能抛出异常的包罗万象:
/**
* A handler for rejected tasks that throws a
* {@code RejectedExecutionException}.
*/
public static class AbortPolicy implements RejectedExecutionHandler {
/**
* Creates an {@code AbortPolicy}.
*/
public AbortPolicy() { }
/**
* Always throws RejectedExecutionException.
*
* @param r the runnable task requested to be executed
* @param e the executor attempting to execute this task
* @throws RejectedExecutionException always.
*/
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
throw new RejectedExecutionException("Task " + r.toString() +
" rejected from " +
e.toString());
}
}
此外,您会发现在 ThreadPoolExecutor 顶部声明的 defaultHandler:
private static final RejectedExecutionHandler defaultHandler = new AbortPolicy();
最后,如果您查看 ThreadPoolExecutor 的默认构造函数:
public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory) {
this(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue,
threadFactory, defaultHandler);
}
你会看到它使用它的 AbortPolicy
类来实例化自己,这是它的默认 RejectedExecutionHandler
。
ThreadPoolExecutor
还包括其他几个您可以设置为默认的 RejectedExecutionHandler
子类,例如:
/**
* A handler for rejected tasks that silently discards the
* rejected task.
*/
public static class DiscardPolicy implements RejectedExecutionHandler {
/**
* Creates a {@code DiscardPolicy}.
*/
public DiscardPolicy() { }
/**
* Does nothing, which has the effect of discarding task r.
*
* @param r the runnable task requested to be executed
* @param e the executor attempting to execute this task
*/
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
}
}
其他 3 个 ThreadPoolExecutor
构造函数包含一个处理程序选项,因此您可以使用不同的处理程序创建它的实例,或者创建自己的子类,类似于:
package com.justinbuser;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.Executors;
import java.util.concurrent.RejectedExecutionException;
import java.util.concurrent.RejectedExecutionHandler;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class NoThrowThreadPool extends ThreadPoolExecutor {
private static final RejectedExecutionHandler defaultHandler = new AdoptPolicy();
public NoThrowThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue) {
super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, Executors.defaultThreadFactory(), defaultHandler);
setRejectedExecutionHandler(defaultHandler);
}
public NoThrowThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory) {
super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, threadFactory, defaultHandler);
}
public NoThrowThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue,
RejectedExecutionHandler handler) {
super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, Executors.defaultThreadFactory(), defaultHandler);
}
public NoThrowThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory, RejectedExecutionHandler handler) {
super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, threadFactory, defaultHandler);
}
public static class AdoptPolicy extends ThreadPoolExecutor.AbortPolicy {
@Override
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
new RejectedExecutionException("Task " + r.toString() + " rejected from " + e.toString()).printStackTrace();
}
}
}
关于android - 将任务提交到线程池会产生 RejectedExecutionException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7788672/
在我们的一项服务中,有人添加了这样(简化)的一段代码: public class DeleteMe { public static void main(String[] args) {
下面是我的方法,其中我有单线程执行器在 run 方法中执行一些任务。 private void trigger(final Packet packet) { // this line is
是什么导致了此 RejectedExecutionException? [Running, pool size = 40, active threads = 3, queued tasks = 20,
为什么当来自线程池的线程之一抛出 RejectedExecutionException 时主线程没有停止?我在这里做错了吗?线程池中的第三个线程抛出 RejectedExecutionExceptio
除了先前在 Executor 上调用的 shutdown() 之外,是否还有其他原因导致 RejectedExecutionException 被抛出(我使用的是 singleThreadExecut
谁能给我提供一个获得 RejectedExecutionException 的例子可能是一个现实生活中的例子。提前致谢。 最佳答案 Anybody able to provide me with an
间歇性头痛需要帮助。代码调用 com.google.api.client.http.HttpRequest#executeAsync() 基本上具有以下逻辑, @Beta public Fut
我正在开发一款在 Android NDK 中运行大部分原生代码的社交游戏。游戏有 3 个主要的 ndk pthreads: 一个游戏线程 服务器通信线程 主渲染线程(通过 Renderer.onRen
我在我的 tomcat 服务器 (+liferay) 上遇到此异常 java.util.concurrent.RejectedExecutionException 我的课是这样的: public cl
我想实现以下行为: 从文件中读取 n 个事件 在线程中处理它们 如果仍有任何事件,请返回步骤 1 我编写了以下应用程序来测试解决方案,但它在随机时刻失败,例如。 java.lang.IllegalSt
我正在使用 AsyncTask 从远程服务器获取大量缩略图并在 GridView 中显示它们。问题是,我的 GridView 一次显示 20 个缩略图,因此创建 20 个 AsyncTasks 并启动
我正在用 java 编写一个多线程程序。我写过这样的东西 exec.execute(p) // where p is a runnable task working on an array prin
我正在从远程服务器获取大量缩略图,并使用 AsyncTask 在 GridView 中显示它们。问题是,我的 GridView 一次显示 20 个缩略图,因此创建 20 个 AsyncTask 并启动
我有这个客户: OkHttpClient okHttpClient = new OkHttpClient.Builder() .pingInterval(Duration.of
我正在尝试将行批量放入 HBase(0.90.0)中,大小约为 1000(行)我有多个生产者线程将数据写入队列,还有一个消费者线程每几分钟唤醒一次,并写入所有内容在队列中作为批处理到 HBase。但是
我希望atomicInteger的值为100,然后程序终止 public static void main(String[] args) throws InterruptedException {
我创建调度程序来测试处理 RejectedExecutionException: @Component public class TestScheduler { private final T
我正在尝试实现生产者-消费者模式,并且我希望能够阻止消费者。到目前为止我写道: import java.util.concurrent.BlockingQueue; import java.util.
我的代码基本上遵循官方教程,主要目的是收集一个订阅(Constants.UNFINISHEDSUBID)中的所有消息并在另一个订阅上重新发布它们。但目前我面临着一个我无法解决的问题。在我的实现中,调用
这是一个例子: // max 1 pending task in queue val queue = LinkedBlockingQueue(1) // max 1 thread / 1 active
我是一名优秀的程序员,十分优秀!