使用interrupt()中断线程 当一个线程运行时,另一个线程可以调用对应的Thread对象的interrupt()方法来中断它,该方法只是在目标线程中设置一个标志,表示它已经被中断,并立即返回。这里需要注意的是,如果只是单纯的调用interrupt()方法,线程并没
public class Thread10 {
public static void main(String[] args) {
Thread10_Entity entity = new Thread10_Entity();
Thread10_1 t10_1 = new Thread10_1(entity);
t10_1.start();
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(entity.get());
}
}
class Thread10_1 extends Thread {
private Thread10_Entity thread10_Entity;
public Thread10_1(Thread10_Entity t10) {
this.thread10_Entity = t10;
}
@Override
public void run() {
thread10_Entity.set("admin", "admin");
}
}
class Thread10_Entity {
private String username = "user";
private String password = "user";
synchronized void set(String username, String password) {
this.username = username;
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
this.password = password;
}
String get() {
return username + " " + password;
}
}
运行结果:admin userExecutor框架简介 在Java 5之后,并发编程引入了一堆新的启动、调度和管理线程的API。Executor框架便是Java 5中引入的,其内部使用了线程池机制,它在java.util.cocurrent 包下,通过该框架来控制线程的启动、执行和关闭,可以简化并发编程的操作。因此,
加上sleep只是为了放大错误,便于观察。
有任何疑问欢迎留言或者加企鹅群(282034885)讨论
那么如何避免脏读呢?上篇文章(java并发编程学习之一段简单代码证明synchronized锁的是对象)中提到过,synchronized锁的是对象,这里就可以用上了。
在get方法上加上synchronized关键字即可,在set没处理完之前,对对象加锁,避免其他线程进行脏读。