Eclipse的字符串分区同享优化机制[Java编程]
本文“Eclipse的字符串分区同享优化机制[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
在 Java/C# 这样基于引用语义处理字符串的语言中,作为不可变对象存在的字符串,假如内容相同,则可以通过某种机制实现重用.因为对这类语言来说,指向内存中两块内存位置差别内容相同的字符串,与同时指向一个字符串并没有任何辨别.分外是对大量利用字符串的 XML 文件解析近似场所,这样的优化可以很大程度上降低程序的内存占用,如 SAX 解析引擎尺度中就专门定义了一个 http://xml.org/sax/features/string-interning 特点用于字符串重用.
在语言层面,Java/C# 中都直接供应了 String.Intern 的支持.而对 Java 来说,实现上的非常近似.由 String.intern 办法,将当前字符串以内容为键,对象引用为值,放入一个全局性的哈希表中.
代码:
//
// java/lang/String.java
//
public final class String
{
//...
public native String intern(); // 利用 JNI 函数实现以保障效率
}
//
// hotspot/src/share/vm/prims/jvm.cpp
//
JVM_ENTRY(jstring, JVM_InternString(JNIEnv *env, jstring str))
JVMWrapper("JVM_InternString");
if (str == NULL) return NULL;
oop string = JNIHandles::resolve_non_null(str); // 将引用解析为内部句柄
oop result = StringTable::intern(string, CHECK_0); // 举行实际的字符串 intern 操作
return (jstring) JNIHandles::make_local(env, result); // 获得内部句柄的引用
JVM_END
//
// hotspot/src/share/vm/memory/symbolTable.cpp
//
oop StringTable::intern(oop string, TRAPS)
{
if (string == NULL) return NULL;
ResourceMark rm(THREAD); // 保护线程资源区域
int length;
Handle h_string (THREAD, string);
jchar* chars = java_lang_String::as_unicode_string(string, length); // 获得实际字符串内容
oop result = intern(h_string, chars, length, CHECK_0); // 完成字符串 intern 操作
return result;
}
oop StringTable::intern(Handle string_or_null, jchar* name, int len, TRAPS)
{
int hashValue = hash_string(name, len); // 首先按照字符串内容计算哈希值
stringTableBucket* bucket = bucketFor(hashValue); // 按照哈希值获得目标容器
oop string = bucket->lookup(name, len); // 然后检测字符串能否已经存在
// Found
if (string != NULL) return string;
// Otherwise, add to symbol to table
return basic_add(string_or_null, name, len, hashValue, CHECK_0); // 将字符串放入哈希表
}
以上是“Eclipse的字符串分区同享优化机制[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |