- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在对几种算法进行基准测试,这些算法处理第 k 个最近邻问题的变体。在重复运行对我的数据进行排序的算法时,我看到了令人不安的结果。
似乎数据本身并没有像人们所说的那样被缓存。我运行了相同的 n = 50000 测试,但每次运行三个测试时都会在两个 ArrayList 中生成随机点。我担心的加速仍然发生了。这似乎是 JITC 的功能。
输出:
Stopping :: Brute Force. Time (ms): 21716
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 24014
Stopping :: Quickselect. Time (ms): 17655
Stopping :: Brute Force. Time (ms): 22034
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 23975
Stopping :: Quickselect. Time (ms): 18438
Stopping :: Brute Force. Time (ms): 20097
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15677
Stopping :: Quickselect. Time (ms): 14399
Stopping :: Brute Force. Time (ms): 20457
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15141
Stopping :: Quickselect. Time (ms): 14146
Stopping :: Brute Force. Time (ms): 20143
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15834
Stopping :: Quickselect. Time (ms): 14084
Stopping :: Brute Force. Time (ms): 20173
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15170
Stopping :: Quickselect. Time (ms): 13745
Stopping :: Brute Force. Time (ms): 19625
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 14924
Stopping :: Quickselect. Time (ms): 15972
Stopping :: Brute Force. Time (ms): 19388
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15209
Stopping :: Quickselect. Time (ms): 13639
Stopping :: Brute Force. Time (ms): 19420
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 14779
Stopping :: Quickselect. Time (ms): 13798
Stopping :: Brute Force. Time (ms): 19390
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15078
Stopping :: Quickselect. Time (ms): 13548
背景/细节:
我有两个未排序的 n 大小的点数组列表 - A 和 B。对于 A 中的每个点 P,检查 B 中有多少点在距 P 的距离 d 内。
算法:
示例:
public void quickSelect(ArrayList<Point> field1, ArrayList<Point> input2, int distance){
ArrayList<Point> field2 = new ArrayList<Point>();
deepCopy(field2, input2);
startTimer("Starting :: Quickselect.\n");
Collections.sort(field2, new ComparePoints());
for(int i = 0; i < field1.size(); ++i){
//Find pivot
...
//Scan to its left until out of bounds.
...
//Scan to its right until out of bounds.
...
}
endTimer("Stopping :: Quickselect. ");
field2.clear();
}
deepCopy 在哪里:
private void deepCopy(ArrayList<Point> field1, ArrayList<Point> input1){
for(int i = 0; i < input1.size(); ++i){
field1.add(input1.get(i).getLocation());
}
}
测试方法:
public static void main(String[] args){
int points = 50000;
ArrayList<Point> field1 = generator.makeGraph(points);
ArrayList<Point> field2 = generator.makeGraph(points);
GraphTester tester = new GraphTester(field1);
int maxDistance = 300;
for(int i = 0; i < 10; ++i){
tester.bruteForce(field1, field2, maxDistance);
}
for(int i = 0; i < 10; ++i){
tester.sortedBruteForce(field1, field2, maxDistance);
}
for(int i = 0; i < 10; ++i){
tester.quickSelect(field1, field2, maxDistance);
}
}
结果:
Stopping :: Brute Force. Time (ms): 22851
Stopping :: Brute Force. Time (ms): 22482
Stopping :: Brute Force. Time (ms): 20690
Stopping :: Brute Force. Time (ms): 21073
Stopping :: Brute Force. Time (ms): 20860
Stopping :: Brute Force. Time (ms): 21311
Stopping :: Brute Force. Time (ms): 20847
Stopping :: Brute Force. Time (ms): 21000
Stopping :: Brute Force. Time (ms): 20503
Stopping :: Brute Force. Time (ms): 21342
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 23083
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 22616
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15881
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15323
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15930
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15360
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 16072
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15601
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 16952
Stopping :: Sorted 'Smart' Brute Force. Time (ms): 15950
Stopping :: Quickselect. Time (ms): 18202
Stopping :: Quickselect. Time (ms): 18109
Stopping :: Quickselect. Time (ms): 14685
Stopping :: Quickselect. Time (ms): 14401
Stopping :: Quickselect. Time (ms): 14052
Stopping :: Quickselect. Time (ms): 14782
Stopping :: Quickselect. Time (ms): 14175
Stopping :: Quickselect. Time (ms): 14187
Stopping :: Quickselect. Time (ms): 13870
Stopping :: Quickselect. Time (ms): 14601
如您所见,Sorted Smart Brute Force 和 Quickselect 算法开始时的计算时间较长,但随着测试的重复,逐渐趋于稳定到更好的数字。
虽然我正在清除临时 ArrayList,但我觉得排序后的 ArrayList 以某种方式被 JVM 保留并重新使用/重新映射到新的 ArrayList 指针。
我的问题有两个方面,那么:
最佳答案
我不明白你为什么要深度克隆数据。
Does this seem like a case of caching?
不,是 JITC 在您运行的内容上做得更好。每个重要的 Java 基准测试都需要预热,在此期间收集统计数据,然后对代码的相关部分(HotSpot
)进行大量编译和优化。
更复杂的算法需要更多的预热。
Can I guarantee that the data is not cached?
我在那里看不到任何缓存。谁会做? JITC 无法理解你在做什么。如果它知道您一直在计算相同的东西,那么除一次之外的所有时间都将为零。
If I randomize the Points every time I generate the graphs, I'm betting there would be more control, but then I couldn't be sure that the algorithms are fairly matched.
如果你有这种感觉,那就去吧。我想您可以宁愿相信您的基准测试也无需这样做。
预热:常见的情况是服务器运行许多小时(至少),一直在执行大部分相同的操作。对于这样的服务器,在最初几分钟内测量性能毫无意义。另一种需要预热的情况是测量或优化非常快速的操作,例如String.hashCode,通常重复数千次。单次长时间计算的情况似乎是个异常(exception)。
不过,我写的关于热身的内容是对您的观察的合理解释。总之,Quickselect
在所有运行中都是赢家,所以选择很明确。它后来有所改善的事实对获胜者来说是不错的奖励。接下来的位置不太清楚,但 22851 与 23083 并不是真正的胜利,因为测量误差更大(因此可能是深度复制的成本)。如果您想了解更多(1 次迭代就足够了),请多次重新运行基准测试(使用新的 JVM)。
关于Java 基准测试 : Ensuring that objects are not reused after coming out of scope,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24317685/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!