同步方法是用synchronized修饰的方法,确保多线程下同一时刻仅一个线程执行。实例同步方法锁当前对象(this),静态同步方法锁Class对象。如Counter类中increment()和getCount()通过同步保证count操作线程安全;MathUtils的静态方法doSomething()则锁定类。注意:同步降低性能,应缩小同步范围;不同对象的实例方法不互斥,静态与实例方法因锁不同也不互阻;异常时JVM自动释放锁。可改用同步代码块synchronized(this){...}细粒度控制,提升效率。合理使用可保障线程安全并避免性能损耗。

Java中的同步方法主要用于解决多线程环境下对共享资源的并发访问问题,确保同一时刻只有一个线程可以执行该方法,从而避免数据不一致或竞态条件。
什么是同步方法
在Java中,使用 synchronized 关键字修饰的方法就是同步方法。当一个线程调用某个对象的同步方法时,它会自动获取该对象的锁(也叫监视器锁),其他线程若想调用该对象的任何同步方法,就必须等待当前线程释放锁。
同步方法分为两种:
- 实例同步方法:synchronized 修饰普通成员方法,锁的是当前实例对象(this)。
- 静态同步方法:synchronized 修饰静态方法,锁的是该类的 Class 对象(如 MyClass.class)。
如何使用同步方法
下面通过一个简单的例子说明同步方法的使用场景:
立即学习“Java免费学习笔记(深入)”;
public class Counter {
private int count = 0;
// 同步方法,保证线程安全
public synchronized void increment() {
count++;
}
public synchronized int getCount() {
return count;
}
}
在这个例子中,increment() 和 getCount() 都是同步方法。多个线程同时调用 increment() 时,只会有一个线程能进入方法执行,其余线程阻塞等待,从而保证 count 自增操作的原子性。
如果是静态方法需要同步:
public class MathUtils {
public static synchronized void doSomething() {
// 静态同步方法,锁的是 MathUtils.class
}
}
同步方法的注意事项
虽然同步方法简单易用,但使用时需要注意以下几点:
- 同步方法会降低程序性能,因为同一时间只能有一个线程执行,应尽量减少同步代码块的范围。
- 不同对象的实例同步方法不会互相阻塞,只有同一个对象的同步方法才会互斥。
- 静态同步方法和实例同步方法之间不会相互阻塞,因为它们使用的锁不同(Class 锁 vs 实例锁)。
- 异常退出时,JVM会自动释放同步方法持有的锁,不会造成死锁。
替代方案:同步代码块
有时候不需要对整个方法进行同步,可以使用同步代码块来提高效率:
public void increment() {
synchronized (this) {
count++;
}
}
这种方式粒度更细,只对关键代码加锁,其他非共享资源的操作可以并发执行。
基本上就这些。合理使用同步方法能有效保证线程安全,但要避免过度同步影响性能。











