本文介绍: 面试题为:线程t2调用doother方式是否需要线程t1释放对象myClass的对象锁之后才能执行;答案:不需要,因为doother方法根本就没有使用关键字synchronized修饰,也就是说我们调用这个方法根本就不需要对象锁。具体实现请看下面的代码。package sybchro;public class O1 { public static void main(String[] args) { MyClass myClass = new MyClass();
线程t2调用doother方式是否需要线程t1释放对象myClass的对象锁之后才能执行;
答案:不需要,因为doother方法根本就没有使用关键字synchronized修饰,也就是说我们调用这个方法根本就不需要对象锁。
具体实现请看下面的代码。
仅仅对dosome加锁 doother不做任何处理
package sybchro;
public class O1 {
public static void main(String[] args) {
MyClass myClass = new MyClass();
MyThread myThread1= new MyThread(myClass);
MyThread myThread2=new MyThread(myClass);
//线程myThread1和myThread2拥有的是同意Myclass引用;
myThread1.setName("t1");
myThread2.setName("t2");
myThread1.start();
try {
Thread.sleep(1000);//此处的Thread指的是Main线程
//此处休眠主要是为了让myThread1先执行。
} catch (InterruptedException e) {
e.printStackTrace();
}
myThread2.start();
}
}
class MyThread extends Thread{
MyClass myClass;
public MyThread(MyClass myClass) {
this.myClass = myClass;
}
@Override
public void run() {
if(Thread.currentThread().getName().equals("t1")){
this.myClass.dosome();
}
if(Thread.currentThread().getName().equals("t2")){
this.myClass.doother();
}
}
}
class MyClass{
public synchronized void dosome(){
System.out.println("dobebin");
try {
Thread.sleep(1000*10);
//此处睡眠主要是为了验证myThread2调用doother方法并不受到对象锁的影响;
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("doover");
}
public void doother(){
//myThread2调用doother方法之所以不会受到对象锁的影响是因为doother方法根本就没用使用关键字
//synchronized修饰。
System.out.println("dobebin");
System.out.println("doover");
}
}
dosome 和 doother方法同时加锁
package sybchro;
public class O1 {
public static void main(String[] args) {
MyClass myClass = new MyClass();
MyThread myThread1= new MyThread(myClass);
MyThread myThread2=new MyThread(myClass);
//线程myThread1和myThread2拥有的是同意Myclass引用;
myThread1.setName("t1");
myThread2.setName("t2");
myThread1.start();
try {
Thread.sleep(1000);//此处的Thread指的是Main线程
//此处休眠主要是为了让myThread1先执行。
} catch (InterruptedException e) {
e.printStackTrace();
}
myThread2.start();
}
}
class MyThread extends Thread{
MyClass myClass;
public MyThread(MyClass myClass) {
this.myClass = myClass;
}
@Override
public void run() {
if(Thread.currentThread().getName().equals("t1")){
this.myClass.dosome();
}
if(Thread.currentThread().getName().equals("t2")){
this.myClass.doother();
}
}
}
class MyClass{
public synchronized void dosome(){
System.out.println("dobebin");
try {
Thread.sleep(1000*10);
//此处睡眠主要是为了验证myThread2调用doother方法并不受到对象锁的影响;
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("doover");
}
public synchronized void doother(){
//myThread2调用doother方法之所以不会受到对象锁的影响是因为doother方法根本就没用使用关键字
//synchronized修饰。
System.out.println("dobebin");
System.out.println("doover");
}
}
创建了两个对象一个线程拥有一个对象,此时线程之间不会再产生争夺对象锁的现象,也就是说线程与线程之间变成了异步编程,线程与线程之间不会再有任何的关系。一个线程也不会去等待另一个线程释放掉对象锁了。
package sybchro;
public class O1 {
public static void main(String[] args) {
MyClass myClass1 = new MyClass();
MyClass myClass2 = new MyClass();
MyThread myThread1= new MyThread(myClass1);//一个线程一个对象
MyThread myThread2=new MyThread(myClass2);
//线程myThread1和myThread2拥有的是同意Myclass引用;
myThread1.setName("t1");
myThread2.setName("t2");
myThread1.start();
try {
Thread.sleep(1000);//此处的Thread指的是Main线程
//此处休眠主要是为了让myThread1先执行。
} catch (InterruptedException e) {
e.printStackTrace();
}
myThread2.start();
}
}
class MyThread extends Thread{
MyClass myClass;
public MyThread(MyClass myClass) {
this.myClass = myClass;
}
@Override
public void run() {
if(Thread.currentThread().getName().equals("t1")){
this.myClass.dosome();
}
if(Thread.currentThread().getName().equals("t2")){
this.myClass.doother();
}
}
}
class MyClass{
public synchronized void dosome(){
System.out.println("dobebin");
try {
Thread.sleep(1000*10);
//此处睡眠主要是为了验证myThread2调用doother方法并不受到对象锁的影响;
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("doover");
}
public synchronized void doother(){
//myThread2调用doother方法之所以不会受到对象锁的影响是因为doother方法根本就没用使用关键字
//synchronized修饰。
System.out.println("dobebin");
System.out.println("doover");
}
}
总结:
我们加锁的目的主要是为了在对共享数据操作时保证数据的安全性问题,如果我们操作的不是共性的数据是不需要加锁的,加锁会使得程序的运行效率变慢(加锁也叫做同步编程不加锁叫做异步编程)
只有多个线程拥有一个共享的对象时,我们才能为这个对象加锁,只有拿到这个对象锁的人释放掉这个对象的对象锁其他的线程才有机会去争夺这个对象的对象锁。
synchronized(“这里放的就是那个共享的对象,不能为空,”)
原文地址:https://blog.csdn.net/qq_45858803/article/details/122070963
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_25554.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。