??xml version="1.0" encoding="utf-8" standalone="yes"?>国产中文在线观看,超碰在线亚洲,国产第一页在线视频http://www.aygfsteel.com/CreJavasky/articles/88014.html桥 水桥 水Fri, 15 Dec 2006 09:48:00 GMThttp://www.aygfsteel.com/CreJavasky/articles/88014.htmlhttp://www.aygfsteel.com/CreJavasky/comments/88014.htmlhttp://www.aygfsteel.com/CreJavasky/articles/88014.html#Feedback0http://www.aygfsteel.com/CreJavasky/comments/commentRss/88014.htmlhttp://www.aygfsteel.com/CreJavasky/services/trackbacks/88014.html2Q? JVM中内存的划分

  垃圾攉器对JavaE序员来_基本上是透明的,但是只有了解GC的工作原理、如何优化GC的性能、如何与GCq行有限的交互,才能提高整个应用E序的性能、全面提升内存的理效率,Z说明其工作方式,我们首先看看内存中几U常用的存放数据的地方:

  (1) 堆栈QStackQ:位于常规RAMQ随问存储器Q区域,但可通过它的“堆栈指针”获得处理器的直接支持。堆栈指针若向下U,会创建新的内存;若向上移Q则会释N些内存。这是一U特别快、特别有效的数据保存方式Q仅ơ于CPU的寄存器。创建程序时QJava~译器必d地知道堆栈内保存的所有数据的“长度”以及“存在时间”。这是由于它必须生成相应的代码,以便向上和向下移动指针。这一限制无疑影响了程序的灉|性,所以尽有些Java数据要保存在堆栈?-特别是对象的引用Q也可称为对象的引用变量Q,但Java中的对象不会攑֜其中?

  (2) 堆(HeapQ。一U常规用途的内存池(也在RAM区域Q,其中保存了Java对象。和堆栈不同Q“内存堆”或“堆”(HeapQ最吸引人的地方在于~译器不必知道要从堆里分配多存储空_也不必知道存储的数据要在堆里停留多长的时间。因此,用堆保存数据时会得到更大的灵zL。要求创Z个对象时Q只需用new命o~制相关的代码即可。执行这些代码时Q会在堆里自动进行数据的保存。当Ӟ到这U灵zL,必然会付Z定的代h(hun)Q在堆里分配存储I间时会花掉更长的时_q是DJava性能不佳的因素之一?

  SUN的JVM使用分代方式QGenerationQ管理堆I间Q“代”分配给新旧对象的内存池。这些对象的不断U篏会导致一个的内存状态,从而推动垃圾收集的开始。如图说明了SUN的JVM中堆I间_略的划分?

  q轻的一代包括年ȝ对象I间QedenQ和两个存活QsurvivorQ空_SS#1和SS#2Q。新对象被分配到eden中,那些存活较久的对象则会从q轻的一代{Ud老一代中。图中的PermD叫做永久代Qpermanent generationQ,它保存了JVM的类和方法对象?

  (3) 静态存储(StaticQ。这儿的“静态”(StaticQ是指“位于固定位|”(管也在RAM里)或是有且仅有一份。程序运行期_静态存储的数据随时等候调用。可用static关键字指Z个对象的特定元素是静态的。但Java对象本n永远都不会置入静态存储空间?

   2Q? 对象在内存中的分配?

  了解了内存中q些存放数据的方式后Q我们先来看看C++中存攑֯象的机制Q在C++中,对象可以是在堆栈中创建的Q这样可辑ֈ更快的速度。然而,在C++里创建“内存堆”(HeapQ对象通常会慢得多。这U内存堆实际是一个大的内存池Q要求必进行再循环Q再生)。这里可以把C++的Heap惌是一块场圎ͼ在这里面中每个对象不断监视属于自q地盘Q他们可能在以后的某个时M再l占用目前所占用的空_即释攑֐的内存会在堆里留下一个洞Q所以再调用new的时候,存储分配机制必须q行某种形式的搜索,使新对象能够利用已经存在的空z,否则׃很快用光堆的存储I间。之所以内存堆的分配会在C++里对性能造成如此重大的性能影响Q对可用内存的搜索正是一个重要的原因。所以创建基于堆栈的对象要快得多?

  而在Java中的内存堆(HeapQ更像一条传送带Q每ơ分配了一个新对象后,“Heap指针”都会朝前移动,q意味着对象存储I间的分配可以达到非常快的速度。因为“Heap指针”只是单U的往前移动至未经分配的区域,所以它与C++的堆栈分配方式几乎是不相上下的(当然Q在数据记录上会多花一些开销Q但要比搜烦存储I间快多了)。但是如果只是按那种方式分配Q最l就要求q行大量的内存页面交换(q对性能的发挥会产生巨大q扰Q,而且l究会用光内存,出现内存分页错误Qpage faultQ。所以Java引入了“垃圾收集器”。它在收集“垃䏀的同时Q也负责重新紧密排列QcompactQ堆里的所有对象,消除内存I洞Q将“堆指针”移臛_可能靠近传送带开头的地方Q远d生(内存Q分错误的地点。垃圾收集器会重新安排所有东西,使其成ؓ一个高速、无限自q堆模型,同时游刃有余地分配存储空间。但是垃圾收集时的代h非常高昂的,q也是导致Java性能不佳的因素之一?br />


桥 水 2006-12-15 17:48 发表评论
]]>
转: Java 容器http://www.aygfsteel.com/CreJavasky/articles/87959.html桥 水桥 水Fri, 15 Dec 2006 07:40:00 GMThttp://www.aygfsteel.com/CreJavasky/articles/87959.htmlhttp://www.aygfsteel.com/CreJavasky/comments/87959.htmlhttp://www.aygfsteel.com/CreJavasky/articles/87959.html#Feedback0http://www.aygfsteel.com/CreJavasky/comments/commentRss/87959.htmlhttp://www.aygfsteel.com/CreJavasky/services/trackbacks/87959.html  Array的长度是固定的且无法动态改变其长度Q也是说定义大后Q此变量的大不可以再改变了Q但它是最有效的一个容器,存取速度相当快?/div>
 
  Array对象用length成员q行计算元素个数Q通过[]来取用数据,array对象无法判断元素个数Q只能计其定w?/div>
 
  ArraycL有一lstatic函数Qequals(),fill(),sort(),binary(),
 
  Array复制System.arrayCopy().
 
  compareTo()接受一个对象引敎ͼ此引数大于自己时q回负|相等时返回零Q小于时q回正倹{?/div>
 
 
  Java中的最关键的三个容器接口(list,set,mapQ?
 
  List是一个interface
 
  List以元素按插次序来攄元素Q不会重新排列?/div>
 
  ArrayList以Array实现完成的ListQ允许快速随问。如果只是简单地存取数据Q而不对其中的数据q行有序插入使用此容器会很方便且速度很快。LinkList提供最?jng)_@序访问,haddFirst(),addLast(),getFirst(),getLast(),removeFirst(),removeLast()Q如果需要在队列中插入一些数据,可用此容器。由于其list的灵zL,在各U程序中使用的比较多?/div>
 
 
  Set是一个Collection 不接受重复元素,它用自己内部的一个排列机制?/strong>
 
  Set拥有和Collection一L(fng)interfaces
 
  HashSet注重查找旉Q所有元素必d义hashCode();对自׃的数据不q行有序排列Q按照加入的先后ơ序q行排列?/div>
 
  TreeSet底层l构为tree的一U有序Set. 内部数据q行有序排列?/div>
 
 
  Map也不接受重复元素Q重复与否以键|keyQ判断,它拥有自q内部排列机制?/div>
 
  ArrayList使用数字来选择|而Map使用另一个对象来取倹{?/div>
 
  Map用putValue值加入,用get()传回key对应的value?/div>
 
  使用containsKey()和containsValue()来检查map内是否含有某个key或某个value?/div>

 
  Map包括两个mapsQHashMap,TreeMap
 
  HashMap会运用对象的hashCode()q利用它来快速找到keyQ带来巨q的效率提升。HashMap取代了Java2中的HashTable容器?/div>
 
  TreeMapZU黑?wi)完成的一个实现品Q它的数据按ơ序排列q惟一拥有subMap(),此函数返回tree中的部分l成?/div>
 
 
  容器的填?/strong>
 
  ArrayList?add()Ҏ(gu)q行数据的增加。容器有个Collections ClassQ含有一些static函数Q比如fill()Q它?yu)用一个object reference 复制到容器的每个位置上(只能list有用Q?x原先的D盖掉Q此函数用处不大?/div>
 
 
  q代器Iterator
 
  q代器是个对象,其职责便是走访以及选择序列中的一q串对象QP代器是“轻量”对晚,产生的代h?/div>
 
  W一ơ调用Iterator的next()Ӟq回序列中的W一个元素?/div>
 
  调用next()取得序列中的下一个元素?/div>
 
  调用hasNext()查序列是否还有其它元素?/div>
 
  调用remove()Udq代器最C回的元素?/div>
 
 
  外引Q?/strong>
 
  C++中的vector容器知道他所持有的对象隶属型别,但不q行边界查,而Java中的容器都进行了边界查,一旦越界即报RuntimeException。边界检查会带来额外的效率负担?/div>
 
  Java中的容器可以持有JavaM对象Q基本型别除外)?一旦将对象装入容器Q其型别׃丢失Q当你用的时候,必须先进行{型?/div>

桥 水 2006-12-15 15:40 发表评论
]]> վ֩ģ壺 | | | | ܱ| | ͭϿ| | | | ɽ| | | | | | | | ʯ̨| ƽ| | ˮ| | ʯ| | | ӱ| | ƽ| ľ| ƽ| | | | μԴ| Ұ| Ƽ| ¡| | | ƽ|