我传输一个对象,想测试传输速度。
java中有没有类似于sizeof的函数,用来求一个对象的大小?
java中有没有类似于sizeof的函数,用来求一个对象的大小?
解决方案 »
- 在synchronized块中声明变量!!
- java 继承 多态 引用的问题 神人来啊
- 刚建的一个JAVA交流群~~欢迎喜欢JAVA或JAVA高手进~~!!!!!
- JAVA生成高质量缩略图问题,(百分问题)
- 本人想速成java2D绘图,哪位好心人能介绍几个有好教程,尤其是大量源代码下载的网站?不胜感激 。
- 高分求助:查找两篇文章的异同算法思路。
- 学JAVA过程中,我遇到了几个关于main()方法与static修饰符的疑惑.详情请看......
- 这个操作java会自动释放内存空间吗?
- 我是一个新手,怎样用jdbc连接数据库
- Eclipse安装m2e总是不成功
- 按位与的简单问题(计算器和程序里结果不一样!)
- 按位与的简单问题(计算器和程序里结果不一样!)
· 与C++不同,类方法以及他们的虚拟不影响对象的尺寸
· 类超接口不影响对象尺寸(见该列表末尾的注释)
· 完整的对象尺寸可作为根于启动对象的整个对象图形的闭合来获得 注释:实现任何Java接口只对怀疑类做标记,而且不添加任何数据到它的定义上。实际上, JVM 甚至不校验接口实现有没有提供接口所请求的所有方法:在目前的规范中,这严格说来是编译器的责任。 为了引导整个进程,对于初级数据类型,我使用Java 技巧130的Sizeof 类来测量物理尺寸。正如它所证明的一样,对于普通的32位JVM来说,一个简单的java.lang.Object 占了8位,并且基本数据类型通常都是能够适应语言要求的最少的物理尺寸 (除了boolean 要占据整个字节之外): // java.lang.Object shell size in bytes:
public static final int OBJECT_SHELL_SIZE = 8;public static final int OBJREF_SIZE = 4;
public static final int LONG_FIELD_SIZE = 8;
public static final int INT_FIELD_SIZE = 4;
public static final int SHORT_FIELD_SIZE = 2;
public static final int CHAR_FIELD_SIZE = 2;
public static final int BYTE_FIELD_SIZE = 1;
public static final int BOOLEAN_FIELD_SIZE = 1;
public static final int DOUBLE_FIELD_SIZE = 8;
public static final int FLOAT_FIELD_SIZE = 4;
interface IObjectProfileNode
{
Object object ();
String name ();int size ();
int refcount ();IObjectProfileNode parent ();
IObjectProfileNode [] children ();
IObjectProfileNode shell ();IObjectProfileNode [] path ();
IObjectProfileNode root ();
int pathlength ();boolean traverse (INodeFilter filter, INodeVisitor visitor);
String dump ();} // End of interface IObjectProfileNodes采用与原始对象图形非常类似的方法互连,它使用了返回每个节点所代表的实际对象的IObjectProfileNode.object()函数。IObjectProfileNode.size()返回以该节点的对象实例为根的对象子树的总体尺寸(以字节为单位)。如果对象实例通过非空实例域或者通过包含在排列域内部的引用链接到其他对象上,那么IObjectProfileNode.children()将会变成按降序排列的子图形节点的相应列表。相反,对于每个不是起始节点的节点来说,IObjectProfileNode.parent()返回他们的父节点。从而IObjectProfileNode的整个收集就会切断原始对象,并且展示对象存储在其内部如何分割。而且,图形节点名源于类域,检测图形内的节点路径(IObjectProfileNode.path())允许你回溯从原始对象实例到数据的任一部分的所有权链接。 你可能已经注意到上述段落有些思想表达得有点含糊。如果在遍历对象图形过程中,你不止一次的遇到同一对象(如,在图形中不止一个域指向它),你将如何分配它的所有权(父指针)?考虑下列代码片段:Object obj = new String [] {new String ("JavaWorld"),
new String ("JavaWorld")}; 每个java.lang.String实例都有类型char[]的内域,类型char[]具有真正的字符串内容。String复制构造器的方式在Java 2平台标准版(J2SE) 1.4中有效,上述排列内的两个 String实例共享同一个包含{J, a, v, a, W, o, r, l, d}字符序列的char[]排列。两个字符串同等的属于这个排列,那么像这种情况你怎么办? 如果我总是想将单个父节点赋给图形节点,那么这个问题就没有普遍适用的答案。但是实际上,许多这样的对象实例可以回溯到一个单一的"自然的"父节点。这种自然的链接序列通常比其他的更迂回的路径要短。把实例域指向的数据看作更从属于该实例而不是其它。把排列中的项看作更从属于该排列自己。因此,如果内部对象实例可通过几条路经到达,我们选择最短的那条路经。如果路径一样长,我们就选最早发现的那一条。在最坏的情况下,这个万能策略很有用。 考虑图形遍历和最短路径应该注意这一点:宽度优先的搜索,这个图形遍历能够保证找到从起始节点到任何其他可到达的图形节点之间的最短路径。
在做了所有这些准备之后,下面就是这种图形遍历的标准实现:
public static IObjectProfileNode profile (Object obj)
{
final IdentityHashMap visited = new IdentityHashMap (); final ObjectProfileNode root = createProfileTree (obj, visited,
CLASS_METADATA_CACHE);
finishProfileTree (root);return root;
}private static ObjectProfileNode createProfileTree (Object obj,
IdentityHashMap visited,
Map metadataMap)
{
final ObjectProfileNode root = new ObjectProfileNode (null, obj, null);final LinkedList queue = new LinkedList ();queue.addFirst (root);
visited.put (obj, root);final ClassAccessPrivilegedAction caAction =
new ClassAccessPrivilegedAction ();
final FieldAccessPrivilegedAction faAction =
new FieldAccessPrivilegedAction ();while (! queue.isEmpty ())
{
final ObjectProfileNode node = (ObjectProfileNode) queue.removeFirst ();obj = node.m_obj;
final Class objClass = obj.getClass ();if (objClass.isArray ())
{
final int arrayLength = Array.getLength (obj);
final Class componentType = objClass.getComponentType ();// Add shell pseudo-node:
final AbstractShellProfileNode shell =
new ArrayShellProfileNode (node, objClass, arrayLength);
shell.m_size = sizeofArrayShell (arrayLength, componentType);node.m_shell = shell;
node.addFieldRef (shell);
这个链接
http://www.softhouse.com.cn/html/200410/2004102515234900001286.html