实例解析 Java 中的 synchronized 关键字与线程安全问题 首先要清楚的是 synchronized 锁住的不是代码而是对象,因此在编写相关的代码块时要留意线程同步安全问题,下面就来以实例解析 Java中的 synchronized 关键字与线程安全问题 首先来回顾一下 synchronized 的基本使用: synchronized 代码块,被修饰的代码成为同步语句块,其作用的范围是调用这个代码块的对象,我们在用 synchronized 关键字的时候,能缩小代码段的范围就尽量缩小,能在代码段上加同步就不要再整个方法上加同步。这叫减小锁的粒度,使代码更大程度的并发。 synchronized 方法,被修饰的方法成为同步方法,其作用范围是整个方法,作用对象是调用这个方法的对象。 synchronized 静态方法,修饰一个 static 静态方法,其作用范围是整个静态方法,作用对象是这个类的全部对象。 synchronized 类,其作用范围是 Synchronized 后面括号括起来的部分 synchronized(className.class),作用的对象是这个类的全部对象。 synchronized() ()中是锁住的对象, synchronized(this)锁住的只是对象本身,同一个类的不同对象调用的 synchronized 方法并不会被锁住,而 synchronized(className.class)实现了全局锁的功能,全部这个类的对象调用这个方法都受到锁的影响,此外()中还可以添加一个具体的对象,实现给具体对象加锁。 synchronized (object) { //在同步代码块中对对象进行操作 } synchronized 关键字与线程安全 以为用了 synchronized 关键字包住了代码就可以线程同步安全了。测试了下。发觉是完全的错了。synchronized 必需正确的使用才是真正的线程安全。。。虽然知道这种写法,始终以为却由于懒而用了错误的方法。 看来基础还没有打好。仍需复习加强!工作中犯这种错误是不行谅解的,要知道使用 synchronized 关键字的地方都是数据敏感的!汗一把。。。 先贴代码: package com; public class ThreadTest { public static void main(String[] args) { MyThread m1 = new MyThread(1); MyThread m2 = new MyThread(2); m1.start(); m2.start(); } } final class MyThread extends Thread { private int val; public MyThread(int v) { val = v; } //这种做法其实是非线程安全的 public synchronized void print1(int v) { for (int i = 0; i 100; i++) { System.out....