我经常遇到人们实例化一个新的ArrayList并将其分配给List接口(interface)的代码,如下所示:Listnames=newArrayList();这种方法背后的原因是什么? 最佳答案 将您的代码与接口(interface)的特定实现分离。这也可以帮助您转移到List的另一个实现future的界面。例如——你有Listnames=newArrayList();稍后你决定你应该使用List的一些其他实现。界面,说LinkedList所以你只需将其更改为Listnames=newLinkedList();没有任何问题。
我发现自己同意返回一个接口(interface)而不是一个具体的类。原因很简单,我要松耦合。但是会有其他影响或权衡吗? 最佳答案 最好返回最适合您的接口(interface)的通用类型。如果出于某些原因ArrayList本质上适合您要返回的数据,那么您应该使用它。通常List没问题,但如果返回值本质上是无序的,您也可以考虑使用Collection: 关于java-我应该返回List还是ArrayList?,我们在StackOverflow上找到一个类似的问题:
我脑抽筋了:我有一个publicinterfaceSomeInterface和一个staticprivateclassSomeClass并试图返回List从我的一种方法,但我得到了错误(在下面的returnlist;行):Typemismatch:cannotconvertfromListtoList如何在不创建新列表的情况下解决此问题?澄清:我不想将列表创建为List(也许是显而易见的解决方案)因为私下里我想维护一个List允许将来访问SomeClass的方法,而不是公共(public)接口(interface)中的方法。这在下面的示例中没有显示,但在我的实际程序中我需要它。impo
这个问题在这里已经有了答案:HowtoconvertListtoMap?(20个答案)关闭7年前。我想找到一种方法来获取下面的对象特定例程并将其抽象为一个方法,您可以通过该方法传递类、列表和字段名以取回Map。如果我能得到关于使用的模式或等的一般指示,这可以让我在正确的方向上开始。Mapmapped_roles=newHashMap();Listp_roles=(List)c.list();for(Roleel:p_roles){mapped_roles.put(el.getName(),el);}为了这个?(伪代码)MapMapMe(Classclz,Collectionlist,S
这个问题在这里已经有了答案:CannotconvertfromListtoList>(3个答案)关闭7年前。我没有得到这段代码以任何方式编译:Lista=newArrayList();List>b=newArrayList();a=b;//incompatibletypesb=a;//incompatibletypesjava好像没有考虑List和List在涉及泛型时是同一类型。这是为什么呢?有什么好的出路吗?上下文有一个具有以下签名的库函数:publicSet>getSubTypesOf(finalClasstype).这适用于作为参数传递的简单类型,但在泛型的情况下,结果未使用通配
这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:AreThread.sleep(0)andThread.yield()statementsequivalent?在我的理解中,Thread.yield()和Thread.sleep(0)都应该通过某种调度算法让CPU重新判断运行哪个线程。区别在于:Thread.yield()是给其他线程执行的机会,而Thread.sleep(0)不会,它只是告诉CPU你应该重新安排执行线程,包括当前线程本身。Thread.yield()只是一个建议,这意味着它可能根本不会被接受,但Thread.sleep(0)会强制进行重新
我正在寻找一个库,它会提供一种方法,该方法会给我一个匹配给定类Ant模式的文件列表。对于*foo/**/*.txt我会得到foo/x.txtfoo/bar/baz/.txtmyfoo/baz/boo/bar.txt等我知道这可以通过DirWalker和PathMatchermat=FileSystems.getDefault().getPathMatcher("glob:"+filesPattern);,但我更喜欢一些维护的库。我希望CommonsIO拥有它,但没有。更新:我很高兴重用Ant的代码,但更喜欢比整个Ant更小的东西。 最佳答案
阅读Java8Spliterator的文档时我遇到了“串行线程限制”的概念。准确地说,文档说:Despitetheirobviousutilityinparallelalgorithms,spliteratorsarenotexpectedtobethread-safe;instead,implementationsofparallelalgorithmsusingspliteratorsshouldensurethatthespliteratorisonlyusedbyonethreadatatime.Thisisgenerallyeasytoattainviaserialthrea
考虑以下JUnit测试:@TestpublicvoidtestSettingInterruptFlag()throwsInterruptedException{ThreadblockingThread=newThread(newRunnable(){@Overridepublicsynchronizedvoidrun(){try{wait();}catch(InterruptedExceptione){Thread.currentThread().interrupt();}}});blockingThread.start();blockingThread.interrupt();blo
我有这段代码:while((line=br.readLine())!=null){StringWords[]=line.split("");outputLine=SomeAlgorithm(Words);output.write(outputLine);}正如您在上面的代码中看到的,对于输入文件中的每一行,我都读取一行,在其上运行一些算法,基本上修改读取的那行,然后将输出行写入某个文件。文件中有9k行,整个程序在我的机器上花了3分钟。我想,好吧,我为算法的每一(行)运行执行2个I/O。所以我正在做大约18kI/O。为什么不先将所有行收集到ArrayList中,然后遍历列表并在每一行上运