util方法与在该方法中编写相同代码之间的性能差异…? - java

private void test(){
   List<String> list=new ArrayList<>();
   list.add("aaa");
   list.add("bbb");
   list.add("ccc");

   //using utility
   boolean flag = Util.search(list,"bbb");
   flag = Util.search(list,"aaa");

   //using same code here only
   for(String obj:list){
      if(obj.equals("bbb")){
         return true;
      }
   }

   for(String obj:list){
      if(obj.equals("aaa")){
         return true;
      }
   }
   // util method has same logic as in the method for search
}

我的问题是哪个更好:实用程序方法还是测试方法中的相同逻辑(例如关于性能)?

参考方案

不应有任何明显的性能差异。

您应该做一些您认为更清晰,更易于维护的事情。

差异不大的原因是,JIT可以内联方法,并且一旦对其进行优化,最终将在运行时得到相同的代码。

当您有大量的收藏品和不同的时间复杂性时,性能才是最重要的。例如。说你想做

if (words.contains("bbb"))
    return true;

如果使用列表,则这是O(N)操作,但是如果使用HashSet,则这应该是O(1)操作。这与您几乎可以做的其他任何事情相比,可以带来更大的不同。

简而言之,请坚持使用O(1)或O(log N)或非常小的集合,并且应该没问题,除非您的探查器表明您在特定位置有问题,否则我不会再猜测代码的性能了。

注意:在某些情况下,实用程序方法可以执行内联代码。为了优化代码,必须将其运行一定次数或循环一定次数。 (循环,调用的确切数目取决于VM和编译的哪个阶段)

与在许多地方重复的相同代码相比,在许多地方被调用的方法被称为很多(或循环很多)的方法将被更快地优化。

Java-搜索字符串数组中的字符串 - java

在Java中,我们是否有任何方法可以发现特定字符串是字符串数组的一部分。我可以避免出现一个循环。例如String [] array = {"AA","BB","CC" }; string x = "BB" 我想要一个if (some condition to tell wheth…

Java-固定大小的列表与指定初始容量的列表之间的差异 - java

我在理解这一点上遇到了问题。当我们做 List<Integer> list = Arrays.asList(array); 我们不能在该列表上使用添加,删除之类的方法。我知道Arrays.asList()返回固定大小的列表。我不明白的是,如果我们创建一个具有指定初始容量的列表,例如List<Integer> list2 = new A…

Java:线程池如何将线程映射到可运行对象 - java

试图绕过Java并发问题,并且很难理解线程池,线程以及它们正在执行的可运行“任务”之间的关系。如果我创建一个有10个线程的线程池,那么我是否必须将相同的任务传递给池中的每个线程,或者池化的线程实际上只是与任务无关的“工人无人机”可用于执行任何任务?无论哪种方式,Executor / ExecutorService如何将正确的任务分配给正确的线程? 参考方案 …

JAVA:字节码和二进制有什么区别? - java

java字节代码(已编译的语言,也称为目标代码)与机器代码(当前计算机的本机代码)之间有什么区别?我读过一些书,他们将字节码称为二进制指令,但我不知道为什么。 参考方案 字节码是独立于平台的,在Windows中运行的编译器编译的字节码仍将在linux / unix / mac中运行。机器代码是特定于平台的,如果在Windows x86中编译,则它将仅在Win…

java:继承 - java

有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…