이 글은 Java 8에서 일반적으로 사용되는 내장 함수에 대한 요약(코드 예제)을 제공합니다. 특정 참고 가치가 있으므로 도움이 필요한 친구가 참고할 수 있기를 바랍니다.
나중에 쉽게 참조할 수 있도록 자주 사용되는 함수 인터페이스를 기록해 두었습니다.
Interface | Parameters | Return type | Description |
---|---|---|---|
Predicate | T | boolean | 을 입력하세요 특정 값, 특정 값을 결정하는 데 사용되는 부울 값 출력 |
Consumer |
T | void | 특정 값을 입력하면 출력되지 않습니다. 특정 값을 소비하는 데 사용됩니다 |
Function |
T | R | 특정 유형의 값을 입력하고, 다른 유형의 값을 출력하고, 유형 변환 등에 사용됩니다. |
Supplier | None | T | 입력 없음, 특정 값 출력, 특정 값을 생성하는 데 사용 |
UnaryOperator |
T | T | 특정 유형의 값을 입력하면 동일하게 출력 값에 대해 4개의 산술 연산을 수행하는 등 동일한 유형의 값 변환에 사용되는 값 유형입니다. |
BinaryOperator |
(T,T) | T | 두 개의 값을 입력하세요. 특정 유형을 지정하고 두 값을 병합하기 위해 동일한 유형의 값을 출력합니다. |
Predicates
Predicates는 하나의 매개변수를 포함하는 부울 인터페이스입니다. 여기에는 몇 가지 기본 메서드가 포함되어 있으며 이들의 조합으로 복잡한 비즈니스 논리(예: and, or, negate)를 구현할 수 있습니다. 샘플 코드는 다음과 같습니다.
Predicate<string> predicate = (s) -> s.length() > 0; predicate.test("foo"); // true predicate.negate().test("foo"); // false Predicate<boolean> nonNull = Objects::nonNull; Predicate<boolean> isNull = Objects::isNull; Predicate<string> isEmpty = String::isEmpty; Predicate<string> isNotEmpty = isEmpty.negate();</string></string></boolean></boolean></string>
Functions
Functions 인터페이스는 매개변수를 수신하고 결과를 생성합니다. 기본 메소드는 일반적으로 여러 기능을 함께 연결하는 데 사용됩니다(compose, andThen).
Function<string> toInteger = Integer::valueOf; Function<string> backToString = toInteger.andThen(String::valueOf); backToString.apply("123"); // "123"</string></string>
Suppliers
Suppliers 인터페이스는 특정 유형의 결과를 생성합니다. 함수와 달리 매개변수를 받지 않습니다.
Supplier<person> personSupplier = Person::new; personSupplier.get(); // new Person</person>
Consumers
소비자는 단일 입력 매개변수를 사용하는 작업을 나타냅니다.
Consumer<person> greeter = (p) -> System.out.println("Hello, " + p.firstName); greeter.accept(new Person("Luke", "Skywalker"));</person>
Comparators
비교기는 이전 버전의 Java에서 업그레이드되었으며 일부 기본 메소드가 추가되었습니다.
Comparator<person> comparator = (p1, p2) -> p1.firstName.compareTo(p2.firstName); Person p1 = new Person("John", "Doe"); Person p2 = new Person("Alice", "Wonderland"); comparator.compare(p1, p2); // > 0 comparator.reversed().compare(p1, p2); // <h4 id="Stream-일반-메서드">Stream 일반 메서드</h4><h5 id="Create-Stream">Create Stream</h5><ol><li>기존 데이터 구조를 Stream</li></ol><pre class="brush:php;toolbar:false">Stream<integer> s = Stream.of(1, 2, 3, 4, 5); Stream<integer> s = Arrays.stream(arr); Stream<integer> s = aList.stream();</integer></integer></integer>
- 으로 변환 Stream.generate() 메서드를 통해:
// 这种方法通常表示无限序列 Stream<t> s = Stream.generate(SuppLier<t> s); // 创建全体自然数的Stream class NatualSupplier implements Supplier<biginteger> { BigInteger next = BigInteger.ZERO; @Override public BigInteger get() { next = next.add(BigInteger.ONE); return next; } }</biginteger></t></t>
- 다른 메서드를 통해 반환
Stream<string> lines = Files.lines(Path.get(filename)) ...</string>
map 메서드
Stream의 각 요소에 작업 작업을 매핑하여 한 Stream에서 다른 Stream으로의 변환을 완료합니다.
map 메서드에서 허용하는 개체는 기능적 인터페이스인 Function 인터페이스입니다.
<r> Stream<r> map(Function super T, ? extends R> mapper); @FunctionalInterface public interface Function<t> { // 将T转换为R R apply(T t); }</t></r></r>
사용 방법:
// 获取Stream里每个数的平方的集合 Stream<integer> ns = Stream.of(1, 2, 3, 4, 5); ns.map(n -> n * n).forEach(System.out::println);</integer>
FlatMap
map 메서드는 일대일 매핑이며 각 입력 데이터에 대해 하나의 값만 출력됩니다.
FlatMap 메소드는 일대다 매핑입니다. 각 요소는 Stream에 매핑되고, 이 하위 스트림의 요소는 상위 컬렉션에 매핑됩니다.
Stream<list>> inputStream = Stream.of(Arrays.asList(1), Arrays.asList(2, 3), Arrays.asList(4, 5, 6)); List<integer> integerList = inputStream.flatMap((childList) -> childList.stream()).collect(Collectors.toList()); //将一个“二维数组”flat为“一维数组” integerList.forEach(System.out::println);</integer></list>
filter 메소드
filter 메소드는 필터링에 사용됩니다. Stream 요소를 처리하고 조건을 충족하는 요소로 새 Stream을 생성합니다.
filter 메소드에서 허용하는 매개변수는 Predicate 인터페이스 개체입니다. 이 인터페이스는 기능적 인터페이스입니다.
Stream<t> filter(Predicate super T>) predicate; @FunctionInterface public interface Predicate<t> { // 判断元素是否符合条件 boolean test(T t); }</t></t>
얻을 수 있는 결과 수를 제한하려면
// 获取当前Stream所有偶数的序列 Stream<integer> ns = Stream.of(1, 2, 3, 4, 5); ns.filter(n -> n % 2 == 0).forEach(System.out::println);</integer>
limit 및 Skip
limit를 사용하세요. 데이터베이스 건너뛰기가 사용됩니다. 제외되기 전의 결과 수입니다.
sorted
정렬 함수는 Comparator 기능 인터페이스를 구현하는 객체를 전달해야 합니다. 이 인터페이스의 추상 메서드 비교는 두 개의 매개변수를 받고 정수 값을 반환하며 이는 다른 일반적인 정렬과 일치합니다. 행동 양식.
distinct
distinct는 중복을 제거하는 데 사용되며, 이는 데이터베이스의 구별 사용과 일치합니다.
findFirst
findFirst 메소드는 항상 첫 번째 요소를 반환하며, 그렇지 않은 경우 반환 값 유형은 Optional
Stream<user> stream = users.stream(); Optional<string> userID = stream.filter(User::isVip).sorted((t1, t2) -> t2.getBalance() - t1.getBalance()).limit(3).map(User::getUserID).findFirst(); userID.ifPresent(uid -> System.out.println("Exists"));</string></user>
min, max
min은 정수 스트림의 최소값을 찾아 OptionalInt를 반환할 수 있습니다.
max는 정수 스트림의 최대값을 찾아 OptionalInt를 반환할 수 있습니다.
이 두 메서드는 종료 작업이며 한 번만 호출할 수 있습니다.
allMatch, anyMatch, noneMatch
allMatch: Stream의 모든 요소가 들어오는 조건자와 일치하고 true를 반환합니다.
anyMatch: Stream의 한 요소가 들어오는 조건자와 일치하는 한 true를 반환합니다
noneMatch: None of the Stream의 요소는 들어오는 조건자와 일치합니다. 입력된 조건자는 true를 반환합니다
reduce method
reduce 메서드는 Stream의 각 요소를 BiFunction에 한 번에 적용하고 결과를 병합합니다.
reduce 메소드가 허용하는 메소드는 BinaryOperator 인터페이스 객체입니다.
Optional<t> reduce(BinaryOperator<t> accumulator); @FuncationalInterface public interface BinaryOperator<t> extends BiFunction<t> { // Bi操作,两个输入,一个输出 T apply(T t, T u); }</t></t></t></t>
사용법:
// 求当前Stream累乘的结果 Stream<integer> ns = Stream.of(1, 2, 3, 4, 5); int r = ns.reduce( (x, y) -> x * y ).get(); System.out.println(r);</integer>
위 내용은 Java8에서 일반적으로 사용되는 내장 함수 요약(코드 예제)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

신흥 기술은 위협을 일으키고 Java의 플랫폼 독립성을 향상시킵니다. 1) Docker와 같은 클라우드 컴퓨팅 및 컨테이너화 기술은 Java의 플랫폼 독립성을 향상 시키지만 다양한 클라우드 환경에 적응하도록 최적화되어야합니다. 2) WebAssembly는 Graalvm을 통해 Java 코드를 컴파일하여 플랫폼 독립성을 확장하지만 성능을 위해 다른 언어와 경쟁해야합니다.

다른 JVM 구현은 플랫폼 독립성을 제공 할 수 있지만 성능은 약간 다릅니다. 1. OracleHotspot 및 OpenJDKJVM 플랫폼 독립성에서 유사하게 수행되지만 OpenJDK에는 추가 구성이 필요할 수 있습니다. 2. IBMJ9JVM은 특정 운영 체제에서 최적화를 수행합니다. 3. Graalvm은 여러 언어를 지원하며 추가 구성이 필요합니다. 4. AzulzingJVM에는 특정 플랫폼 조정이 필요합니다.

플랫폼 독립성은 여러 운영 체제에서 동일한 코드 세트를 실행하여 개발 비용을 줄이고 개발 시간을 단축시킵니다. 구체적으로, 그것은 다음과 같이 나타납니다. 1. 개발 시간을 줄이면 하나의 코드 세트 만 필요합니다. 2. 유지 보수 비용을 줄이고 테스트 프로세스를 통합합니다. 3. 배포 프로세스를 단순화하기위한 빠른 반복 및 팀 협업.

Java'SplatformIndenceFacilitatesCodereScoderEByWatHeAveringByTeCodetOrunonAnyPlatformwitHajvm.1) DevelopersCanwriteCodeOnceforConsentEStentBehaviorAcRossPlatforms.2) MAINTENDUCEDSCODEDOES.3) LIBRRIESASHSCORAREDERSCRAPERAREDERSPROJ

Java 응용 프로그램의 플랫폼 별 문제를 해결하려면 다음 단계를 수행 할 수 있습니다. 1. Java의 시스템 클래스를 사용하여 시스템 속성을보고 실행중인 환경을 이해합니다. 2. 파일 클래스 또는 java.nio.file 패키지를 사용하여 파일 경로를 처리하십시오. 3. 운영 체제 조건에 따라 로컬 라이브러리를로드하십시오. 4. visualVM 또는 JProfiler를 사용하여 크로스 플랫폼 성능을 최적화하십시오. 5. 테스트 환경이 Docker Containerization을 통해 생산 환경과 일치하는지 확인하십시오. 6. githubactions를 사용하여 여러 플랫폼에서 자동 테스트를 수행하십시오. 이러한 방법은 Java 응용 프로그램에서 플랫폼 별 문제를 효과적으로 해결하는 데 도움이됩니다.

클래스 로더는 통합 클래스 파일 형식, 동적로드, 부모 위임 모델 및 플랫폼 독립적 인 바이트 코드를 통해 다른 플랫폼에서 Java 프로그램의 일관성과 호환성을 보장하고 플랫폼 독립성을 달성합니다.

Java 컴파일러가 생성 한 코드는 플랫폼 독립적이지만 궁극적으로 실행되는 코드는 플랫폼 별입니다. 1. Java 소스 코드는 플랫폼 독립적 인 바이트 코드로 컴파일됩니다. 2. JVM은 바이트 코드를 특정 플랫폼의 기계 코드로 변환하여 크로스 플랫폼 작동을 보장하지만 성능이 다를 수 있습니다.

멀티 스레딩은 프로그램 대응 성과 리소스 활용을 향상시키고 복잡한 동시 작업을 처리 할 수 있기 때문에 현대 프로그래밍에서 중요합니다. JVM은 스레드 매핑, 스케줄링 메커니즘 및 동기화 잠금 메커니즘을 통해 다양한 운영 체제에서 멀티 스레드의 일관성과 효율성을 보장합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

WebStorm Mac 버전
유용한 JavaScript 개발 도구
