多线程 同步 信号量-如果synchronized(new Object){} 和 Object obj = new Object(); synchronized(obj){}的区别是什么?

问题描述

如果synchronized(new Object){} 和 Object obj = new Object(); synchronized(obj){}的区别是什么?

如果synchronized(new Object){} 和 Object obj = new Object(); synchronized(obj){}的区别是什么? 主要是在synchronized()中放new Object 是四个线程一起,而放obj对象是一个一个的执行,这是什么原因呢?

代码:
class XianChengDemo {

public static void main(String[] args)

{

Card c = new Card();

Thread t = new Thread(c);

Thread t1 = new Thread(c);

Thread t2 = new Thread(c);

Thread t3 = new Thread(c);

t.start();

t1.start();

t2.start();

t3.start();
}}

class Card implements Runnable{
private static int cards = 100;
Object obj = new Object();

public void run()

{ while(true)
{ synchronized(obj)
{ if(cards>0)
{ try{Thread.sleep(10);}catch(Exception e){} System.out.println(Thread.currentThread().getName()+"------"+cards--);
}
else{
break;

}
}
} }}

解决方案

  第一种写法使用的锁监视器对象是临时创建的,即每个线程运行到这段代码时都会新建一个对象并以此为同步锁,锁不同当然不存在锁竞争而等待问题,所以看到的是并行的。
 第二个写法同步块对象是全局的成员变量,所有访问这段代码的线程使用的是同一个锁监视器,所以有竞争等待。

解决方案二:

Object obj = new Object();定义成函数内的成员变量,那么和第一种一样,定义成成员变量,你写的那种,那么锁定的是实例,也就是相同的对象实例被多个线程调用,那么会被同步。
还可以锁静态变量。那么相当于全局类的同步。

时间: 2024-09-11 07:21:34

多线程 同步 信号量-如果synchronized(new Object){} 和 Object obj = new Object(); synchronized(obj){}的区别是什么?的相关文章

多线程 同步 信号量-用信号量实现多线程同步(用 c# 语言实现) ?

问题描述 用信号量实现多线程同步(用 c# 语言实现) ? 现实信号量关键是 p v 操作,由于p v 操作是不可中断的,怎么模拟使得 p v 操作不可中断的执行呢? 解决方案 http://www.cnblogs.com/heqichang/archive/2011/12/24/2300301.html 解决方案二: http://blog.csdn.net/adream307/article/details/7566342

多线程同步synchronized问题

问题描述 在多线程同步的时候,synchronized(object ){//同步代码块},其中同步的代码块和加锁的对象object有必然关系吗?他们关系怎样? 解决方案 没有关系!synchronized(object ){ //同步代码块 }表示只有当前这个对象拿到object这个对象的锁才能执行同步代码块中的代码每一个对象有一个对象锁,但是每一个对象只有一个Class锁解决方案二:synchronized(object)中的object使用什么决定了锁定的范围,通常可能会简单的使用this

JAVA之旅(十三)——线程的安全性,synchronized关键字,多线程同步代码块,同步函数,同步函数的锁是this

JAVA之旅(十三)--线程的安全性,synchronized关键字,多线程同步代码块,同步函数,同步函数的锁是this 我们继续上个篇幅接着讲线程的知识点 一.线程的安全性 当我们开启四个窗口(线程)把票陆陆续续的卖完了之后,我们要反思一下,这里面有没有安全隐患呢?在实际情况中,这种事情我们是必须要去考虑安全问题的,那我们模拟一下错误 package com.lgl.hellojava; import javax.security.auth.callback.TextInputCallback

详解Linux多线程使用信号量同步_Linux

信号量.同步这些名词在进程间通信时就已经说过,在这里它们的意思是相同的,只不过是同步的对象不同而已.但是下面介绍的信号量的接口是用于线程的信号量,注意不要跟用于进程间通信的信号量混淆. 一.什么是信号量 线程的信号量与进程间通信中使用的信号量的概念是一样,它是一种特殊的变量,它可以被增加或减少,但对其的关键访问被保证是原子操作.如果一个程序中有多个线程试图改变一个信号量的值,系统将保证所有的操作都将依次进行. 而只有0和1两种取值的信号量叫做二进制信号量,在这里将重点介绍.而信号量一般常用于保护

起底多线程同步锁(iOS)

iOS/MacOS为多线程.共享内存(变量)提供了多种的同步解决方案(即同步锁),对于这些方案的比较,大都讨论了锁的用法以及锁操作的开销,然后就开销表现排个序.小哥以为,最优方案的选用还是看应用场景,高频接口PK低频接口.有限冲突PK激烈竞争.代码片段耗时的长短,以上都是正确选用的重要依据,不同方案在其适用范围表现各有不同.这些方案当中,除了熟悉的iOS/MacOS系统自有的同步锁,另外还有两个自研的读写锁,还有应用开发中常见的set/get访问接口的原子操作属性. 1.@synchronize

java多线程同步的问题

问题描述 java多线程同步的问题 小测试,如何实现变量ticket的同步 private int ticket = 100; public void run() { while(ticket > 0 ) { System.out.println(ticket+" is saled by "+ Thread.currentThread().getName()); ticket--; try { Thread.sleep(200); } catch (InterruptedExce

Servlet及JSP中的多线程同步问题

js|servlet|多线程|问题 Servlet/JSP技术和ASP.PHP等相比,由于其多线程运行而具有很高的执行效率.由于Servlet/JSP默认是以多线程模式执行的,所以,在编写代码时需要非常细致地考虑多线程的同步问题.然而,很多人编写Servlet/JSP程序时并没有注意到多线程同步的问题,这往往造成编写的程序在少量用户访问时没有任何问题,而在并发用户上升到一定值时,就会经常出现一些莫明其妙的问题,对于这类随机性的问题调试难度也很大. 一.在Servlet/JSP中的几种变量类型 在

Java多线程同步问题的探究(一、线程的先来后到)

众所周知,在Java多线程编程中,一个非常重要的方面就是线程的同步问题. 关于线程的同步,一般有以下解决方法: 1. 在需要同步的方法的方法签名中加入synchronized关键字. 2. 使用synchronized块对需要进行同步的代码段进行同步. 3. 使用JDK 5中提供的java.util.concurrent.lock包中的Lock对象. 另外,为了解决多个线程对同一变量进行访问时可能发生的安全性问题,我们不仅可以采用同步机制,更可以通过JDK 1.2中加入的 ThreadLocal

Java开发多线程同步技巧

在编写一个类时,如果该类中的代码可能运行于多线程环境下,那么就要考虑同步的问题.在Java中内置了语言级的同步原语--synchronized,这也大大简化了Java中多线程同步的使用. 我们首先编写一个非常简单的多线程的程序,是模拟银行中的多个线程同时对同一个储蓄账户进行存款.取款操作的. 在程序中我们使用了一个简化版本的Account类,代表了一个银行账户的信息.在主程序中我们首先生成了1000个线程,然后启动它们,每一个线程都对John的账户进行存100元,然后马上又取出100元.这样,对