Java中的Unsafe 类 概述

本文探讨了Java unsafe在高性能IO框架如JUC、CurrentHashMap和Netty中的应用,涉及内存操作、cas、Class操作、对象和数组操作,以及内存屏障、线程调度和系统相关知识。警告读者谨慎使用以防内存泄漏,揭示了底层编程的复杂性和技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用unsafe类 在juc 包 以及CurrentHashMap 以及Netty 等高性能IO框架中应用广泛。但是对于普通程序员来说应该谨慎使用,防止内存泄漏。

1、内存操作

unsafe.allocateMemory(long bytes);
/*o == null 时 offset 就是绝对偏移量 初始化字节数为 bytes 值为value*/
unsafe.setMemory(Object o,long offset,long bytes,byte value);

unsafe.freeMemory(long l);

2、cas

unsafe.compareAndSwapInt(Object o,long offset,int expected,int update);

3、Class 相关

public native Object unsafe.staticFieldBase(Field f);
public native long unsafe.staticFieldOffset(Field f);//获取相对偏移量
public native Class<?>  unsafe.defineCalss()//获取Class实例

4、对象操作

unsafe.objectFieldOffset(Field f);
unsafe.allocateInstance(Class<?> class)//创建一个类的实例,不需要使用其构造函数、初始化等。
unsafe.putInt(Object,long offset,int x);
unsafe.getInt(Object o,long offset);

5、数组操作

unsafe.arrayBaseOffset(Class<?> aClass);//数组偏移
unsafe.arrayIndexScale(Class<?> aClass)//返回数组中一个元素占用大小

6、内存屏障
内存屏障是cpu 或者编译器随机访问内存的一个同步点,该同步点之前的读写操作完成之后才能进行同步点之后的读写操作,防止编译器的激进优化,指令重排序。可以防止线程工作区数据和内存数据不一致的问题。

loadFence();
storeFence();
fullFence();

7、线程调度

unsafe.park();//注意不会主动释放锁 挂起当前线程
unsafe.unpark(Thread t1);//使得t1线程恢复执行

8、系统相关

unsafe.addressSize();// 64位系统 输出 8
unsafe.pageSize()// 4096
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值