synchronized用于Java线程同步,保证同一时刻仅一个线程执行代码。1. 修饰实例方法时锁当前对象(this),多线程访问同一对象该方法需串行;2. 修饰静态方法时锁类的Class对象(如Counter.class),不同实例共用锁;3. synchronized代码块可指定锁对象(如lock、this、类名),粒度更细,性能更优;4. 底层基于监视器(Monitor)机制,每个对象关联一个,线程需获取锁才能进入同步区域,执行完释放,Java 6起优化为偏向锁、轻量级锁、重量级锁状态,提升低竞争性能。掌握这三种用法可解决多数线程安全问题,虽有ReentrantLock等更灵活工具,synchronized仍是基础且常用手段,使用时需注意锁对象是否正确及互斥范围。

在Java中,synchronized关键字用于控制多线程对共享资源的访问,保证同一时刻只有一个线程可以执行某个代码块或方法。它是实现线程同步的一种基本机制,能有效防止数据竞争和保证内存可见性。
当synchronized修饰一个实例方法时,锁的是当前对象实例(即this)。多个线程访问同一个对象的该方法时,会串行执行。
示例:
public class Counter {
private int count = 0;
public synchronized void increment() {
count++;
}
public int getCount() {
return count;
}
}
上面代码中,increment()方法被synchronized修饰,不同线程调用同一个Counter实例的increment()时,会互斥执行,避免count++出现并发问题。
静态方法属于类而非实例,因此synchronized修饰静态方法时,锁的是该类的Class对象(如Counter.class)。所有该类的实例共用这一把锁。
立即学习“Java免费学习笔记(深入)”;
示例:
public class Counter {
private static int total = 0;
public static synchronized void addTotal() {
total++;
}
}
多个线程即使操作不同的Counter实例,调用addTotal()也会同步执行,因为锁的是类的Class对象。
有时不需要锁住整个方法,只希望保护关键代码段。这时可以用synchronized代码块,指定具体的锁对象,粒度更细,性能更好。
示例:
public class Counter {
private int count = 0;
private final Object lock = new Object();
public void increment() {
synchronized (lock) {
count++;
}
}
}
这里使用一个私有对象lock作为锁,其他线程必须获取lock的监视器才能进入代码块。这种方式比锁整个方法更灵活,也避免了锁this可能带来的意外干扰。
也可以使用this或类名作为锁对象:
synchronized基于JVM内部的监视器(Monitor)机制实现。每个Java对象都关联一个监视器。当线程进入synchronized代码块时,需先获取对象的监视器锁,执行完后自动释放。如果锁已被占用,线程会阻塞等待。
从Java 6开始,synchronized经过优化,支持偏向锁、轻量级锁、重量级锁等状态,提升了性能,在低竞争场景下开销很小。
基本上就这些。掌握synchronized的三种用法——修饰实例方法、静态方法和代码块,就能应对大多数线程安全问题。虽然现在有ReentrantLock等更灵活的工具,但synchronized仍是基础且常用的同步手段。不复杂但容易忽略细节,比如锁的对象是否正确、是否真的互斥等,写并发代码时要特别注意。
以上就是Java语法基础中synchronized关键字的用法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号