/*实现多线程共享处理数据*/
class Demo2
{
public static void main(String[] args) {
/*
这种方式,是每线程处理一个num,而不是多个线程处理一个num
Test t1 = new Test();
Test t2 = new Test();
Test t3 = new Test();
t1.start();
t2.start();
t3.start();
所以:得改用第二种处理多线程方法,继承接口
*/
/*
现在运行结果,就可以看出是共享num了
问题来了,结果里出现了num -1, 多线程处理时越界了。
原因:线程是cpu随即调用的,当一个线程执行到if 代码块里时,被休眠,同时其它进程进来了。这样就造成-1结果
解决办法:synchronized 代码区域加锁
*/
Test t = new Test();
Thread t1 = new Thread(t);
Thread t2 = new Thread(t);
Thread t3 = new Thread(t);
Thread t4 = new Thread(t);
t3.start();
t4.start();
t1.start();
t2.start();
}
}
class Test implements Runnable
{
private int num = 100;
Object obj = new Object();
public void run() {
show();
}
void show() {
while(true) {
// synchronized 关键字声名为代码区域,给这块区域加线程锁,一个线程执行完,下一下线程才能进来。
synchronized(obj) {
if (num > 0) {
try{
Thread.sleep(10);
} catch(InterruptedException e) {
}
System.out.println(Thread.currentThread()+".."+num--);
}
}
}
}
}
java 多线程 加锁
最新推荐文章于 2024-02-22 09:46:47 发布