- 浏览: 209412 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (391)
- java (18)
- python (3)
- ruby (4)
- linux (48)
- 网络 (9)
- 前端 (2)
- 社会、文化、哲学、人生、百态 (0)
- 工具 (10)
- 下载 (0)
- 常用地址 (0)
- tracert (0)
- mysql (8)
- 开源相关收藏 (1)
- 模块查看依懒 (1)
- watch使用 (1)
- Tcpdump (2)
- easy_install安装 (1)
- 构造redis批量删除脚本 (1)
- MYSQL 性能测试 (1)
- JAVA code encode utf-8 (1)
- linux nginx awk 实时 每妙 (1)
- mkpasswd (1)
- spring security oauth (1)
- jmap dump java memory Analyzer (1)
- JAVA DUMP (1)
- swap linux 过高 解决 (1)
- SWAP (1)
- jmap jstat jstack dump (1)
- java jconsole 的使用 (1)
- git 常用 (1)
- MYSQL 索引 动态 唯一 (1)
- TCP 三次握手 四次挥手 (1)
- linux date (1)
- 删除 空行 注释行 (1)
- maven3 yum linux install repository (1)
- linux git 搭建 (1)
- linux sar eth1 查看 流量 (1)
- sar (1)
- netstat ip 过滤 常用脚本 (1)
- Tcpdump 包分析网络连接过程 (1)
- net ipv4 tcp time wait tw recycle (0)
- /etc/sysctl.conf linux 网络 配置 (1)
- ss 网络连接查看 (比netstat 快很多,实时性牺牲) (1)
- MYSQL 关键字 (1)
- Linux 下多核CPU知识 (1)
- top (1)
- 令牌 证书 (1)
- mysql unix timestamp (1)
- 端口扫描 nc nmap (1)
- 204 http code 状态码 (1)
- ss -s ss -l (1)
- linux 常用 curl (1)
- linux sed 替换 换行 (1)
- centos yum install rpm install (1)
- spring-mvc源码解读 (1)
- 使用iftop查看实时的网络流量 (0)
- linux 命令 expect (1)
- HTTP (1)
- openssl ddif 加密 (1)
- iptables 详解 (1)
- python 虚拟化 VirtualEnv virtualenvwrapper (1)
- nginx (2)
- more less 实用技巧 (1)
- linux nginx (2)
- linux curl https ssl 证书 ca (1)
- openssl (1)
- php mysql linux (1)
- linux 虚拟机 虚拟 xen (0)
- linux 虚拟机 虚拟 xen kvm (1)
- linux perl 单行执行技巧 (1)
- mysql 查看库占用空间 表查用空间 (1)
- linux tcpdump (1)
- maven (1)
- sun.misc.Unsafe (1)
- OpenSSL生成证书 (1)
- http://blog.csdn.net/zzulp/article/details/8018751 (1)
- maven 本地 jar dependency (1)
- 计算JAVA代码行数最简单命令 sed (1)
- 常用的证书格式转换 rsa eg (1)
- 加密 解密 签名 (1)
- 分析jar包冲突 (1)
- 使用JMockit编写java单元测试 (1)
- Linux 技巧:让进程在后台可靠运行的几种方法 (1)
- 环境变量控制 (1)
- 5+ 个 tar 命令的用法,附示例 (1)
- scp自动输入密码 (1)
- ps axo pid (1)
- ppid (1)
- comm (1)
- pmem (1)
- lstart|grep mysql (0)
- lstart (1)
- etime|grep mysql (1)
- UML类图字少好理解 (1)
- HTTP经典文章 (1)
- git (1)
- Git常用命令 (1)
- LINUX 系统被攻击的分析过程 (1)
- NIO (1)
- LINUX 操作快捷键使用 (1)
- openSSL命令、PKI、CA、SSL证书原理 (1)
- shell (2)
- 转载 (1)
- mysqldump 可以直接dump->xml (1)
- VIM比较全面的文章 (1)
- eclipse regex 正则表达式 (1)
- synchronized (1)
- 锁 (1)
- java 正则表达式 regex (1)
- Reference Queue 引用 源码 (1)
- spring aop 源码 分析 (1)
- java @Cache @Transaction 注解 (1)
- spring aop (1)
- spring jdk proxy cglib 动态代理 性能比较 (1)
- spring proxy private public 代理限制 (1)
- spring transaction aop 事务 (1)
- spring autowire 注解注入 (1)
- 桥接 NAT NAT地址转换 内部网络 虚拟网络 (1)
- spring-web-mvc 源码解读 之 RequestMappingHandlerMapping (1)
- find atime mtime ctime -n n +n (1)
- android studio 快捷键初探 (1)
- android 源码阅读的计划 (1)
- 计算机网络学习-VLAN (1)
- sed 高级 合并行 (1)
- CAP 一致性 可用性 分布式容错性 (1)
- android lib so 库文件 (0)
- android lib so 库文件 移植 (1)
- android 不错的博文 (1)
- sourceinsight 源码 阅读 (1)
- Android Tab UI (1)
- 诗 (1)
- mysql 批处理 (0)
- netty 堆外内存 DirectByteBuffer (1)
- netty 并发 百万 推送 (1)
- Linux操作系统中内存buffer和cache的区别 (1)
- maven intellij target bytecode version (1)
- linux sleep()的实现原理 (1)
- android (2)
- javadoc 代码注释规范 (1)
- spring 自动注入bean auto (1)
- Photoshop CS6常用快捷键 (1)
- 股票 数据 机器 分析 (1)
- 批处理 (1)
- mysql -e (1)
- char (1)
- Unicode (1)
- 编码 (1)
- utf8 (1)
- utf-8 (1)
- utf16 (1)
- utf-16 (1)
- IntelliJ IDEA (1)
- ide (1)
- idea (1)
- intellij (1)
- 文件 (1)
- 目录 (1)
- 源代码 (1)
- CountDownLatch (1)
- CyclicBarrier (1)
- Semaphore (1)
- spring (1)
- linux 查看不同进制文件 (1)
- WebMvcConfigurationSupport (1)
- sdkman工具的使用 (1)
- http header (1)
- LINUX系统优化 (1)
最新评论
-
gelongmei:
威武我大酒神
shell脚本不换行刷新数据
http://www.cnblogs.com/tianchi/archive/2013/02/27/2935695.html
Java不能直接访问操作系统底层,而是通过本地方法来访问,Unsafe提供了硬件级别的原子操作,提供了以下功能:
分配、释放内存
操作内存主要依靠下面三个方法:
allocateMemory:分配内存;
reallocateMemory:扩充内存;
freeMemory:释放内存;
操作对象的字段
Java对象中字段的定位可以通过staticFieldOffset实现,而读取具体便宜位置的字段的值可以使用getLong(根据不同类型选择不同的函数)来完成,可以使用putLong(根据不同的类型选择不同的函数)来设置值,可以使用arrayBaseOffset(获取数组第一个元素的偏移地址)和arrayIndexScale(获取数组中元素增量的地址)来访问数组中的元素。
CAS操作
CAS操作(会在java.util.concurrent中大量地使用)包括三个操作数:
内存位置;
预期原值;
新值;
如果内存位置的值与预期的值相等,那么处理器会将该位置的值设置为新值,否则,处理器不做任何处理。int类型的CAS实现如下:
复制代码
static inline bool compareAndSwap (volatile jint *addr, jint old, jint new_val)
{
jboolean result = false;
spinlock lock;
if ((result = (*addr == old)))
*addr = new_val;
return result;
}
复制代码
这段代码看起来根本无法保证操作的原子性,而其中的关键就在于spinlock lock这段看似没有用的代码,这时会调用构造函数,其中不停检查lock的值是否为0,如果不是0则线程让步等到线程下次执行时再次检查;否则,将lock设置为1。在离开函数的时候会调用其析构函数,将lock的值再次设置为0。spinlock的代码如下:
复制代码
class spinlock
{
static volatile obj_addr_t lock;
public:
spinlock ()
{
while (!compare_and_swap(&lock, 0, 1))
_Jv_ThreadYield();
}
~spinlock ()
{
release_set(&lock, 0);
}
};
复制代码
而且,不管是在多核还是在单核的情况下,总是需要一些特殊的手段才能保证CAS操作成功吧,比如锁总线,compare_and_swap的实现如下:
复制代码
inline static bool compare_and_swap(volatile obj_addr_t *addr, obj_addr_t old, obj_addr_t new_val)
{
char result;
#ifdef __x86_64__ __asm__ __volatile__("lock; cmpxchgq %2, %0; setz %1"
: "=m"(*(addr)), "=q"(result)
: "r" (new_val), "a"(old), "m"(*addr)
: "memory");
#else
__asm__ __volatile__("lock; cmpxchgl %2, %0; setz %1"
: "=m"(*addr), "=q"(result)
: "r" (new_val), "a"(old), "m"(*addr)
: "memory");
#endif
return (bool) result;
}
复制代码
挂起和恢复
使用park方法将一个线程挂起,知道超时或者中断等条件出现,实现如下:
复制代码
void sun::misc::Unsafe::park(jboolean isAbsolute, jlong time)
{
using namespace ::java::lang;
Thread *thread = Thread::currentThread();
natThread *nt = (natThread *) thread->data;
nt->park_helper.park(isAbsolute, time);
}
复制代码
使用unpark来终止一个挂起的线程,使其恢复正常,实现如下:
sun::misc::Unsafe::unpark (::java::lang::Thread *thread)
{
natThread *nt = (natThread *) thread->data;
nt->park_helper.unpark ();
}
----- -- -
END
Java不能直接访问操作系统底层,而是通过本地方法来访问,Unsafe提供了硬件级别的原子操作,提供了以下功能:
分配、释放内存
操作内存主要依靠下面三个方法:
allocateMemory:分配内存;
reallocateMemory:扩充内存;
freeMemory:释放内存;
操作对象的字段
Java对象中字段的定位可以通过staticFieldOffset实现,而读取具体便宜位置的字段的值可以使用getLong(根据不同类型选择不同的函数)来完成,可以使用putLong(根据不同的类型选择不同的函数)来设置值,可以使用arrayBaseOffset(获取数组第一个元素的偏移地址)和arrayIndexScale(获取数组中元素增量的地址)来访问数组中的元素。
CAS操作
CAS操作(会在java.util.concurrent中大量地使用)包括三个操作数:
内存位置;
预期原值;
新值;
如果内存位置的值与预期的值相等,那么处理器会将该位置的值设置为新值,否则,处理器不做任何处理。int类型的CAS实现如下:
复制代码
static inline bool compareAndSwap (volatile jint *addr, jint old, jint new_val)
{
jboolean result = false;
spinlock lock;
if ((result = (*addr == old)))
*addr = new_val;
return result;
}
复制代码
这段代码看起来根本无法保证操作的原子性,而其中的关键就在于spinlock lock这段看似没有用的代码,这时会调用构造函数,其中不停检查lock的值是否为0,如果不是0则线程让步等到线程下次执行时再次检查;否则,将lock设置为1。在离开函数的时候会调用其析构函数,将lock的值再次设置为0。spinlock的代码如下:
复制代码
class spinlock
{
static volatile obj_addr_t lock;
public:
spinlock ()
{
while (!compare_and_swap(&lock, 0, 1))
_Jv_ThreadYield();
}
~spinlock ()
{
release_set(&lock, 0);
}
};
复制代码
而且,不管是在多核还是在单核的情况下,总是需要一些特殊的手段才能保证CAS操作成功吧,比如锁总线,compare_and_swap的实现如下:
复制代码
inline static bool compare_and_swap(volatile obj_addr_t *addr, obj_addr_t old, obj_addr_t new_val)
{
char result;
#ifdef __x86_64__ __asm__ __volatile__("lock; cmpxchgq %2, %0; setz %1"
: "=m"(*(addr)), "=q"(result)
: "r" (new_val), "a"(old), "m"(*addr)
: "memory");
#else
__asm__ __volatile__("lock; cmpxchgl %2, %0; setz %1"
: "=m"(*addr), "=q"(result)
: "r" (new_val), "a"(old), "m"(*addr)
: "memory");
#endif
return (bool) result;
}
复制代码
挂起和恢复
使用park方法将一个线程挂起,知道超时或者中断等条件出现,实现如下:
复制代码
void sun::misc::Unsafe::park(jboolean isAbsolute, jlong time)
{
using namespace ::java::lang;
Thread *thread = Thread::currentThread();
natThread *nt = (natThread *) thread->data;
nt->park_helper.park(isAbsolute, time);
}
复制代码
使用unpark来终止一个挂起的线程,使其恢复正常,实现如下:
sun::misc::Unsafe::unpark (::java::lang::Thread *thread)
{
natThread *nt = (natThread *) thread->data;
nt->park_helper.unpark ();
}
----- -- -
END
发表评论
-
代码沉淀
2018-01-17 10:08 5461、如果一个代码片段是抽象的,那意味着它是可以有多种实现的,那 ... -
java.nio.file.StandardOpenOption
2018-01-04 11:19 845java.nio.file.StandardOpenOptio ... -
char类型与Unicode编码
2017-12-27 17:12 545char类型与Unicode编码 Unicode(UTF-8, ... -
javadoc 规范
2017-03-06 13:12 501http://www.cnblogs.com/felix-/ ... -
Java Socket 几个重要的TCP/IP选项解析
2015-12-15 17:02 527http://elf8848.iteye.com/blog/1 ... -
ReentrantLock可重入锁的使用场景
2015-05-05 13:45 567JAVA锁 从使用场景的角度出发来介绍对ReentrantLo ... -
Java ClassLoader详解
2015-04-07 16:27 491http://xjtom78.iteye.com/blog/8 ... -
JVM参数设置、分析
2014-12-01 19:11 0转自http://itlab.idcquan.com/Java ... -
java原生工具常用命令
2014-10-09 14:59 408jmap -histo pid [实体化情况] jstat ... -
jstat 详细使用
2014-07-16 10:01 642jstat分析VM内存 from:ht ... -
JavaWeb的各种中文乱码终极解决方法
2014-06-12 17:16 521一、Servlet输出乱码 1. 用servlet.getOu ... -
scala环境
2014-06-10 19:05 466http://download.scala-ide.org/e ... -
sonar忽略
2014-06-10 16:54 1156<properties> <aider. ... -
java AES 命令行 报错处理
2014-04-01 11:24 561java.security.NoSuchAlgorithmEx ... -
JVM内核参数说明
2014-03-12 02:14 549java虽然是自动回收内存,但是应用程序,尤其服务器程序最好根 ... -
jmap常用
2014-02-14 17:02 425SYNOPSIS jmap [ option ] pid ... -
JAVA GC详细说明
2014-01-06 13:54 4191.java中GC 即垃圾收集机制是指jvm用于释放那 ... -
JAVA中的GC
2014-01-03 20:34 01.java中GC 即垃圾收集机制是指jvm用于释放那 ... -
JAVA GC详细说明
2014-01-03 20:32 0http://www.360doc.com/content/1 ... -
分析包冲突命令
2013-12-31 16:43 409分析jar包冲突 ls|awk '{a=system(&quo ...
相关推荐
《深入解析Java sun.misc.Unsafe》 在Java编程语言中,`sun.misc.Unsafe`类是一个神秘而强大的工具,它提供了对内存的直接操作和访问,绕过了Java的一些安全限制。这个类通常不被推荐在生产环境中直接使用,因为它...
Field theUnsafe = Unsafe.class.getDeclaredField("theUnsafe"); theUnsafe.setAccessible(true); Unsafe unsafe = (Unsafe) theUnsafe.get(null); ``` 三、主要方法解析 1. **内存操作**:UnSafe提供了内存分配...
JDK8中sun.misc包下的UnSafe类,想查看源码的就拿走,没积分的请与我联系!xtfggef@gmail.com
Field f = Unsafe.class.getDeclaredField("theUnsafe"); f.setAccessible(true); Unsafe unsafe = (Unsafe) f.get(null); ``` 这种做法可能会在编译时产生警告,但可以通过调整IDE的配置来允许。 3. **...
unsafe-helper-包含一些简单的方法,这些方法使使用sun.misc.Unsafe更容易。 unsafe-collection-在ArrayList上建模的示例列表,该列表不存储对集合内对象的引用,而是直接将元素复制到列表中。 这有一些有趣的特性...
在早期版本中,MapDB 曾利用 `sun.misc.Unsafe` 类来优化内存管理和性能。`sun.misc.Unsafe` 是一个非常底层的 API,它允许 Java 程序员执行一些通常被认为是不安全或者不推荐的操作,如直接内存访问和对象字段的非...
例如,`sun.misc.Unsafe`类提供了对内存操作的直接访问,这是Java语言规范中没有定义的,但它在高性能和低级别的系统操作中起着关键作用。通过研究`sun`包的源码,我们可以更深入地理解JVM的工作机制。 接下来,`...
`unsafe`通常指的是`sun.misc.Unsafe`类,这是一个强大的内部类,它提供了一些直接内存操作和低级资源管理的接口。这些功能包括非受检类型转换、对象字段的直接访问、内存分配和释放等。`Unsafe`类虽然强大,但也很...
`sun.misc.Unsafe`类是一个特殊的存在,它提供了对Java内存模型的直接访问,尽管不建议在普通应用中使用,但在一些高性能或底层操作的场景下可能会用到。 5. **网络编程**:`sun.net`包包含了网络协议的实现,如TCP...
例如,`sun.misc.Unsafe`类提供了许多非安全但高效的原生操作,如内存分配、原子操作等。尽管不推荐直接使用,但在高性能或低级别编程场景中,这些功能有时是必需的。 3. **编译器和JIT(Just-In-Time)优化**: ...
例如,`sun.misc.Unsafe`类提供了对内存操作的直接访问,这在某些高效率的数据结构实现中非常有用。 本压缩包提供的JDK源码包含了`sun`包,这意味着你可以研究诸如`sun.nio`(非阻塞I/O)、`sun.jdbc`(数据库连接...
《深入理解Java中的sun.misc.Unsafe工具》 在Java编程领域,`sun.misc.Unsafe`是一个神秘而强大的工具类,它提供了对Java内存模型的直接访问,包括堆外内存操作和字节数组的高效处理。`gate-core-8.0.zip`与`unsafe...
`sun`包是OpenJDK的核心组件之一,它包含了许多私有和内部使用的类,如`sun.misc.Unsafe`和`sun.misc.Cleaner`。 二、"sun.misc"包详解 1. `sun.misc.Unsafe`: 这个类是Java中的一个神器,它提供了一系列底层操作...
1. `sun.misc.Unsafe`:这个类提供了对内存的直接操作,包括对象字段的读写、内存分配和释放等。它绕过了Java的正常安全检查,因此使用时需谨慎。 2. `sun.nio.ch`包:包含了与操作系统I/O密切相关的类,如...
- **sun.misc**:这个包包含了一些工具类和JVM相关的辅助类,如`sun.misc.Unsafe`,这是一个非常强大的类,可以访问和修改Java对象的内存,执行低级别的操作,但使用需谨慎。 - **sun.nio**:提供了非阻塞I/O的...
在IT行业中,视频监控系统是安全领域不可或缺的一部分,而大华作为知名的监控设备制造商,提供了丰富的SDK(Software Development Kit)供开发者集成其设备到自定义系统中。本篇将详细探讨"大华视频监控java示例demo...
Java中的`sun.misc.Unsafe`类是一个特殊的存在,它提供了对Java语言规范中未公开的底层操作的访问。自Java 1.4起,Unsafe就成为了一种强大的工具,允许开发人员执行一些Java语言不直接支持但又非常有用的任务。然而...
Field field = sun.misc.Unsafe.class.getDeclaredField("theUnsafe"); field.setAccessible(true); return (Unsafe) field.get(null); } public static void main(String[] args) { // 创建一个示例对象 ...
在JDK1.8中,`sun`包的源码可以让我们深入了解Java运行时的细节,例如`sun.misc.Unsafe`类,它是许多高级技术如内存操作和并发工具的基础。然而,需要注意的是,`sun`包中的类并不是Java标准API的一部分,可能在不同...
UNSAFE = sun.misc.Unsafe.getUnsafe(); headOffset = UNSAFE.objectFieldOffset(TransferStack.class.getDeclaredField("head")); } catch (Exception e) { throw new Error(e); } } boolean casHead(SNode h,...