举报投诉联系我们 手机版 热门标签 编程学
您的位置:编程学 > java分流什么意思 Java 流分区

java分流什么意思 Java 流分区

2023-05-24 03:18 Java教程

java分流什么意思 Java 流分区

java分流什么意思

Java分流是指将一个大量的数据流分割成多个小的数据流,以便进行处理。它可以帮助程序员更有效地处理大量的数据,并且可以减少系统资源的使用。

Java分流是一种高效的数据处理方式,它可以将大量的数据流分割成多个小的数据流,然后通过不同的线程来处理这些小的数据流。这样做可以有效地减少系统资源的使用,并且可以加快处理速度。

// Java代码实例 
public class StreamDemo { 

    public static void main(String[] args) { 

        // 创建一个Stream对象 
        Stream stream = Stream.of("a", "b", "c", "d"); 

        // 利用forEach()方法遍历Stream对象 
        stream.forEach(System.out::println); 

        // 利用parallel()方法将Stream对象转化为并行Stream对象 
        Stream parallelStream = stream.parallel(); 

        // 利用forEach()方法遍历并行Stream对象 
        parallelStream.forEach(System.out::println); 

    } 
}  

Java 流分区

Java流 - Java流分区


分区是分组的一种特殊情况。

分组数据基于从函数返回的键。可能有很多组。

分区仅处理基于谓词的两个组。评估为true的值为一个组,false为另一个组。

partitioningBy()方法,它收集映射中的数据,其键的总是布尔类型,在两个版本中重载。

partitioningBy(Predicate<? super T> predicate)
partitioningBy(Predicate<? super T> predicate,  Collector<? super T,A,D> downstream)

例子

第一个版本的partitioningBy()方法返回基于谓词执行分区的收集器。

以下代码显示如何根据性别对employee进行分区。

import java.time.LocalDate;
import java.time.Month;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class Main {
  public static void main(String[] args) {
    Map<Boolean,  List<Employee>>  partionedByMaleGender = 
    Employee.persons()
            .stream()
            .collect(Collectors.partitioningBy(Employee::isMale)); 
    System.out.println(partionedByMaleGender);
  }
}

class Employee {
  public static enum Gender {
    MALE, FEMALE
  }

  private long id;
  private String name;
  private Gender gender;
  private LocalDate dob;
  private double income;

  public Employee(long id, String name, Gender gender, LocalDate dob,
      double income) {
    this.id = id;
    this.name = name;
    this.gender = gender;
    this.dob = dob;
    this.income = income;
  }
  public boolean isMale() {
    return this.gender == Gender.MALE;
  }
  public static List<Employee> persons() {
    Employee p1 = new Employee(1, "Jake", Gender.MALE, LocalDate.of(1971,
        Month.JANUARY, 1), 2343.0);
    Employee p2 = new Employee(2, "Jack", Gender.MALE, LocalDate.of(1972,
        Month.JULY, 21), 7100.0);
    Employee p3 = new Employee(3, "Jane", Gender.FEMALE, LocalDate.of(1973,
        Month.MAY, 29), 5455.0);
    Employee p4 = new Employee(4, "Jode", Gender.MALE, LocalDate.of(1974,
        Month.OCTOBER, 16), 1800.0);
    Employee p5 = new Employee(5, "Jeny", Gender.FEMALE, LocalDate.of(1975,
        Month.DECEMBER, 13), 1234.0);
    Employee p6 = new Employee(6, "Jason", Gender.MALE, LocalDate.of(1976,
        Month.JUNE, 9), 3211.0);

    List<Employee> persons = Arrays.asList(p1, p2, p3, p4, p5, p6);

    return persons;
  }

  @Override
  public String toString() {
    String str = String.format("(%s, %s,  %s,  %s,  %.2f)n", id, name, gender,
        dob, income);
    return str;
  }
}

上面的代码生成以下结果。

例2

第二个版本允许我们指定另一个可以执行还原操作的收集器。

以下代码显示如何按性别分区员工,并以逗号分隔的字符串收集其名称:

import java.time.LocalDate;
import java.time.Month;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class Main {
  public static void main(String[] args) {
    Map<Boolean,String> partionedByMaleGender = Employee.persons()
        .stream()
        .collect(Collectors.partitioningBy(Employee::isMale, 
                   Collectors.mapping(Employee::getName, Collectors.joining(", "))));
    System.out.println(partionedByMaleGender);
  }
}

class Employee {
  public static enum Gender {
    MALE, FEMALE
  }

  private long id;
  private String name;
  private Gender gender;
  private LocalDate dob;
  private double income;

  public Employee(long id, String name, Gender gender, LocalDate dob,
      double income) {
    this.id = id;
    this.name = name;
    this.gender = gender;
    this.dob = dob;
    this.income = income;
  }
  public String getName() {
    return name;
  }
  public boolean isMale() {
    return this.gender == Gender.MALE;
  }
  public static List<Employee> persons() {
    Employee p1 = new Employee(1, "Jake", Gender.MALE, LocalDate.of(1971,
        Month.JANUARY, 1), 2343.0);
    Employee p2 = new Employee(2, "Jack", Gender.MALE, LocalDate.of(1972,
        Month.JULY, 21), 7100.0);
    Employee p3 = new Employee(3, "Jane", Gender.FEMALE, LocalDate.of(1973,
        Month.MAY, 29), 5455.0);
    Employee p4 = new Employee(4, "Jode", Gender.MALE, LocalDate.of(1974,
        Month.OCTOBER, 16), 1800.0);
    Employee p5 = new Employee(5, "Jeny", Gender.FEMALE, LocalDate.of(1975,
        Month.DECEMBER, 13), 1234.0);
    Employee p6 = new Employee(6, "Jason", Gender.MALE, LocalDate.of(1976,
        Month.JUNE, 9), 3211.0);

    List<Employee> persons = Arrays.asList(p1, p2, p3, p4, p5, p6);

    return persons;
  }
}

上面的代码生成以下结果。



阅读全文
以上是编程学为你收集整理的java分流什么意思 Java 流分区全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 编程学 bianchengxue.com 版权所有 联系我们
桂ICP备19012293号-7 返回底部