synchronized 关键字是实现锁的一种方式,是在jvm层面实现的非公平锁,以下是使用synchronized的四种方式
synchronized 特性:
1.非公平锁
2.可重入性
1.作用在方法上,保证了访问同一个对象的同一个方法的线程同步
public synchronized void testFun(String str){ for(int i=0;i<15;i++){ System.out.println(str+",执行中..."); } }
2.对象加锁,保证同时访问同一个对象的线程同步
public void testObject(String str){ synchronized (this){ for(int i=0; i<15;i++){ System.out.println(str+",执行中"); } } }
1,2 两种加锁方式在表现形式上是相同的
public static void main(String[] args){ ExecutorService executorService = Executors.newCachedThreadPool(); SynchronizeTest1 synchronizeTest1 = new SynchronizeTest1(); executorService.execute(new Runnable() { @Override public void run() { synchronizeTest1.testObject("线程1"); } }); executorService.execute(new Runnable() { @Override public void run() { synchronizeTest1.testObject("线程2"); } }); }
3.作用在类上
public static void testClass(String str){ synchronized (SynchronizeTest2.class){ for(int i=0 ;i<15;i++){ System.out.println(str+",执行中"); } } }
4.作用在静态方法上
public synchronized static void testStaticFun(String str){ for(int i=0;i<15;i++){ System.out.println(str+",执行中"); } }
3,4 在表现形式上是一样的
public static void main(String[] args){ ExecutorService executorService = Executors.newCachedThreadPool(); executorService.execute(new Runnable() { @Override public void run() { testClass("线程1"); //可以替换为testStaticFun 方法 } }); executorService.execute(new Runnable() { @Override public void run() { testClass("线程2"); //可以替换为testStaticFun 方法 } }); executorService.shutdown(); }