下面的代码每隔一段时间给我一个android.content.ActivityNotFoundException
。
我在我的一些活动中使用相同的代码来引导用户到网站上的其他信息,它似乎在大多数时候都没有问题。
private void openWebPage(String url_to_view) {
Intent open_web_page_intent = new Intent();
if (url_to_view != null && !url_to_view.equals("")) {
open_web_page_intent.setAction(Intent.ACTION_VIEW);
try {
open_web_page_intent.setData(Uri.parse(url_to_view));
startActivity(open_web_page_intent);
} catch (ParseException e) {
Log.e(LOGTAG, "URI Parse Exception in Open Web Page");
}
}
}
有办法防止这个错误吗?
我无法从堆栈跟踪中找出问题是与调用活动还是与我正在启动的新活动?(下面是完整的堆栈跟踪)
如果问题是新的活动,StartActivity
语句周围的try/catch
是一个很好的保护吗?(崩溃是不常见的,我不能重现我的测试设备或avd)。
还请注意,堆栈跟踪指的是StartActivityForResult
,我在这个实例中没有这样做,我只是正常启动新活动。
android.content.ActivityNotFoundException:
at android.app.Instrumentation.checkStartActivityResult (Instrumentation.java:2071)
at android.app.Instrumentation.execStartActivity (Instrumentation.java:1717)
at android.app.Activity.startActivityForResult (Activity.java:5252)
at androidx.fragment.app.FragmentActivity.startActivityForResult (FragmentActivity.java:6)
at android.app.Activity.startActivityForResult (Activity.java:5203)
at androidx.fragment.app.FragmentActivity.startActivityForResult (FragmentActivity.java:6)
at android.app.Activity.startActivity (Activity.java:5581)
at android.app.Activity.startActivity (Activity.java:5549)
at com.nooriginalthought.amalfi.FirstRun.openWebPage (FirstRun.java:27)
at com.nooriginalthought.amalfi.FirstRun.lambda$initialize$4 (FirstRun.java:1)
at com.nooriginalthought.amalfi.FirstRun.lambda$initialize$4$FirstRun (FirstRun.java:1)
at com.nooriginalthought.amalfi.-$$Lambda$FirstRun$iHROIfEVj1qDNupIO6vj8JGEmlM.onClick (-.java:1)
at android.view.View.performClick (View.java:7869)
at android.widget.TextView.performClick (TextView.java:14958)
at android.view.View.performClickInternal (View.java:7838)
at android.view.View.access$3600 (View.java:886)
at android.view.View$PerformClick.run (View.java:29362)
at android.os.Handler.handleCallback (Handler.java:883)
at android.os.Handler.dispatchMessage (Handler.java:100)
at android.os.Looper.loop (Looper.java:237)
at android.app.ActivityThread.main (ActivityThread.java:8107)
at java.lang.reflect.Method.invoke (Method.java)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:496)
at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1100)
是否有办法防止这种错误?
将任何使用隐式Intent
的startActivity()
或startActivityForResult()
调用包装在try
/catch
块中,在那里捕获ActivityNotFoundException
。请记住,没有要求您的应用程序的用户有访问Web浏览器(例如,儿童与受限制的帐户)。
我无法从堆栈跟踪中找出问题是与调用活动还是与我正在开始的新活动?
来自com.nooriginalthought.amalfi.FirstRun.openWebPage (FirstRun.java:27)
。我们没有完整的文件,不能告诉你是哪一行。
还请注意,堆栈跟踪指的是StartActivityForResult,我在这个实例中没有这样做,我只是正常启动新活动。
您的代码正在调用startActivity()
,正如您在堆栈跟踪的at android.app.Activity.startActivity (Activity.java:5549)
行中看到的那样。最终,在内部调用startActivityForResult()
。