- 浏览: 383965 次
- 性别:
文章分类
最新评论
-
wjw103:
You are using old notation for ...
Struts2 入门实例代码 -
hhb19900618:
你好 你这个工程压缩包是不是有问题啊?根本不能导入?
Struts2 入门实例代码 -
it爱:
[list][*]dsadsa[*]dsadsa[*]dsad ...
Spring AOP 学习小结 -
youjianbo_han_87:
和 weblogic 有个毛线关系???????
Weblogic下的自动任务 -
hua839:
是用SmartUpload进行文件上传
第一种情况,synchronized无效
第二种情况,synchronized有效
第三种情况,synchronized有效
总结:
1、对于同步的方法或者代码块来说,必须获得对象锁才能够进入同步方法或者代码块进行操作;
2、如果采用method级别的同步,则对象锁即为method所在的对象(怎么这么别扭),如果是静态方法,对象锁即指method所在的Class对象(唯一);
3、对于代码块则,对象锁即指synchronized(abc)中的abc;
4、因为第一种情况,对象锁即为每一个线程对象,因此有多个,所以同步失效,第二种共用同一个对象锁lock,因此同步生效,第三个因为是static因此对象锁为ThreadTest3的class 对象,因此同步生效。
如上述正确,则同步有两种方式,代码块和方法
如果是代码块,则对象锁自己指定,一般有些代码为synchronized(this)只有在单态模式才生效;
如果是方法,则分静态和非静态两种。
静态方法则一定会同步,非静态方法需在单例模式才生效,推荐用静态方法(不用担心是否单例)。
不知道以上说的对否,如不对请指点。
http://www.iteye.com/topic/48750
jdk5concurrent也是建立在java的锁机制上的.
对于这种形式的多线程,ThreadTest实际也为单例模式,即对象只被创建一次,因此可以放心使用method级别的synchronized.
package com.test; public class ThreadTest extends Thread { private int threadNo; public ThreadTest(int threadNo) { this.threadNo = threadNo; } public static void main(String[] args) throws Exception { for (int i = 1; i < 10; i++) { new ThreadTest(i).start(); Thread.sleep(1); } } public synchronized void run() { for (int i = 1; i < 10000; i++) { System.out.println("No." + threadNo + ":" + i); } } }
第二种情况,synchronized有效
package com.test; public class ThreadTest2 extends Thread { private int threadNo; private String lock; public ThreadTest2(int threadNo, String lock) { this.threadNo = threadNo; this.lock = lock; } public static void main(String[] args) throws Exception { String lock = new String("lock"); for (int i = 1; i < 10; i++) { new ThreadTest2(i, lock).start(); Thread.sleep(1); } } public void run() { synchronized (lock) { for (int i = 1; i < 10000; i++) { System.out.println("No." + threadNo + ":" + i); } } } }
第三种情况,synchronized有效
package com.test; public class ThreadTest3 extends Thread { private int threadNo; private String lock; public ThreadTest3(int threadNo, String lock) { this.threadNo = threadNo; this.lock = lock; } public static void main(String[] args) throws Exception { String lock = new String("lock"); for (int i = 1; i < 20; i++) { new ThreadTest3(i, lock).start(); Thread.sleep(1); } } public static synchronized void abc(int threadNo) { for (int i = 1; i < 10000; i++) { System.out.println("No." + threadNo + ":" + i); } } public void run() { abc(threadNo); } }
总结:
1、对于同步的方法或者代码块来说,必须获得对象锁才能够进入同步方法或者代码块进行操作;
2、如果采用method级别的同步,则对象锁即为method所在的对象(怎么这么别扭),如果是静态方法,对象锁即指method所在的Class对象(唯一);
3、对于代码块则,对象锁即指synchronized(abc)中的abc;
4、因为第一种情况,对象锁即为每一个线程对象,因此有多个,所以同步失效,第二种共用同一个对象锁lock,因此同步生效,第三个因为是static因此对象锁为ThreadTest3的class 对象,因此同步生效。
如上述正确,则同步有两种方式,代码块和方法
如果是代码块,则对象锁自己指定,一般有些代码为synchronized(this)只有在单态模式才生效;
如果是方法,则分静态和非静态两种。
静态方法则一定会同步,非静态方法需在单例模式才生效,推荐用静态方法(不用担心是否单例)。
不知道以上说的对否,如不对请指点。
http://www.iteye.com/topic/48750
评论
10 楼
skydream
2007-01-17
这个东西一直感觉应该是挺简单的,怎么越说越糊涂了?我说几个我的理解吧,如果有误请大家指出:
1.synchronized是锁对象,根本不存在锁代码块的概念
2.synchronized锁定的对象
(1)synchronized(obj){}-> 这个当然是锁obj
(2)public void synchronized function(){} -> 这个锁的是function这个方法所在的对象,相当于
public void function() {
synchronized(this){}
}
(3)public static void synchronized function() ->对于静态方法,锁定的是当前类(假设是类TestClass)的Class对象,相当于
public static void function() {
synchronized(TestClass.class) {}
}
3.jdk1.5中的concurrent包
这个东西一直就存在的,没记错的话是一个大学的教授写的(名字忘了,挺佩服这人的),一直都是以一个工具包的形式存在,因为这个包写的太好,jdk1.5时被收录到jdk的标准包,以java.util.concurrent的形式出现。
这个concurrent包实际也是对java的同步,锁这些操作的一个代码封装, java本身的机制并没有做任何修改。
对于jdk1.5以前的jdk如jdk1.4,可以去找concurrent这个包的以前的版本,google一下应该就能出来的,不必拘泥于jdk1.5。
1.synchronized是锁对象,根本不存在锁代码块的概念
2.synchronized锁定的对象
(1)synchronized(obj){}-> 这个当然是锁obj
(2)public void synchronized function(){} -> 这个锁的是function这个方法所在的对象,相当于
public void function() {
synchronized(this){}
}
(3)public static void synchronized function() ->对于静态方法,锁定的是当前类(假设是类TestClass)的Class对象,相当于
public static void function() {
synchronized(TestClass.class) {}
}
3.jdk1.5中的concurrent包
这个东西一直就存在的,没记错的话是一个大学的教授写的(名字忘了,挺佩服这人的),一直都是以一个工具包的形式存在,因为这个包写的太好,jdk1.5时被收录到jdk的标准包,以java.util.concurrent的形式出现。
这个concurrent包实际也是对java的同步,锁这些操作的一个代码封装, java本身的机制并没有做任何修改。
对于jdk1.5以前的jdk如jdk1.4,可以去找concurrent这个包的以前的版本,google一下应该就能出来的,不必拘泥于jdk1.5。
9 楼
lzzzl
2007-01-12
没抓住要点!另外后2个示例的synchronized关键字在哪啊?
我这几天遇到同步问题,看了一篇文章,里面有一个关键的说法:“锁定的是对象而不是代码”,所以问题也就迎刃而解了。
我这几天遇到同步问题,看了一篇文章,里面有一个关键的说法:“锁定的是对象而不是代码”,所以问题也就迎刃而解了。
8 楼
jamesby
2006-12-31
5.0中锁的使用方式
Lock lock = new ReentrantLock(); lock.lock(); try { // update object state } finally { lock.unlock(); }
7 楼
jamesby
2006-12-31
Godlikeme 写道
对java锁机制研究不深,转贴两片文章,觉得还不错,作为参考。
http://www.ibm.com/developerworks/cn/java/j-jtp11234/index.html
http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html
5.0 中好像对锁的机制改善很多,sychronized的锁应该是只实现一个等待锁,而5.0中又多了比如时间锁等候、可中断锁等候、无块结构锁、多个条件变量或者锁投票等很多种,最大区别是5.0自定义锁,自己负责锁的释放.其它优势还不清楚.
http://www.ibm.com/developerworks/cn/java/j-jtp11234/index.html
http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html
6 楼
Godlikeme
2006-12-30
对java锁机制研究不深,转贴两片文章,觉得还不错,作为参考。
http://www.ibm.com/developerworks/cn/java/j-jtp11234/index.html
http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html
http://www.ibm.com/developerworks/cn/java/j-jtp11234/index.html
http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html
5 楼
jamesby
2006-12-30
to Godlikeme:
复杂的是锁的机制吧,那是JDK的事情,我们写程序不复杂吧!
jdk5concurrent什么东西?现在还在用1.4,有时间再看。
复杂的是锁的机制吧,那是JDK的事情,我们写程序不复杂吧!
jdk5concurrent什么东西?现在还在用1.4,有时间再看。
4 楼
XMLDB
2006-12-30
Godlikeme 写道
本来简单的东西这么一说到复杂了,
java本身的这个锁机制还是有一些问题,还是建议多研究下,jdk5concurrent包吧。
java本身的这个锁机制还是有一些问题,还是建议多研究下,jdk5concurrent包吧。
jdk5concurrent也是建立在java的锁机制上的.
3 楼
Godlikeme
2006-12-30
本来简单的东西这么一说到复杂了,
java本身的这个锁机制还是有一些问题,还是建议多研究下,jdk5concurrent包吧。
java本身的这个锁机制还是有一些问题,还是建议多研究下,jdk5concurrent包吧。
2 楼
jamesby
2006-12-30
引用
public class ThreadTest implements Runnable {
public void run() {
}
public static void main(String[] args) {
ThreadTest threadTest= new ThreadTest();
Thread threadA = new Thread(threadTest, "A");
Thread threadB = new Thread(threadTest, "B");
threadA.start();
threadB.start();
}
}
public void run() {
}
public static void main(String[] args) {
ThreadTest threadTest= new ThreadTest();
Thread threadA = new Thread(threadTest, "A");
Thread threadB = new Thread(threadTest, "B");
threadA.start();
threadB.start();
}
}
对于这种形式的多线程,ThreadTest实际也为单例模式,即对象只被创建一次,因此可以放心使用method级别的synchronized.
1 楼
jamesby
2006-12-30
当然,如果有多个synchronized块,只要对象锁相同,如果有线程访问其中一个synchronized块,其它只能阻塞。
发表评论
-
weblogic.xml文件代码示例
2008-04-19 10:44 8893<?xml version="1.0" ... -
java 运行版本问题
2008-02-26 08:33 1830在JDK 5.0 上编译好的class,即使未用到任何5.0的 ... -
sqlserver 2000 1433 端口未打开的问题
2008-02-26 08:32 2568需要安装SqlServer 2000 SP4 -
我的一次weblogic 8升级到weblogic9遇到的问题.
2007-04-29 18:17 51561、web应用的乱码问题。 原来的基于weblogic8的应用 ... -
关于手机浏览器的问题?
2007-04-20 12:07 7368现在有一个新的需求,本来目前的基于web的软件开发已经完成,但 ... -
Weblogic下的自动任务
2007-04-03 14:13 2942package com.jamesby.listener; ... -
是用SmartUpload进行文件上传
2007-04-03 14:06 5647package com.jamesby.file.servle ... -
文件下载Servlet
2007-04-03 13:57 4352package com.jamesby.action; ... -
Java 5.0 枚举
2007-03-12 15:09 2210http://www.ibm.com/developerwor ... -
关于web-inf/classes的优先级高于web-inf/lib的优先级
2007-03-08 12:11 4856背景 一直以来都知道web-inf/classes的优先级高 ... -
深入了解WebLogic的类装载机制详解
2007-03-01 19:05 2230http://publish.it168.com/2005/1 ... -
我的一次EJB重构过程
2007-03-01 12:13 2096背景 因为历史遗留问题,代码写的杂乱无章,没有条理,而且该 ... -
如何防止用户恶意的F5刷新操作的问题?
2007-02-25 18:45 13140背景: 问题是这样的,系统持久层采用ibatis架构,系统 ... -
自己实现的TransactionManager
2007-02-23 13:53 4834背景: 目前有一个系统,系统已经写好了,但是要不停的添加新的功 ... -
关于Service和DAO层的功能划分的迷惑
2007-02-13 17:27 20711Service 层的代码 public class Gene ... -
关于Service调用Service 的思考
2007-02-10 20:04 5185以前做软件都是随便写几个Service,纯粹为了Service ... -
通过IP访问服务器session失效,计算机名则可以,什么原因?
2007-02-08 17:26 4806最近开发一个新项目采用Spring MVC+Spring+iB ... -
Tomcat 类加载机制
2007-02-08 12:04 1763yahoo中国的一个面试题,转至水木. Tomcat Ser ... -
Weblogic 8.1.3 下数据库连接池的配置问题
2007-02-07 21:00 2600weblogic8.1.3下同一个数据库连接池最好只被一个we ... -
Weblogic 8.1.3 下如何使用JSTL
2007-02-07 20:56 3189一、下载jakarta-taglibs-standard-1. ...
相关推荐
Java 线程同步控制机制 线程同步是 Java 编程中的一种机制,用于控制多个线程之间的资源访问顺序,以避免线程之间的冲突和数据不一致。线程同步的目的就是避免线程“同步”执行,即让多个线程之间排队操作共享资源...
java线程同步java线程同步java线程同步
总结一下,Java线程同步的关键点: 1. **线程同步是为了解决共享资源的并发访问问题,防止数据不一致和冲突。** 2. **同步意味着线程排队,依次访问共享资源,而不是同时访问。** 3. **只有共享变量(可变状态)才...
随着Java版本的更新,Java也引入了新的并发工具类,例如java.util.concurrent包下的并发集合、原子操作类以及各种并发控制类,这些工具类提供了比传统synchronized和volatile关键字更强大、更灵活的线程同步控制机制...
在Java编程环境中,...总之,使用Java线程实现数据库主从同步更新是一种常见且实用的技术手段,它涉及到多线程编程、数据库操作、事务管理等多个方面。理解和掌握这些知识点对于开发高可用性的分布式系统至关重要。
线程同步的主要目的是解决多线程环境下的资源共享问题,确保资源的安全访问。Java提供了多种同步机制,包括但不限于: 1. **同步方法**:通过在方法声明上使用 `synchronized` 关键字来实现。 2. **同步块**:...
因此,在使用Java多线程同步机制时,需要小心避免这些问题的出现。 Java多线程同步机制在实际应用中的应用 Java多线程同步机制在实际应用中有很多应用,例如: * 在线银行系统中,使用Java多线程同步机制来确保...
#### 一、Java线程:概念与原理 1. **操作系统中线程和进程的概念** - 当前的操作系统通常为多任务操作系统,多线程是实现多任务的一种手段。 - **进程**:指内存中运行的应用程序,每个进程拥有独立的内存空间。...
本文档("Java线程学习和总结.htm")可能包含了更多关于线程的实例、源码分析和常见问题解决方案,你可以通过阅读来进一步加深对Java线程的理解。同时,"Java线程学习和总结.files"目录下的文件可能是与文章相关的...
Java线程同步与通信是多线程编程中的关键概念,用于解决并发访问共享资源时可能出现的数据不一致性和竞态条件问题。以下将详细介绍这两个主题,以及如何通过代码示例进行演示。 1. **线程同步**: 线程同步是确保...
java多线程同步互斥访问实例,对于初学者或是温故而知新的同道中人都是一个很好的学习资料
Java线程同步调用是多线程编程中的基石,它通过同步方法和同步代码块两种方式,有效地控制了线程之间的交互,防止了多线程环境下常见的并发问题。无论是对于初学者还是有经验的开发者,掌握和熟练应用这些同步机制都...
在Java编程中,线程同步和互斥是多线程编程中的重要概念,它们用于解决多个线程同时访问共享资源时可能出现的问题。本项目通过一个生产者消费者问题的实例,展示了如何在Java中实现线程间的同步与互斥。 生产者消费...
多线程注意:wait()方法的调用要有判定条件常用 while () obj.wait(timeout, nanos); ... // Perform action appropriate to condition } synchronized会影响共享数据,但对其他语句的执行不会有规律了!
在“操作系统实验 多线程同步与互斥 java编写 有界面”的实验中,可能需要设计一个图形用户界面(GUI),通过按钮或事件触发线程的创建和同步操作,直观地展示线程间的交互和同步效果。例如,可以模拟银行账户转账,...
以下是对Java线程安全的深入总结: ### 一、线程安全的定义 线程安全是指当多个线程访问同一块代码时,如果每个线程都能得到预期的结果,且不产生数据不一致或同步问题,那么这块代码就被称为线程安全的。Java中的...
Java线程(二):线程同步synchronized和volatile 详细讲解Java 同步的原理技术资料
电子书相关:包含4个有关JAVA线程的电子书(几乎涵盖全部有关线程的书籍) OReilly.Java.Threads.3rd.Edition.Sep.2004.eBook-DDU Java Thread Programming (Sams) java线程第二版中英文 java线程第二版中英文 ...