0
i am calling java code in c++ using jni ,i alloted 60GB as max heap memory ,but while running its using less memory because of that its taking much time .

我正在使用 windows7 操作系统,VS2008。

我使用控制台运行java,它正在使用分配的内存,并且做得很快,你能帮我解决这个问题吗?

更新说明:

我们有一个内存密集型 Java 应用程序,我们尝试了以下两种方式。

1.来自使用 JNI 的 c++ 应用程序。

2.直接通过命令提示符执行。

在这两种情况下,我们都为 jvm 分配了 60GB 的堆内存大小。我们发现上述两种执行方法有以下区别。

1.c++应用使用JNI达到40GB内存。(执行慢)

2.通过命令提示符执行达到约60GB内存。(快速执行)

内存使用量不同的原因可能是什么?

JVM初始化:

JavaVMInitArgs vm_args;
 JavaVMOption options[3];

 options[0].optionString = "-Djava.class.path=c:\\Application\\bin-7.0\\morpher\\app.jar;";
 options[1].optionString = "-Xms1024m";
 options[2].optionString = "-Xmx50000m";

 vm_args.version = JNI_VERSION_1_6;
 vm_args.nOptions = 3;
 vm_args.options = options;
 vm_args.ignoreUnrecognized = 0;
 JNI_GetDefaultJavaVMInitArgs(&vm_args);
 int ret = JNI_CreateJavaVM(jvm, (void**)&env, &vm_args);
4

1 回答 1

1

不可能以这种方式回答你的问题,但我可以告诉你。

  • 您可以非常快速地分配堆,每秒 400+ MB 非常小的对象。对于大型物体来说要快得多。
  • 你可能会发现增加你的 eden 大小会通过减少触发的 GC 数量来提高分配对象的速率。
  • 可能让你慢下来的是堆集合。我建议增加你的伊甸园大小,但也通过将大量数据放置在带有 ByteBuffers 和内存映射文件的本机内存中来减少你的堆。
  • 您可以在几秒钟或更短的时间内附加 500 GB 的内存映射文件。
  • 如果您正在创建数以亿计或数百万个对象,则值得重新考虑您的设计以减少对象数量,例如使用基于列的表而不是基于行的表。(你可能只有几十列,但几百万行和创建几十个数组比创建几百万个对象要快)
于 2012-12-11T08:44:32.457 回答