Java 中怎么利用SynDemo对象解决继承问题,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
Java SynDemo对象刚一出现的时候有很多程序员都很头痛,其实这是完全没有必要的,下面我们就来详细的学习下有关的相关问题。我们发现,对于Java SynDemo对象,只有synMethord1运行了,而synMethord2却没有运行。
这是应为在方法级别的synchronized声明将lock这个类对象的当前实例。所以在synMethord1运行结束unlock之前,当前Java SynDemo对象实例是无法运行synMethord2的。这种方法级别的synchronized声明和以下的做法是等同的:
package com.cnblogs.gpcuster;/** * * @author Aaron.Guo * */
public class SynDemo { public void synMethord1() {
synchronized (this) { while (true) { try { Thread.sleep(1000);
System.out.println("synMethord1"); } catch (InterruptedException
e) { // TODO Auto-generated catch blocke.printStackTrace();
}
}
}
}
public void synMethord2() { synchronized (this) { while (true)
{ try { Thread.sleep(1000); System.out.println("synMethord2"); }
catch (InterruptedException e) { // TODO Auto-generated catch blocke.printStackTrace();
}
}
}
}
}
运行程序,结果与上次相同。
如果我们希望分别同步2个方法该如何处理?可以参考这个实现:
package com.cnblogs.gpcuster;/** * * @author Aaron.Guo * */
public class SynDemo { private Object flag1 = new Object();
private Object flag2 = new Object(); public void synMethord1()
{ synchronized (flag1) { while (true) { try { Thread.sleep(1000);
System.out.println("synMethord1"); } catch (Interrupted
Exception e) { // TODO Auto-generated catch blocke.printStackTrace();
}
}
}
}
public void synMethord2() { synchronized (flag2) { while (true)
{ try { Thread.sleep(1000); System.out.println("synMethord2"); }
catch (InterruptedException e) { // TODO Auto-generated catch blocke.printStackTrace();
}
}
}
}
}
运行程序,结果如我们预期:
main synMethord2 synMethord2 main synMethord1 main synMethord1 synMethord2
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。