Java - 使用Condition和Lambda在Array中查找元素

Joe*_*ore 21 java arrays lambda java-8 java-stream

简而言之,我有这个代码,我想使用条件和lambda获取数组的特定元素.代码将是这样的:

Preset[] presets = presetDALC.getList();
Preset preset = Arrays.stream(presets).select(x -> x.getName().equals("MyString"));
Run Code Online (Sandbox Code Playgroud)

但显然这不起作用.在C#中会有类似的东西,但在Java中,我该怎么做?

Cod*_*roc 36

你可以这样做,

Optional<Preset> optional = Arrays.stream(presets)
                                   .filter(x -> "MyString".equals(x.getName()))
                                   .findFirst();

if(optional.isPresent()) {//Check whether optional has element you are looking for
    Preset p = optional.get();//get it from optional
}
Run Code Online (Sandbox Code Playgroud)

你可以Optional 在这里阅读更多信息.

  • 不直接。使用Optional的主要原因是强制检查(尽早触发错误)。如果你能证明它成立的话,使用 get() 是可以的,他确实做到了。我同意,但总的来说,最好使用替代方案。但很多情况下,你不能直接命名默认值或想要抛出异常,而是你可能希望在 isPresent() 的 if-else 中进行错误处理,然后使用 get() `。 (4认同)

Rob*_*sen 23

像这样:

Optional<Preset> preset = Arrays
        .stream(presets)
        .filter(x -> x.getName().equals("MyString"))
        .findFirst();
Run Code Online (Sandbox Code Playgroud)

这将返回一个Optional可能包含或不包含值的值.如果你想Optional完全摆脱:

Preset preset = Arrays
        .stream(presets)
        .filter(x -> x.getName().equals("MyString"))
        .findFirst()
        .orElse(null);
Run Code Online (Sandbox Code Playgroud)

filter()操作是一个返回惰性流的中间操作,因此即使遇到匹配也无需担心整个数组被过滤.


And*_*eas 8

你想先匹配,还是全匹配?

String[] presets = {"A", "B", "C", "D", "CA"};

// Find all matching
List<String> resultList = Arrays.stream(presets)
                                .filter(x -> x.startsWith("C"))
                                .collect(Collectors.toList());
System.out.println(resultList);

// Find first matching
String firstResult = Arrays.stream(presets)
                           .filter(x -> x.startsWith("C"))
                           .findFirst()
                           .orElse(null);
System.out.println(firstResult);
Run Code Online (Sandbox Code Playgroud)

产量

[C, CA]
C
Run Code Online (Sandbox Code Playgroud)