esi*_*ver 14 android window-managers android-activity
伙计们 - 谁能解释这个堆栈?请注意,我的代码无处可去.如果你谷歌中的任何一个例外,遇到此问题的每个人都试图在活动终止后创建对话框,这似乎不是这里的情况.这只是一个简单的活动简历.我经常看到该领域的客户报告此异常,并且如果可能的话想要纠正它.
android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@405177d8 is not valid; is your activity running?
at android.view.ViewRoot.setView(ViewRoot.java:527)
at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:177)
at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
at android.view.Window$LocalWindowManager.addView(Window.java:424)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2268)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1721)
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:2955)
at android.app.ActivityThread.access$1600(ActivityThread.java:124)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:972)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:3806)
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:839)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
at dalvik.system.NativeStart.main(Native Method)
Run Code Online (Sandbox Code Playgroud)
更新:
以下是我能够远程检索此堆栈的方法.首先,我在我的活动的onCreate顶部添加了一个uncaughtExceptionHandler:
try {
File crashLogDirectory = new File(Environment.getExternalStorageDirectory().getCanonicalPath() + Constants.CrashLogDirectory);
crashLogDirectory.mkdirs();
Thread.setDefaultUncaughtExceptionHandler(new RemoteUploadExceptionHandler(this, crashLogDirectory.getCanonicalPath()));
} catch (Exception e) {
if (MyActivity.WARN) Log.e(MyActivity.TAG, "Exception setting up exception handler! " + e.toString());
}
Run Code Online (Sandbox Code Playgroud)
在我的RemoteUploadExceptionHandler类中,我有以下代码:
public void uncaughtException(Thread t, Throwable e) {
String timestamp = Calendar.getInstance().getTime().toGMTString();
String filename = timestamp + ".stacktrace";
final Writer result = new StringWriter();
final PrintWriter printWriter = new PrintWriter(result);
e.printStackTrace(printWriter);
String stacktrace = result.toString();
printWriter.close();
sendToServer(stacktrace, filename);
defaultUEH.uncaughtException(t, e);
}
private void sendToServer(String stacktrace, String filename) {
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(Constants.RemoteUploadUrl);
List<NameValuePair> nvps = new ArrayList<NameValuePair>();
nvps.add(new BasicNameValuePair("filename", filename));
nvps.add(new BasicNameValuePair("stacktrace", stacktrace));
nvps.add(new BasicNameValuePair("platform_version", platformVersion));
nvps.add(new BasicNameValuePair("device_id", deviceId));
nvps.add(new BasicNameValuePair("build_device", Build.DEVICE));
nvps.add(new BasicNameValuePair("build_brand", Build.BRAND));
nvps.add(new BasicNameValuePair("build_product", Build.PRODUCT));
nvps.add(new BasicNameValuePair("build_manufacturer", Build.MANUFACTURER));
nvps.add(new BasicNameValuePair("build_model", Build.MODEL));
nvps.add(new BasicNameValuePair("build_version", String.format("%d",Build.VERSION.SDK_INT)));
try {
httpPost.setEntity(
new UrlEncodedFormEntity(nvps, HTTP.UTF_8));
httpClient.execute(httpPost);
} catch (IOException e) {
e.printStackTrace();
}
}
Run Code Online (Sandbox Code Playgroud)
这是我每小时向我发送许多堆栈的代码,就像我上面显示的那样.
此外,如果您通过谷歌代码搜索查看ActivityThread代码,您可以在调用addView之前看到此检查:
if (r.window == null && !a.mFinished && willBeVisible) {
Run Code Online (Sandbox Code Playgroud)
因此,活动尚未完成,因此它应该仍然有效.
此外,行号似乎与您在谷歌源代码中看到的不一致.签出 2.3.3源代码中的ActivityThread.java文件.第2268行位于私有方法createThumbnailBitmap中.崩溃客户端上传的Build版本为10,表示SDK_INT为10,因此为2.3.3.
当Application.onCreate()中运行耗时的操作时,我可以不断重现此问题.在这种情况下,如果我从启动器按下应用程序图标,但然后快速按下主页按钮并运行其他应用程序,我将最终得到此崩溃.
我的应用程序中发生此崩溃的更改是android:noHistory="true"在AndroidManifest.xml的Activity声明中.
看起来Android处理具有backstack历史记录的活动,并且没有区别于窗口令牌的活动.
有许多关于同一异常的报告。所有的观点都指向了一些使用错误的观点Context。
请参阅下面的示例,并尝试查找您的 Activity 中的哪些位置正在执行类似的操作:
http://groups.google.com/group/android-developers/browse_thread/thread/7a648edddccf6f7d
Android:ProgressDialog.show() 与 getApplicationContext 崩溃
Android 1.6:“android.view.WindowManager$BadTokenException:无法添加窗口——令牌 null 不适用于应用程序”
检查代码setView(...)中的方法ViewRoot.java。它可能会帮助您弄清楚:http://grepcode.com/file/repository.grepcode.com/java/ext/com.google.android/android/2.2_r1.1/android/view/ViewRoot.java#ViewRoot。 setView%28android.view.View%2Candroid.view.WindowManager.LayoutParams%2Candroid.view.View%29
特别是,这些行:
case WindowManagerImpl.ADD_BAD_SUBWINDOW_TOKEN:
throw new WindowManagerImpl.BadTokenException(
"Unable to add window -- token " + attrs.token
+ " is not valid; is your activity running?");
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4649 次 |
| 最近记录: |