写一个程序,模拟8个窗口共同卖50张票。
这个问题涉及线程应用时,怎么使用锁,我用的是synchronized的方法来锁的。
public class Ticket extends Thread{
public Ticket(String name) {
super(name);
}
private static Object obj = new Object();
public static int tickets = 50;
public void run() {
while(tickets>0) {
synchronized (obj) {
if(tickets >0) {
try {
sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
tickets--;
System.out.println(currentThread().getName()+"卖了第"+(50-tickets)+"张票");
}
}
}
}
public static void main(String[] args) {
Ticket t1 = new Ticket("窗口1");
Ticket t2 = new Ticket("窗口2");
Ticket t3 = new Ticket("窗口3");
Ticket t4 = new Ticket("窗口4");
Ticket t5 = new Ticket("窗口5");
Ticket t6 = new Ticket("窗口6");
Ticket t7 = new Ticket("窗口7");
Ticket t8 = new Ticket("窗口8");
t1.start();
t2.start();
t3.start();
t4.start();
t5.start();
t6.start();
t7.start();
t8.start();
}
}
这里的private static Object obj = new Object(); obj 必须写成static的,否则锁不住。因为如果不是静态的,每次实例化的时候都会调用一次,锁也就没有了意义。我之前试过把synchronized的参数写成this的,不好使,因为写this锁的是当前的对象。
用我个人理解的通俗的话来讲的话,synchronized方法必须要把对象锁住,当你新创建对象的时候如果参数没有用static的,那相当于每次进去的对象都不相同,也就和锁没有关系了。注意:锁是用来锁对象的,代码是不能锁的,这是很多人的误区,锁代码这个词是错误的。
本文通过一个具体的Java程序示例,模拟了8个窗口同时售卖50张票的过程,详细解释了如何使用synchronized关键字来确保线程间的同步操作,并强调了在多线程环境中正确使用锁的重要性。
1827

被折叠的 条评论
为什么被折叠?



