Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
ec5ccec3
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看板
提交
ec5ccec3
编写于
16年前
作者:
D
dcubed
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
c74a5142
87a46b4e
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
35 addition
and
29 deletion
+35
-29
agent/src/share/classes/sun/jvm/hotspot/tools/PermStat.java
agent/src/share/classes/sun/jvm/hotspot/tools/PermStat.java
+35
-29
未找到文件。
agent/src/share/classes/sun/jvm/hotspot/tools/PermStat.java
浏览文件 @
ec5ccec3
...
@@ -266,45 +266,51 @@ public class PermStat extends Tool {
...
@@ -266,45 +266,51 @@ public class PermStat extends Tool {
out
.
println
();
out
.
println
();
}
}
private
static
long
objectSize
(
Oop
oop
)
{
return
oop
==
null
?
0L
:
oop
.
getObjectSize
();
}
// Don't count the shared empty arrays
private
static
long
arraySize
(
Array
arr
)
{
return
arr
.
getLength
()
!=
0L
?
arr
.
getObjectSize
()
:
0L
;
}
private
long
computeSize
(
InstanceKlass
k
)
{
private
long
computeSize
(
InstanceKlass
k
)
{
long
size
=
0L
;
long
size
=
0L
;
//
InstanceKlass object size
//
the InstanceKlass object itself
size
+=
k
.
getObjectSize
();
size
+=
k
.
getObjectSize
();
// add ConstantPool size
// Constant pool
size
+=
k
.
getConstants
().
getObjectSize
();
ConstantPool
cp
=
k
.
getConstants
();
size
+=
cp
.
getObjectSize
();
size
+=
objectSize
(
cp
.
getCache
());
size
+=
objectSize
(
cp
.
getTags
());
// add ConstantPoolCache, if any
// Interfaces
ConstantPoolCache
cpCache
=
k
.
getConstants
().
getCache
();
size
+=
arraySize
(
k
.
getLocalInterfaces
());
if
(
cpCache
!=
null
)
{
size
+=
arraySize
(
k
.
getTransitiveInterfaces
());
size
+=
cpCache
.
getObjectSize
();
}
// add interfaces size
// Inner classes
ObjArray
interfaces
=
k
.
getLocalInterfaces
();
size
+=
objectSize
(
k
.
getInnerClasses
());
size
+=
(
interfaces
.
getLength
()
!=
0L
)?
interfaces
.
getObjectSize
()
:
0L
;
ObjArray
transitiveInterfaces
=
k
.
getTransitiveInterfaces
();
size
+=
(
transitiveInterfaces
.
getLength
()
!=
0L
)?
transitiveInterfaces
.
getObjectSize
()
:
0L
;
// add inner classes size
// Fields
TypeArray
innerClasses
=
k
.
getInnerClasses
();
size
+=
objectSize
(
k
.
getFields
());
size
+=
innerClasses
.
getObjectSize
();
// add fields size
// Methods
size
+=
k
.
getFields
().
getObjectSize
();
// add methods size
ObjArray
methods
=
k
.
getMethods
();
ObjArray
methods
=
k
.
getMethods
();
size
+=
(
methods
.
getLength
()
!=
0L
)?
methods
.
getObjectSize
()
:
0L
;
int
nmethods
=
(
int
)
methods
.
getLength
();
TypeArray
methodOrdering
=
k
.
getMethodOrdering
();
if
(
nmethods
!=
0L
)
{
size
+=
(
methodOrdering
.
getLength
()
!=
0L
)?
methodOrdering
.
getObjectSize
()
:
0
;
size
+=
methods
.
getObjectSize
();
for
(
int
i
=
0
;
i
<
nmethods
;
++
i
)
{
// add each method's size
int
numMethods
=
(
int
)
methods
.
getLength
();
for
(
int
i
=
0
;
i
<
numMethods
;
i
++)
{
Method
m
=
(
Method
)
methods
.
getObjAt
(
i
);
Method
m
=
(
Method
)
methods
.
getObjAt
(
i
);
size
+=
m
.
getObjectSize
();
size
+=
m
.
getObjectSize
();
size
+=
objectSize
(
m
.
getConstMethod
());
}
}
}
// MethodOrdering - an int array that records the original
// ordering of methods in the class file
size
+=
arraySize
(
k
.
getMethodOrdering
());
return
size
;
return
size
;
}
}
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录