快速业务通道

Eclipse的字符串分区共享优化机制 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-21

Eclipse的字符串分区共享优化机制

时间:2011-01-03

在 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的字符串分区共享优化机制(2)

时间:2011-01-03

对全局字符串表中的字符串,是没有办法显式手动清除的。只能在不使用此字符串后,由垃圾回收线程在进行不可达对象标记时进行分析,并最终调用 StringTable::unlink 方法去遍历清除。

代码:

// // hotspot/src/share/vm/memory/genMarkSweep.cpp // void GenMarkSweep::mark_sweep_phase1(...) {   //...   StringTable::unlink(); } // // hotspot/src/share/vm/memory/symbolTable.cpp // void StringTable::unlink() {   // Readers of the string table are unlocked, so we should only be   // removing entries at a safepoint.   assert(SafepointSynchronize::is_at_safepoint(), "must be at safepoint")   for (stringTableBucket* bucket = firstBucket(); bucket <= lastBucket(); bucket++) {    for (stringTableEntry** p = bucket->entry_addr(

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号