E/AndroidRuntime: FATAL EXCEPTION: Thread-3 Process: com.example.zfang.course2_1, PID: 31755 android.view.ViewRootImpl$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views. at android.view.ViewRootImpl.checkThread(ViewRootImpl.java:6855) at android.view.ViewRootImpl.invalidateChildInParent(ViewRootImpl.java:1075) at android.view.ViewGroup.invalidateChild(ViewGroup.java:5242) at android.view.View.invalidateInternal(View.java:13574) at android.view.View.invalidate(View.java:13538) at android.view.View.invalidate(View.java:13522) at android.widget.TextView.checkForRelayout(TextView.java:7354) at android.widget.TextView.setText(TextView.java:4479) at android.widget.TextView.setText(TextView.java:4336) at android.widget.TextView.setText(TextView.java:4311) at com.example.zfang.course2_1.fragment.MineFragment$1$1.showProgress(MineFragment.java:89) at com.example.zfang.course2_1.service.DownloadService$1.run(DownloadService.java:86) at java.lang.Thread.run(Thread.java:761) D/EGL_emulation: eglMakeCurrent: 0xa9d850c0: ver 2 0 (tinfo 0xa9d831d0) D/OpenGLRenderer: endAllActiveAnimators on 0x8c994500 (RippleDrawable) with handle 0xa9dff550 W/System.err: java.net.SocketTimeoutException: connect timed out W/System.err: at java.net.PlainSocketImpl.socketConnect(Native Method) W/System.err: at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:334) W/System.err: at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:196) W/System.err: at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:178) W/System.err: at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:356) W/System.err: at java.net.Socket.connect(Socket.java:586) W/System.err: at com.android.okhttp.internal.Platform.connectSocket(Platform.java:113) W/System.err:
时间: 2024-03-31 17:34:54 浏览: 20
根据你提供的信息,这是一个 Android 应用程序的异常信息。异常类型为 android.view.ViewRootImpl$CalledFromWrongThreadException,表示只有创建视图层次结构的原始线程才能触摸其视图。这个异常可能是由于在不同的线程中更新 UI 元素引起的。另一个异常为 java.net.SocketTimeoutException,表示连接超时。这个异常可能是由于网络请求超时或网络连接不稳定引起的。
相关问题
E/AndroidRuntime: FATAL EXCEPTION: Thread-2 Process: com.example.petgrowing, PID: 19678
这个错误通常是由于在非 UI 线程上访问 UI 元素而引发的。在 Android 中,UI 元素只能在主线程上更新,因此如果在非 UI 线程上更新 UI 元素,就会抛出这个异常。
在这个问题的代码中,使用了一个新线程来进行网络请求,然后在该线程中更新了 UI 线程上的 TextView。这样会导致在非 UI 线程上更新 UI 元素,从而引发了该异常。
为了解决这个问题,可以使用 `runOnUiThread` 方法来在 UI 线程上更新 TextView 的内容。具体来说,可以将获取到的数据作为参数传递给 `runOnUiThread` 方法,并在该方法中更新 TextView 的内容,如下所示:
```
new Thread(() -> {
try {
// 进行网络请求,获取数据
Document doc = Jsoup.connect("https://chl.cn/?jinri").get();
Elements tables = doc.getElementsByTag("table");
Element table1 = tables.first();
Elements tds = table1.getElementsByTag("td");
Element td1 = tds.first();
Element td2 = tds.get(4);
final String retStr = ("1:" + td1.text() + " 2:" + td2.text());
// 在 UI 线程上更新 TextView 的内容
runOnUiThread(() -> {
show.setText(retStr);
});
} catch (IOException e) {
e.printStackTrace();
}
}).start();
```
这样就可以在 UI 线程上更新 TextView 的内容,从而避免了在非 UI 线程上访问 UI 元素的问题。
E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.meiquan, PID: 6591如何解决
要解决这个问题,需要先查看错误详细信息,找到错误的原因,然后采取相应的措施。一般情况下,解决方法可能包括以下几个方面:
1. 查看错误详细信息,找到错误的原因。根据错误信息中的类、方法、行号等信息,可以大致确定错误的位置和原因。
2. 修改代码,修复错误。根据错误的原因,修改代码中可能存在的错误。例如,如果是空指针异常,可以检查代码中是否有可能为空的对象未进行判断,加上必要的判断语句即可。
3. 使用调试工具进行调试。使用 Android Studio 等开发工具自带的调试功能,可以在代码执行过程中逐行调试,找到问题所在。
4. 删除并重建应用程序。如果错误无法通过以上方法解决,可以尝试删除应用程序并重新构建。有时候,这个问题可能是由于应用程序的构建过程中出现的错误导致的。
需要注意的是,解决这个问题可能需要一定的技术水平和经验。如果您不确定如何解决,建议向有经验的开发人员寻求帮助。