你这个不是死锁,就是flag的判断有问题,每个线程都是自己把自己锁住了,当flag为true时,看以下两段代码:
成都创新互联公司主要从事网站制作、成都网站制作、网页设计、企业做网站、公司建网站等业务。立足成都服务河北,10余年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575
public synchronized void set(String name) {
if (flag)
try {
wait();
public synchronized void out() {
if (flag)
try {
wait();
两个线程都在wait,当然卡住不动了。
看你的代码,把set那段改成这样应该就好了:
public synchronized void set(String name) {
if (!flag)
try {
wait();
您好,提问者:
1、重要信息进行加密操作。
2、地址栏尽量采用post提交方式。
3、如果涉及多线程的话,可以使用Synchronized锁。
下面例子:
public class Main{
public static void main(String[] args){
new Thread(new Suo()).start();
new Thread(new Suo()).start();
//开启两个线程,加锁之后数据就不会出错
}
}
class Suo implements Runnable{
private static int num = 100;
public synchronized void run(){
while(true){
if(num==0)
break;
else
System.out.println(num--);
}
}
}
public Object getObject(String key,Object o) {
synchronized (map) {
if(map.get(key)==null) {
map.put(key,o)
}else {
return map.get(key);
}}// 格式没法弄,自己弄一下
}
// demol0326 的回答意思使用MyTest的实例来加锁,但是map是static的,无法锁住
// MyTest的多个实例在多个线程中的请求
//禾木双子 :如果A线程在getObject方法的第二行停止,此时B线程进入getObject后执行部分代码, 此时B线程停止,A线程启动,他不会执行'多线程处理', 仍然有线程线程安全问题,(想像一下更多的线程进入该方法的情况,num甚至会得到负值)
对象是一个锁标志。按照先到先得的原则,如果有多个线程都会执行代码,并使用同一个对象作为锁,
synchronize(对象){ .... }
那么,先执行这段代码的那个线程,将会获得这个对象锁,而当这个线程执行这段代码的时候,其他线程也是使用这个对象作为锁的,就不能执行这段代码,知道最初得到这个锁的线程运行完这段代码,然后再把锁分配给下一个线程执行。
分享文章:java锁的代码 java 各种锁
链接地址:https://www.cdcxhl.com/article16/ddjodgg.html
成都网站建设公司_创新互联,为您提供商城网站、做网站、企业网站制作、微信小程序、企业建站、虚拟主机
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联