File tree 1 file changed +25
-1
lines changed
1 file changed +25
-1
lines changed Original file line number Diff line number Diff line change @@ -147,7 +147,31 @@ public class GCTest {
147
147
148
148
### 1.4 动态对象年龄判定
149
149
150
- 为了更好的适应不同程序的内存情况,虚拟机不是永远要求对象年龄必须达到了某个值才能进入老年代,如果 Survivor 空间中相同年龄所有对象大小的总和大于 Survivor 空间的一半,年龄大于或等于该年龄的对象就可以直接进入老年代,无需达到要求的年龄。
150
+
151
+ 大部分情况,对象都会首先在 Eden 区域分配,在一次新生代垃圾回收后,如果对象还存活,则会进入 s0 或者 s1,并且对象的年龄还会加 1(Eden 区->Survivor 区后对象的初始年龄变为 1),当它的年龄增加到一定程度(默认为 15 岁),就会被晋升到老年代中。对象晋升到老年代的年龄阈值,可以通过参数 ` -XX:MaxTenuringThreshold ` 来设置。
152
+
153
+ > 修正([ issue552] ( https://github.com/Snailclimb/JavaGuide/issues/552 ) ):“Hotspot遍历所有对象时,按照年龄从小到大对其所占用的大小进行累积,当累积的某个年龄大小超过了survivor区的一半时,取这个年龄和MaxTenuringThreshold中更小的一个值,作为新的晋升年龄阈值”。
154
+ >
155
+ > ** 动态年龄计算的代码如下**
156
+ >
157
+ > ``` c++
158
+ > uint ageTable::compute_tenuring_threshold (size_t survivor_capacity) {
159
+ > //survivor_capacity是survivor空间的大小
160
+ > size_t desired_survivor_size = (size_t)((((double) survivor_capacity)* TargetSurvivorRatio)/100);
161
+ > size_t total = 0;
162
+ > uint age = 1;
163
+ > while (age < table_size) {
164
+ > total += sizes[ age] ;//sizes数组是每个年龄段对象大小
165
+ > if (total > desired_survivor_size) break;
166
+ > age++;
167
+ > }
168
+ > uint result = age < MaxTenuringThreshold ? age : MaxTenuringThreshold;
169
+ > ...
170
+ > }
171
+ >
172
+ > ```
173
+ >
174
+ >
151
175
152
176
153
177
## 2 对象已经死亡?
You can’t perform that action at this time.
0 commit comments