synchronized 锁机制简单的用法,高效的执行效率使成为解决线程安全的首选。 下面总结其特性以及使用技巧,加深对其理解。

特性:

  1. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。

      2. 当一个线程同时访问object的一个synchronized(this)同步代码块时,其它线程仍然可以访问非修饰的方法或代码块。

      3. 当多个线程同时访问object的synchronized(this)同步代码块时,会存在互斥访问,其它线程会阻塞直到获取锁。

      4. 当线程访问object的synchronized(this)同步代码块时,同一个线程可以多次获取锁,当然也不需要释放多次。获取和释放必须相同。

      5. 所有的对象都可以获取锁,也可以释放锁。

      6. 所有的类也可以获取锁和释放锁,因此静态方法也可以加锁。而特性同上。

猜想:

     在jvm中对每个对象都有一个记录锁的状态,当同一个线程访问锁时候就会累加,其它线程访问要等到状态变为未锁状态,当让相同线程释放锁会累减。

 质疑:

    那么对于类锁来说,应该是所有对象都可以获取锁,那么锁是全局的对所有对象都有效?

public class SynchronizedMtdTest {

  public static void main(String[] args) {

    new Thread(new Runnable() {
@Override
public void run() {
SynchronizedMtdTest.appendStr();
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
SynchronizedMtdTest.printStr();
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
SynchronizedMtdTest synchronizedMtdTest = new SynchronizedMtdTest();
synchronizedMtdTest.appendStr();
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
SynchronizedMtdTest synchronizedMtdTest = new SynchronizedMtdTest();
synchronizedMtdTest.printStr();
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
SynchronizedMtdTest synchronizedMtdTest = new SynchronizedMtdTest();
synchronizedMtdTest.append();
}
}).start();
} public synchronized static void appendStr() {
System.out.println("pid=" + Thread.currentThread().getId() + "------appendStr------");
try {
Thread.sleep(1000);
System.out.println("pid=" + Thread.currentThread().getId() + "------appendStr1000------");
} catch (InterruptedException e) {
e.printStackTrace();
} } public static void append() {
System.out.println("pid=" + Thread.currentThread().getId() + "------append------");
try {
Thread.sleep(3000);
System.out.println("pid=" + Thread.currentThread().getId() + "------append3000------");
} catch (InterruptedException e) {
e.printStackTrace();
} } public synchronized static void printStr() {
System.out.println("pid=" + Thread.currentThread().getId() + "------printStr------");
try {
Thread.sleep(6000);
System.out.println("pid=" + Thread.currentThread().getId() + "------printStr6000------");
} catch (InterruptedException e) {
e.printStackTrace();
}
} }

结果:

pid=10------appendStr------
pid=14------append------
pid=10------appendStr1000------
pid=13------printStr------
pid=14------append3000------
pid=13------printStr6000------
pid=12------appendStr------
pid=12------appendStr1000------
pid=11------printStr------
pid=11------printStr6000------

分析结果可以看出对于静态方法加锁,所有的线程调用方法,不管怎样都会互斥,而为加锁不会互斥。

因此:

对于类锁来说应该在持久代也就是方法区有对具体类也有加锁机制,而且原理同对象锁。

那么:

    可见,上面可以做如下修改达到相同效果。

public static void appendStr() {
synchronized (SynchronizedMtdTest.class) {
System.out.println("pid=" + Thread.currentThread().getId() + "------appendStr------");
try {
Thread.sleep(1000);
System.out.println("pid=" + Thread.currentThread().getId() + "------appendStr1000------");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
} public static void printStr() {
synchronized (SynchronizedMtdTest.class) {
System.out.println("pid=" + Thread.currentThread().getId() + "------printStr------");
try {
Thread.sleep(6000);
System.out.println("pid=" + Thread.currentThread().getId() + "------printStr6000------");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

结果:

pid=10------appendStr------
pid=10------appendStr1000------
pid=13------printStr------
pid=13------printStr6000------
pid=12------appendStr------
pid=12------appendStr1000------
pid=11------printStr------
pid=11------printStr6000------

JAVA synchronized关键字锁机制(中)的更多相关文章

  1. 由Java 15废弃偏向锁,谈谈Java Synchronized 的锁机制

    Java 15 废弃偏向锁 JDK 15已经在2020年9月15日发布,详情见 JDK 15 官方计划.其中有一项更新是废弃偏向锁,官方的详细说明在:JEP 374: Disable and Depr ...

  2. Java Synchronized 关键字

    本文内容 Synchronized 关键字 示例 Synchronized 方法 内部锁(Intrinsic Locks)和 Synchronization 参考资料 下载 Demo Synchron ...

  3. Java synchronized 关键字详解

    Java synchronized 关键字详解 前置技能点 进程和线程的概念 线程创建方式 线程的状态状态转换 线程安全的概念 synchronized 关键字的几种用法 修饰非静态成员方法 sync ...

  4. JAVA多线程与锁机制

    JAVA多线程与锁机制 1 关于Synchronized和lock synchronized是Java的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码 ...

  5. 深入浅出Java并发包—锁机制(三)

    接上文<深入浅出Java并发包—锁机制(二)>  由锁衍生的下一个对象是条件变量,这个对象的存在很大程度上是为了解决Object.wait/notify/notifyAll难以使用的问题. ...

  6. 深入浅出Java并发包—锁机制(二)

    接上文<深入浅出Java并发包—锁机制(一)  >  2.Sync.FairSync.TryAcquire(公平锁) 我们直接来看代码 protected final boolean tr ...

  7. java并发之线程同步(synchronized和锁机制)

    使用synchronized实现同步方法 使用非依赖属性实现同步 在同步块中使用条件(wait(),notify(),notifyAll()) 使用锁实现同步 使用读写锁实现同步数据访问 修改锁的公平 ...

  8. [多线程] 线程中的synchronized关键字锁

    为什么要用锁? 在多线程中,难免会出现在多个线程中对同一个对象的实例变量或者全局静态变量进行并发访问的情况,如果不做正确的同步处理,那么产生的后果就是"脏读",也就是取到的数据其实 ...

  9. Java:synchronized关键字引出的多种锁

    前言 Java 中的 synchronized关键字可以在多线程环境下用来作为线程安全的同步锁.本文不讨论 synchronized 的具体使用,而是研究下synchronized底层的锁机制,以及这 ...

随机推荐

  1. 删除 Linux /tmp 目录下的临时文件

    使用 tmpreaper How to install and use tmpreaper How to Remove Files Older than N days using tmpreaper ...

  2. Redis集群管理(二)

    1.进入集群客户端 任意选一个redis节点,进入redis 所在目录 cd /redis 所在目录/src/ ./redis-cli -h 本地节点的ip -p redis的端口号 -a 密码 [r ...

  3. [ASP.NET 大牛之路]02 - C#高级知识点概要(1) - 委托和事件

    在ASP.NET MVC 小牛之路系列中,前面用了一篇文章提了一下C#的一些知识点.照此,ASP.NET MVC 大牛之路系列也先给大家普及一下C#.NET中的高级知识点.每个知识点不太会过于详细,但 ...

  4. pta 习题集 5-17九宫格输入法

    假设有九宫格输入法键盘布局如下: [ 1,.?! ] [ 2ABC ] [ 3DEF ] [ 4GHI ] [ 5JKL ] [ 6MNO ] [ 7PQRS ] [ 8TUV ] [ 9WXYZ ] ...

  5. EL表达式经验教训 javax.el.PropertyNotFoundException 出错

    之所以是把他记下来,是因为这个低级错误 害的我找了老半天. 后台传了对象到页面,在页面中循环遍历获得对象某个属性值 如下: <c:forEach items="${resultMap. ...

  6. Git 进阶操作(一)

    1. 获取提交信息(commit) git show 1c002d(哈希值的前几位): 获取提交的信息; git show HEAD^: 显示HEAD的上级(parent)提交的信息; git sho ...

  7. Python开发【数据结构】:排序练习

    排序练习 问题一: 现在有一个列表,列表中的数范围都在0到100之间,列表长度大约为100万.设计算法在O(n)时间复杂度内将列表进行排序. import random data = [random. ...

  8. Python开发【模块】:Requests(一)

    Requests模块 1.模块说明 Requests 是使用 Apache2 Licensed 许可证的 HTTP 库.用 Python 编写,真正的为人类着想. Python 标准库中的 urlli ...

  9. linux 的nohup & 和daemon 总结(转)

    add by zhj:守护进程貌似跟nohup + &方式启动的进程差不多.都可以实现与终端的无关联.   原文:http://blog.csdn.net/lovemdx/article/de ...

  10. centos linux系统日常管理3 服务管理ntsysv,chkconfig,系统日志rsyslog,last ,lastb ,exec,xargs,dmesg,screen,nohup,curl,ping ,telnet,traceroute ,dig ,nc,nmap,host,nethogs 第十六节课

    centos linux系统日常管理3  服务管理ntsysv,chkconfig,系统日志rsyslog,last ,lastb ,exec,xargs,dmesg,screen,nohup,cur ...