子线程常见异常

android.view.ViewRootImpl$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
谁创建的view谁才可以修改view里面的内容

android系统约定了一个规则:默认只有主线程才可以修改应用程序的ui,子线程不可以(更新ui),否则抛出异常

>展示图片、吐司


子线程更新ui的步骤
1. 创建一个消息处理器Handler(一定要在主线程new出来)
private Handler handler = new Handler() {};
2. 在子线程利用handler发送消息给主线程的消息队列
handler.sendMessage(msg);
3. 在主线程的消息处理器里面,处理这个消息
public void handleMessage(Message msg) {}
4. 特殊情况 传递数据
Message.obj 携带数据


public class MainActivity extends Activity {

	private TextView tv;
	/**
	 * 1.创建一个消息处理器,运行在主线程里面.
	 */
	private Handler handler = new Handler() {
		// 3.loop调用的用来处理消息的方法,运行在主线程
		public void handleMessage(Message msg) {
			int i = (Integer) msg.obj;
			tv.setText("当前进度:"+i+"%");
		};
	};

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		tv = (TextView) findViewById(R.id.tv);
	}

	public void click(View view) {
		new Thread() {
			public void run() {
				// tv.setText("hahahah"); 子线程不可以直接更新ui
				// 2.子线程 通过消息处理器 把一个消息发送到消息队列(message queue),消息队列中有looper轮询,处理消息
				for (int i = 0; i < 100; i++) {
					Message msg = new Message();
					//消息携带的数据
					msg.obj = i;
					handler.sendMessage(msg);
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
			};
		}.start();
	}
}


### Java 主线程和子线程中的异常处理行为 在Java编程环境中,当主线程(main thread)或任何子线程(child threads)抛出未捕获的异常时,默认情况下JVM会打印堆栈跟踪(stack trace),随后对于主线程可能会终止程序执行;而对于子线程,则通常仅该特定线程结束而不会影响到整个应用程序继续运行[^1]。 为了更好地管理这些情况,在设计阶段就应该考虑如何优雅地处理可能出现的各种错误条件。一种常见做法是在启动新线程的地方设置`Thread.UncaughtExceptionHandler`来监听并响应那些未能被内部逻辑捕捉下来的异常事件: ```java public class ThreadExceptionExample { public static void main(String[] args) { // 创建一个新的线程实例 Thread t = new Thread(() -> { throw new RuntimeException("Uncaught exception in thread"); }); // 设置未捕获异常处理器 t.setUncaughtExceptionHandler((thread, throwable) -> System.out.println( "Caught Exception from " + thread.getName() + ": " + throwable.getMessage())); // 启动线程 t.start(); try { t.join(); // 等待t线程完成 } catch (InterruptedException e) { Thread.currentThread().interrupt(); // 恢复中断状态 } } } ``` 此外,如果希望自定义异常类以便更精确地区分不同类型的失败情形,并允许调用者针对具体问题采取适当措施的话,可以遵循建议创建专门用于描述特殊情况下的异常类型[^2]。 通过这种方式不仅可以提高代码可读性和维护性,同时也使得调试过程变得更加简单明了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值