Android子线程真的不能刷新UI吗?(一)复现异常

  • onCreate()中更新UI,没有抛出异常哦,代码如下。
public class MainActivity extends AppCompatActivity {
    TextView tv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv = findViewById(R.id.tv);
        new Thread(new Runnable() {
            @Override
            public void run() {
                tv.setText("zhangjin");
            }
        }).start();
    }
}
  • 查阅资料,onCreate()执行时,ViewRootImpl还没有创建。那我们在onResume()中执行,总可以了吧?还是没有抛出异常,代码如下。
public class MainActivity extends AppCompatActivity {
    TextView tv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv = findViewById(R.id.tv);
    }

    @Override
    protected void onResume() {
        super.onResume();
        new Thread(new Runnable() {
            @Override
            public void run() {
                tv.setText("zhangjin");
            }
        }).start();
    }
}
public class MainActivity extends AppCompatActivity {
    TextView tv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv = findViewById(R.id.tv);
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                tv.setText("zhangjin");
            }
        }).start();
    }
}

终于出现了久违的bug:
在这里插入图片描述
文字版:

24698-24800/com.zj.androidthreaddemo E/AndroidRuntime: FATAL EXCEPTION: Thread-3
    Process: com.zj.androidthreaddemo, PID: 24698
    android.view.ViewRootImpl$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
        at android.view.ViewRootImpl.checkThread(ViewRootImpl.java:8632)
        at android.view.ViewRootImpl.requestLayout(ViewRootImpl.java:1380)
        at android.view.View.requestLayout(View.java:23377)
        at android.view.View.requestLayout(View.java:23377)
        at android.view.View.requestLayout(View.java:23377)
        at android.view.View.requestLayout(View.java:23377)
        at android.view.View.requestLayout(View.java:23377)
        at android.view.View.requestLayout(View.java:23377)
        at androidx.constraintlayout.widget.ConstraintLayout.requestLayout(ConstraintLayout.java:3239)
        at android.view.View.requestLayout(View.java:23377)
        at android.widget.TextView.checkForRelayout(TextView.java:9221)
        at android.widget.TextView.setText(TextView.java:5935)
        at android.widget.TextView.setText(TextView.java:5776)
        at android.widget.TextView.setText(TextView.java:5733)
        at com.zj.androidthreaddemo.MainActivity$1.run(MainActivity.java:23)
        at java.lang.Thread.run(Thread.java:784)
  • 后续分析这个异常是怎么抛出的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值