岁月无痕的博客

越努力、越幸福

三、Java内存模型---重排序和顺序一致性

3.2 重排序 重排序是指编译器和处理器为了优化程序性能而对指令序列进行重新排序的一种手段。 3.2.1 数据依赖性 如果两个操作访问同一个变量,且这两个操作中有一个为写操作,此时这两个操作之间 就存在数据依赖性。数据依赖分为下列3种类型,如表3-4所示。 上面3种情况,只要重排...

2017-06-15 14:12:31

阅读数:344

评论数:0

三、Java内存模型---Java内存模型的基础

3.1 Java内存模型的基础 3.1.1 并发编程模型的两个关键问题 并发编程中,有两大关键问题:线程之间如何通信和线程之间如何同步。通信是指线程之间以何种机制来交换信息。在命令式编程中,线程之间的通信机制有两种:共享内存和消息传递。 在共享内存的并发模型里,线程之间共享程序的公共状态,通...

2017-06-15 13:31:24

阅读数:218

评论数:0

二、Java并发机制的底层实现原理

Java代码编译后变成java字节码,字节码被类加载器加载到JVM里,JVM执行字节码,最终需要转化为汇编指令在CPU上执行,java中所使用的并发机制依赖于JVM的实现和CPU的执行。2.1 volatile的应用 在多线程并发编程中,synchronized和volatile都扮演重要的角...

2017-06-07 14:45:20

阅读数:563

评论数:1

一、并发编程的挑战

Java并发编程的目的是为了让程序运行的更快,但不是启动更多的线程就能让程序最大限度的执行,因为在并发编程中,启动更多的线程,会面临上下文切换、死锁、以及所使用的软件和硬件的资源限制等问题。 1.1上下文切换 单核处理器下,多线程执行代码,cpu给每个线程分配cpu时间片来实现多线程,cpu不...

2017-06-07 11:26:52

阅读数:181

评论数:0

Java三种移位运算符

java中有三种移位运算符1、<< : 左移运算符,value<< num,相当于value乘以2的num次方 方法:丢掉最高位移动的位数,最低移动的位数补0,若num大于value转为二进制后的最大位数n,则取模num%n例如:9 <<2 9—int类型...

2017-06-06 11:52:33

阅读数:291

评论数:0

Java HashMap的死循环

在淘宝内网里看到同事发了贴说了一个CPU被100%的线上故障,并且这个事发生了很多次,原因是在Java语言在并发情况下使用HashMap造成Race Condition,从而导致死循环。这个事情我4、5年前也经历过,本来觉得没什么好写的,因为Java的HashMap是非线程安全的,所以在并发下必然...

2017-06-05 18:02:28

阅读数:140

评论数:0

Java并发编程:Thread类的使用

今天我们来学习一下Thread类,在学习Thread类之前,先介绍与线程相关知识:线程的几种状态、上下文切换,然后接着介绍Thread类中的方法的具体使用。  以下是本文的目录大纲:  一.线程的状态  二.上下文切换  三.Thread类中的方法一.线程的状态  在正式学习Thread类中的具体...

2017-06-05 16:54:02

阅读数:169

评论数:0

LinkedHashMap源码剖析

前言:有网友建议分析下LinkedHashMap的源码,于是花了一晚上时间研究了下,分享出此文(这个系列的最后一篇博文了),希望大家相互学习。LinkedHashMap的源码理解起来也不难(当然,要建立在对HashMap源码有较好理解的基础上)。LinkedHashMap简介LinkedHashM...

2017-06-02 12:46:27

阅读数:189

评论数:0

简单选择排序 java实现

简单选择排序基本思想:在要排序的一组数中,选出最小的一个数与第一个位置的数交换;然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。代码实现如下public class SimpleSelectSort { public static void m...

2017-06-01 10:48:23

阅读数:311

评论数:0

提示
确定要删除当前文章?
取消 删除
关闭
关闭