Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
e2af5521
D
dragonwell8_hotspot
项目概览
openanolis
/
dragonwell8_hotspot
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_hotspot
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
e2af5521
编写于
7月 24, 2009
作者:
Y
ysr
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
f610995f
ba324cb0
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
7 addition
and
4 deletion
+7
-4
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
+7
-4
未找到文件。
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
浏览文件 @
e2af5521
...
@@ -1655,9 +1655,8 @@ void G1CollectedHeap::iterate_dirty_card_closure(bool concurrent,
...
@@ -1655,9 +1655,8 @@ void G1CollectedHeap::iterate_dirty_card_closure(bool concurrent,
// Computes the sum of the storage used by the various regions.
// Computes the sum of the storage used by the various regions.
size_t
G1CollectedHeap
::
used
()
const
{
size_t
G1CollectedHeap
::
used
()
const
{
// Temporarily, until 6859911 is fixed. XXX
assert
(
Heap_lock
->
owner
()
!=
NULL
,
// assert(Heap_lock->owner() != NULL,
"Should be owned on this thread's behalf."
);
// "Should be owned on this thread's behalf.");
size_t
result
=
_summary_bytes_used
;
size_t
result
=
_summary_bytes_used
;
// Read only once in case it is set to NULL concurrently
// Read only once in case it is set to NULL concurrently
HeapRegion
*
hr
=
_cur_alloc_region
;
HeapRegion
*
hr
=
_cur_alloc_region
;
...
@@ -2981,6 +2980,7 @@ void G1CollectedHeap::get_gc_alloc_regions() {
...
@@ -2981,6 +2980,7 @@ void G1CollectedHeap::get_gc_alloc_regions() {
for
(
int
ap
=
0
;
ap
<
GCAllocPurposeCount
;
++
ap
)
{
for
(
int
ap
=
0
;
ap
<
GCAllocPurposeCount
;
++
ap
)
{
assert
(
_gc_alloc_regions
[
ap
]
==
NULL
,
"invariant"
);
assert
(
_gc_alloc_regions
[
ap
]
==
NULL
,
"invariant"
);
assert
(
_gc_alloc_region_counts
[
ap
]
==
0
,
"invariant"
);
// Create new GC alloc regions.
// Create new GC alloc regions.
HeapRegion
*
alloc_region
=
_retained_gc_alloc_regions
[
ap
];
HeapRegion
*
alloc_region
=
_retained_gc_alloc_regions
[
ap
];
...
@@ -3009,6 +3009,9 @@ void G1CollectedHeap::get_gc_alloc_regions() {
...
@@ -3009,6 +3009,9 @@ void G1CollectedHeap::get_gc_alloc_regions() {
if
(
alloc_region
==
NULL
)
{
if
(
alloc_region
==
NULL
)
{
// we will get a new GC alloc region
// we will get a new GC alloc region
alloc_region
=
newAllocRegionWithExpansion
(
ap
,
0
);
alloc_region
=
newAllocRegionWithExpansion
(
ap
,
0
);
}
else
{
// the region was retained from the last collection
++
_gc_alloc_region_counts
[
ap
];
}
}
if
(
alloc_region
!=
NULL
)
{
if
(
alloc_region
!=
NULL
)
{
...
@@ -3047,11 +3050,11 @@ void G1CollectedHeap::release_gc_alloc_regions(bool totally) {
...
@@ -3047,11 +3050,11 @@ void G1CollectedHeap::release_gc_alloc_regions(bool totally) {
for
(
int
ap
=
0
;
ap
<
GCAllocPurposeCount
;
++
ap
)
{
for
(
int
ap
=
0
;
ap
<
GCAllocPurposeCount
;
++
ap
)
{
HeapRegion
*
r
=
_gc_alloc_regions
[
ap
];
HeapRegion
*
r
=
_gc_alloc_regions
[
ap
];
_retained_gc_alloc_regions
[
ap
]
=
NULL
;
_retained_gc_alloc_regions
[
ap
]
=
NULL
;
_gc_alloc_region_counts
[
ap
]
=
0
;
if
(
r
!=
NULL
)
{
if
(
r
!=
NULL
)
{
// we retain nothing on _gc_alloc_regions between GCs
// we retain nothing on _gc_alloc_regions between GCs
set_gc_alloc_region
(
ap
,
NULL
);
set_gc_alloc_region
(
ap
,
NULL
);
_gc_alloc_region_counts
[
ap
]
=
0
;
if
(
r
->
is_empty
())
{
if
(
r
->
is_empty
())
{
// we didn't actually allocate anything in it; let's just put
// we didn't actually allocate anything in it; let's just put
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录