当我的应用程序编写Java与SWT下运行OS X,无论是从下Eclipse和jar,其在Launchpad中读取名称"Java"的,就像图片中所示.
在我的代码我所说的开始Display.setAppName("MyApp"),并在菜单栏和菜单项的应用程序的名称是正确的,它读取MyApp,About MyApp,Configure MyApp,等菜单项举止得体,我可以接受和处理相应的事件.所以问题只与应用程序名称有关,如启动板中所示.有没有办法在不创建应用程序包的情况下,从代码中以编程方式设置正确的名称以在启动板中显示?
PS代码实际上是在JVM下运行的,JVM是从我的代码中启动的,使用ProcessBuilder:
new ProcessBuilder("java -cp mypath MyClass my args").start();
Run Code Online (Sandbox Code Playgroud)
一种递归,需要在启动应用程序之前以编程方式计算一些jvm选项和类路径.
为了确保我的计算对于所有情况都是正确的,我希望将结果(双精度数)看作十六进制或二进制字符串.如何获取十六进制/二进制字符串或此数字的字节表示Perl?在Java,我可以使用,例如,
double d = performMyCalculations();
System.out.format("%x\n", Double.doubleToLongBits(d));
Run Code Online (Sandbox Code Playgroud)
为了这个目的,它会打印出3fc3333333333333的0.15.我怎样才能得到类似的结果Perl?
当我准备我的程序进行部署时,我将它与Eclipse jar-in-jar类加载器一起打包到JAR中.当我的程序从JAR运行时,我需要知道一个包的版本,但我无法从jar的清单中以简单和"诚实"的方式获取它.清单看起来像这样:
Manifest-Version: 1.0
Created-By: 1.8.0_73-b02 (Oracle Corporation)
Main-Class: org.eclipse.jdt.internal.jarinjarloader.JarRsrcLoader
Rsrc-Main-Class: com.domain.sp2.controller.Controller
Rsrc-Class-Path: ./ jar-in-jar-loader.zip javahelp-2.0.05.jar json-simple-1.1.1.jar
Class-Path: .
Name: com/domain/sp2/controller/
Implementation-Version: 19
Run Code Online (Sandbox Code Playgroud)
为了获得软件包的实现版本,我尝试使用最简单直接的方法:
package com.domain.sp2.controller;
public class Controller {
...
public static String getBuildNumber() throws IOException {
Package pckg = Controller.class.getPackage();
pr(pckg.getName()); // prints "com.domain.sp2.controller", as expected
return pckg.getImplementationVersion(); // returns null
}
...
}
Run Code Online (Sandbox Code Playgroud)
根据http://docs.oracle.com/javase/tutorial/deployment/jar/packageman.html和http://docs.oracle.com/javase/8/docs/api/java/lang/Package.html# getImplementationVersion--(和其他来源),它应该返回"19",但它返回null.对于JRE库的包,它返回正确的值.也许我错过了关于如何在清单中命名包的详细信息,或者JarRsrcLoader与之相关的原因- 可能需要一些特殊的语法来解决包.我也尝试过".com/domain/...","/com/domain/..."并且".../controller",甚至"rsrc:./com/domain..."在清单的包名-均无功而返.我可以使用其他方法,例如将清单加载为流并使用Manifest类解析它,但我想了解使用该getImplementationVersion()方法的正确方法.
出于研究排序算法(我自己的)的意图,我决定将其性能与经典算法进行比较quicksort,令我惊讶的是,我发现我的实现所花费的时间quicksort与N log(N). 我彻底尝试在我的quicksort但没有成功。这是排序算法的一个简单版本,处理Integer不同大小的数组,填充随机数,我不知道错误可能潜入何处。我什至计算了我的代码执行的所有比较和交换,并且他们的人数与N log(N). 我完全糊涂了,无法理解我观察到的现实。以下是对包含 1,000、2,000、4,000、8,000 和 16,000 个随机值的数组进行排序的基准测试结果(使用 测量JMH):
Benchmark Mode Cnt Score Error Units 2N / N ratio
QSortBenchmarks.sortArray01000 avgt 5 561.505 ± 2.992 us/op
QSortBenchmarks.sortArray02000 avgt 5 2433.307 ± 11.770 us/op 4.334
QSortBenchmarks.sortArray04000 avgt 5 8510.448 ± 34.051 us/op 3.497
QSortBenchmarks.sortArray08000 avgt 5 38269.492 ± 161.010 us/op 4.497
QSortBenchmarks.sortArray16000 avgt 5 147132.524 ± 261.963 us/op 3.845
Run Code Online (Sandbox Code Playgroud)
显然,我观察到的时间复杂度远非O(n log(n)),几乎是O(n^2)。可能有一个很小的怀疑,即随机种子非常不幸,以至于数组中的值碰巧接近最坏的情况。这个概率非常接近于 0,但不是 …