- 浏览: 59168 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
shifulong:
cywhoyi 写道现在用Javassist代理也不错的看了一 ...
java动态代理(jdk &cglib) -
cywhoyi:
现在用Javassist代理也不错的
java动态代理(jdk &cglib)
写了一个线程安全的计数器(用锁显得多没有水平),非阻塞的,通过自旋的CAS操作达到数据一致性的效果
开始先说下原子变量和锁的比较
锁在高竞争的时候效率会高于原子变量,但是在中低竞争的时候原子变量的性能会好一些
类比:(交通拥堵时,交通信号灯能够实现更高的吞吐量,而在低拥堵时,环岛能实现更高的吞吐量)
知识点:
UnSafe的CAS操作
UnSafe的实例化
1.JDK适用UnSafe是通过下面的代码获取的
但是自定义使用UnSafe无法获取,会抛异常,原因如下代码。
2.构造函数私有化,无法new
3.么办法,只能反射了
CyclicBarrier(循环栅栏)
1.提供了两种初始化的构造方法
parties:到达栅栏的线程数目=parties,会释放栅栏
包含Runnable的构造方法,Runnable会在所有线程通过栅栏的时候触发
2.CyclicBarrier可以循环使用
下面是代码,分两个部分,计数器类和测试类
结果是1000*10=10000应该是正确的,在进行了上百次的测试的结果都是10000,程序应该没问题
finalVal : 0
finalVal : 10000
开始先说下原子变量和锁的比较
锁在高竞争的时候效率会高于原子变量,但是在中低竞争的时候原子变量的性能会好一些
类比:(交通拥堵时,交通信号灯能够实现更高的吞吐量,而在低拥堵时,环岛能实现更高的吞吐量)
知识点:
UnSafe的CAS操作
unsafe.compareAndSwapInt(this, valueOffset, oleVal, newVal)
UnSafe的实例化
1.JDK适用UnSafe是通过下面的代码获取的
private static final Unsafe unsafe = Unsafe.getUnsafe();
但是自定义使用UnSafe无法获取,会抛异常,原因如下代码。
public static Unsafe getUnsafe() { Class var0 = Reflection.getCallerClass(); if(var0.getClassLoader() != null) { throw new SecurityException("Unsafe"); } else { return theUnsafe; } }
2.构造函数私有化,无法new
3.么办法,只能反射了
try { Field field = Unsafe.class.getDeclaredField("theUnsafe"); field.setAccessible(true); unsafe = (Unsafe) field.get(Unsafe.class); } catch (Exception e) { e.printStackTrace(); }
CyclicBarrier(循环栅栏)
1.提供了两种初始化的构造方法
parties:到达栅栏的线程数目=parties,会释放栅栏
包含Runnable的构造方法,Runnable会在所有线程通过栅栏的时候触发
public CyclicBarrier(int parties) public CyclicBarrier(int parties, Runnable barrierAction)
2.CyclicBarrier可以循环使用
下面是代码,分两个部分,计数器类和测试类
import sun.misc.Unsafe; import java.io.Serializable; import java.lang.reflect.Field; public class CasCounter implements Serializable { private static Unsafe unsafe; private static long valueOffset; static { try { Field field = Unsafe.class.getDeclaredField("theUnsafe"); field.setAccessible(true); unsafe = (Unsafe) field.get(Unsafe.class); } catch (Exception e) { e.printStackTrace(); } try { valueOffset = unsafe.objectFieldOffset(CasCounter.class.getDeclaredField("value")); } catch (NoSuchFieldException e) { e.printStackTrace(); } } private volatile int value; public CasCounter() {value = 0;} public CasCounter(int initValue) {this.value = initValue;} public int getValue() { return value; } public int increment(int incrNum) {//线程安全 while (true) { int oleVal = value; int newVal = oleVal + incrNum; if (unsafe.compareAndSwapInt(this, valueOffset, oleVal, newVal)) { return newVal; } } } public int incrementNo(int incrNum) {//非线程安全 value += incrNum; return value; } }
import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; public class Test { public static void main(String[] args) throws BrokenBarrierException, InterruptedException { final CasCounter casCounter = new CasCounter(); final CyclicBarrier cb = new CyclicBarrier(1001, new Runnable() { public void run() { System.out.printf("finalVal : %s \n", casCounter.getValue()); } }); for (int i = 0; i < 1000; i++) { new Thread(new Runnable() { public void run() { try { cb.await(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } for (int j = 0; j < 10; j++) { int curr = casCounter.increment(1); System.out.print("");//这行代码会增加冲突概率 } try { cb.await(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }).start(); } cb.await(); cb.await(); } }
结果是1000*10=10000应该是正确的,在进行了上百次的测试的结果都是10000,程序应该没问题
finalVal : 0
finalVal : 10000
发表评论
-
test
2016-02-26 17:45 486http://c.hiphotos.baidu.com/t ... -
java Integer的比较
2016-01-18 20:09 1075/** * A constant ... -
load过高排查
2016-01-07 19:15 1133jstack 线程的运行情况、线程的状态 load过高的 ... -
Runnable Callable Future FutrueTask ExecutorService的关系
2015-11-30 16:34 701public interface ExecutorSe ... -
单例模式以及序列化仍然单例的问题
2015-11-18 10:47 587这种方式仍然存在并发的同步阻塞问题,并且jdk1.5之 ... -
linux5种网络IO模型
2015-11-07 21:58 895看网上书上的各种解释太绕口难理解了,看到个例子挺好的。 ... -
nio学习记录 : start(buffer channel selector)
2015-11-06 22:17 756Buffer的capacity,limit,positio ... -
desgn partten : 适配器&门面
2015-11-05 11:55 612adapter adapter 一个接口转换成另一个接 ... -
java泛型中的PECS
2015-10-26 17:58 1026extends List<? extends Nu ... -
spring自定义cache
2015-10-21 17:14 4558下面是一个较为详细的spring缓存的介绍 http:/ ... -
spring各种接口的作用FactoryBean、ApplicationContextAware、InitializingBean
2015-10-20 20:04 3042FactoryBean 当配置文件中<bean&g ... -
jvm调试命令
2015-10-14 15:42 507jps jps -mlv 列出当前jvm进程 ji ... -
java线程遇见的一个小问题(本质和线程无关都是基础知识)
2015-09-21 10:29 569猜猜下面几个程序,那个是线程安全的 NO1 public cl ... -
JUC--Parser
2015-09-08 16:27 692Java 7的并发包中推出了Phaser,其功能跟Cyclic ... -
JUC--Exchanger
2015-09-07 17:26 897Exchanger 用于线程之间数据交换,通过exchange ... -
java浮点型float遇到的一点问题
2015-04-10 16:32 684float 可以除以0,还可以不是一个数字 即Float.is ... -
java静态块的一个小坑
2015-04-07 18:26 657public class Student { pr ... -
java学习计划
2015-04-07 17:57 437刚入职的时候,team大神给制定的学习计划。 受益匪浅啊 ... -
购物网站(spring+mybatis+velocity+maven)项目
2015-04-03 18:06 1011原文地址: http://www.iteye.com/top ... -
synchronized与static synchronized 的区别
2015-03-25 18:51 722基本上每个面试都问到了,面试命中率很大。 public cl ...
相关推荐
`多线程.docx`可能是关于Java多线程的深入讲解,涵盖线程安全、线程同步、锁的使用等方面。 总之,理解并熟练掌握Java多线程和锁机制对于编写高效、健壮的并发代码至关重要。通过实践和案例学习,可以更好地理解...
CAS(Compare and Swap)是一种无锁算法,在不使用锁的情况下实现多线程之间的变量同步。其工作原理是:比较变量的期望值和实际值是否一致,如果一致,则更新为新值;如果不一致,则不做任何操作。 #### 三、实战...
Java的并发模型就是基于线程的,它利用了Java内存模型(JMM)和特定的并发工具类,如`synchronized`关键字、`volatile`变量以及`java.util.concurrent.atomic`包下的原子类,来确保线程安全。 `java.util....
- **线程基本概念:** Java线程是程序执行流的最小单元,一个线程包含一个程序计数器(PC)、虚拟机栈、本地方法栈、线程私有的工作内存。 - **线程生命周期:** 包括`NEW`、`RUNNABLE`、`BLOCKED`、`WAITING`、`...
3. **获取锁**:使用循环 CAS(Compare and Swap)操作来尝试获取锁,当锁状态为0并且当前线程未持有锁时,将状态设为1并记录线程信息。如果锁已被其他线程持有,进入等待状态。 4. **释放锁**:释放锁时,首先检查...
一个进程中可以有多个线程,它们共享同一内存空间,互相之间可以直接通信,但每个线程都有自己独立的程序计数器、栈和局部变量。 2. **同步与互斥**:在并发环境中,数据共享可能导致数据不一致问题。为了解决这个...
书中从并发性和线程安全性的基本概念出发,介绍了如何使用类库提供的基本并发构建块,用于避免并发危险、构造线程安全的类及验证线程安全的规则,如何将小的线程安全类组合成更大的线程安全类,如何利用线程来提高...
- 高效的线程安全的哈希表。 - 使用分段锁技术,将数据分成若干段,每段使用一个锁。 - **应用场景**: - 适合大量读取操作,少量写入操作的场景。 #### 二十二、volatile关键字的理解 - **作用**: - 保证了...
StringBuffer线程安全,在多线程环境中使用。 【不可变类实现】 实现不可变类的关键在于确保对象一旦创建后,其状态不能改变。这通常要求类的成员变量为final,不提供修改状态的方法,并且构造函数完成所有初始化...
在Java编程领域,`java.util.concurrent`包是并发编程的核心工具包,提供了高效、线程安全的类和接口,使得开发者能够更容易地处理多线程环境。本篇将深入探讨这个包中一些鲜为人知的知识点,以帮助你提升并发编程的...
`AtomicLong`类使用CAS操作来保证线程安全地修改长整型变量。 #### Java指令重排序 指令重排序是指编译器或处理器为了优化程序性能而改变指令的执行顺序。这可能会导致程序的行为不符合编写者的预期。Java通过...
其中,方法区存储类信息,堆是对象实例的存储区域,虚拟机栈处理方法调用,本地方法栈支持JNI,程序计数器记录当前线程执行的指令地址。 2. **内存管理** - **垃圾收集**:JVM自动管理内存,通过GC(垃圾收集器)...
HashMap不是线程安全的,ConcurrentHashMap在Java 8中放弃了分段锁,改为使用CAS和synchronized实现更高的并发性能。 6. **反射机制**:反射可以让我们在运行时检查类的信息,动态创建对象,调用方法等。Class.for...
5. **Atomic原理**:Java中的Atomic类利用CAS(Compare and Swap)无锁算法来保证操作的原子性,从而在多线程环境下实现高效的数据同步。 6. **sleep()与wait()的区别**:sleep()使当前线程暂停指定时间,不会释放...
- **CountDownLatch**用于同步多个线程,当计数器达到0时,所有等待的线程都会被释放。 - **Semaphore**用于控制对资源的并发访问数量,可通过信号量机制实现。 ### JVM与类加载 #### 11. Synchronized的偏向锁、...
- **ConcurrentHashMap的工作原理及代码实现**:通过分段锁实现并发控制,使用CAS和volatile保证线程安全。 - **手写简单的HashMap**:实现基本的put和get方法,了解哈希函数和链表的使用。 - **看过那些Java集合...
10. ArrayList线程不安全,Vector线程安全,但性能较低。 11. Array是固定大小的原始类型数组,ArrayList是动态扩容的Object数组。 12. Queue中的`poll()`移除并返回头元素,`remove()`移除但抛出异常如果没有元素。...