当前位置: 首页 > news >正文

简约淘宝网站模板免费下载搜索引擎营销的特点有

简约淘宝网站模板免费下载,搜索引擎营销的特点有,seo优化排名教程,怎么用word做网站Java中Stream流的详细使用介绍 **1. 创建 Stream**从集合创建从数组创建使用 Stream.of 创建创建无限流 **2. 中间操作**过滤:filter映射:map去重:distinct排序:sorted截取:limit 和 skip **3. 终端操作**收集&#xf…

Java中Stream流的详细使用介绍

    • **1. 创建 Stream**
      • 从集合创建
      • 从数组创建
      • 使用 `Stream.of` 创建
      • 创建无限流
    • **2. 中间操作**
      • 过滤:`filter`
      • 映射:`map`
      • 去重:`distinct`
      • 排序:`sorted`
      • 截取:`limit` 和 `skip`
    • **3. 终端操作**
      • 收集:`collect`
      • 遍历:`forEach`
      • 匹配:`anyMatch`、`allMatch`、`noneMatch`
      • 计数:`count`
      • 聚合:`reduce`
    • **4. 并行流**
    • **5. 常用工具类:`Collectors`**
      • 转换为列表:`toList`
      • 转换为集合:`toSet`
      • 转换为映射:`toMap`
      • 连接字符串:`joining`
    • **6. 示例代码**
    • **总结**

在 JDK 8 中, Stream 是 Java 集合操作的一个强大工具,它允许以声明式的方式处理数据集合(如过滤、映射、排序、聚合等)。 Stream 的核心思想是将数据操作分为 中间操作(Intermediate Operations)和 终端操作(Terminal Operations),并且支持并行处理。

1. 创建 Stream

可以通过多种方式创建 Stream

从集合创建

List<String> list = Arrays.asList("a", "b", "c");
Stream<String> stream = list.stream();

从数组创建

String[] array = {"a", "b", "c"};
Stream<String> stream = Arrays.stream(array);

使用 Stream.of 创建

Stream<String> stream = Stream.of("a", "b", "c");

创建无限流

Stream<Integer> infiniteStream = Stream.iterate(0, n -> n + 1); // 从 0 开始,每次加 1
Stream<Double> randomStream = Stream.generate(Math::random);    // 生成随机数流

2. 中间操作

中间操作返回一个新的 Stream,可以链式调用。

过滤:filter

List<String> list = Arrays.asList("apple", "banana", "cherry");
List<String> result = list.stream().filter(s -> s.startsWith("a")) // 过滤以 "a" 开头的字符串.collect(Collectors.toList());
// 结果:["apple"]

映射:map

List<String> list = Arrays.asList("apple", "banana", "cherry");
List<Integer> result = list.stream().map(String::length) // 将字符串映射为其长度.collect(Collectors.toList());
// 结果:[5, 6, 6]

去重:distinct

List<String> list = Arrays.asList("apple", "banana", "apple");
List<String> result = list.stream().distinct() // 去重.collect(Collectors.toList());
// 结果:["apple", "banana"]

排序:sorted

List<String> list = Arrays.asList("banana", "apple", "cherry");
List<String> result = list.stream().sorted() // 自然排序.collect(Collectors.toList());
// 结果:["apple", "banana", "cherry"]

截取:limitskip

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> result = list.stream().skip(2)  // 跳过前 2 个元素.limit(2) // 只取 2 个元素.collect(Collectors.toList());
// 结果:[3, 4]

3. 终端操作

终端操作会触发流的处理,并返回一个非流的结果。

收集:collect

List<String> list = Arrays.asList("apple", "banana", "cherry");
List<String> result = list.stream().filter(s -> s.startsWith("a")).collect(Collectors.toList());
// 结果:["apple"]

遍历:forEach

List<String> list = Arrays.asList("apple", "banana", "cherry");
list.stream().forEach(System.out::println);
// 输出:
// apple
// banana
// cherry

匹配:anyMatchallMatchnoneMatch

List<String> list = Arrays.asList("apple", "banana", "cherry");
boolean anyStartsWithA = list.stream().anyMatch(s -> s.startsWith("a")); // 是否有以 "a" 开头的
boolean allStartsWithA = list.stream().allMatch(s -> s.startsWith("a")); // 是否全部以 "a" 开头
boolean noneStartsWithZ = list.stream().noneMatch(s -> s.startsWith("z")); // 是否没有以 "z" 开头的

计数:count

List<String> list = Arrays.asList("apple", "banana", "cherry");
long count = list.stream().filter(s -> s.startsWith("a")).count();
// 结果:1

聚合:reduce

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
int sum = list.stream().reduce(0, Integer::sum); // 求和
// 结果:15

4. 并行流

通过 parallelStream()stream().parallel() 可以将流转换为并行流,利用多核处理器加速处理。

List<String> list = Arrays.asList("apple", "banana", "cherry");
List<String> result = list.parallelStream().filter(s -> s.startsWith("a")).collect(Collectors.toList());
// 结果:["apple"]

5. 常用工具类:Collectors

Collectors 提供了丰富的工具方法,用于将流转换为集合或其他数据结构。

转换为列表:toList

List<String> list = Arrays.asList("apple", "banana", "cherry");
List<String> result = list.stream().collect(Collectors.toList());

转换为集合:toSet

Set<String> set = list.stream().collect(Collectors.toSet());

转换为映射:toMap

Map<String, Integer> map = list.stream().collect(Collectors.toMap(s -> s, String::length));
// 结果:{"apple": 5, "banana": 6, "cherry": 6}

连接字符串:joining

String joined = list.stream().collect(Collectors.joining(", "));
// 结果:"apple, banana, cherry"

6. 示例代码

以下是一个完整的示例,展示 Stream 的常见用法:

import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;public class StreamExample {public static void main(String[] args) {List<String> list = Arrays.asList("apple", "banana", "cherry", "date");// 过滤、映射、排序、收集List<String> result = list.stream().filter(s -> s.length() > 4) // 过滤长度大于 4 的字符串.map(String::toUpperCase)    // 转换为大写.sorted()                   // 排序.collect(Collectors.toList()); // 收集为列表System.out.println(result); // 输出:[APPLE, BANANA, CHERRY]}
}

总结

  • Stream 提供了一种高效、简洁的方式来处理集合数据。
  • 中间操作(如 filtermap)是惰性的,只有在终端操作(如 collectforEach)调用时才会执行。
  • 并行流可以充分利用多核 CPU 的性能。
http://www.mmbaike.com/news/92083.html

相关文章:

  • 如何推广网站业务成都关键词排名系统
  • 网站怎么做用户体验百度推广客户端手机版
  • 宣讲家网站李慎明两学一做曼联vs曼联直播
  • 已有网站可以做服务器吗网站收录提交入口
  • 重庆石桥铺网站建设公司semen
  • 大学生毕业设计课题做网站电商网站设计方案
  • 如何做网站优化推广福州seo网络推广
  • html网站怎么搭建搜索引擎名词解释
  • 上海平台网站制作公司sem竞价托管公司
  • wordpress 404跳转首页沈阳seo优化新势力
  • 怎么做多语言的网站seo软文推广
  • 有没有做婚车的网站seo免费外链工具
  • 知名大型网站搭建公司seo是什么及作用
  • 西安专业做网站的公司有哪些无锡网站建设
  • 烟台网站建设服务灰色关键词怎么做排名
  • app外包公司大全成都最好的seo外包
  • 游戏网站模百度今日小说排行榜
  • 陕西省建设执业资格注册中心网站口碑营销的优势
  • 中小型企业查询百度优化公司
  • b2c网站维护拼多多代运营公司十大排名
  • 免费公司网站上海搜索引擎推广公司
  • 专业做装修的网站网络站点推广的方法
  • 烟台酒店网站建设湖北网络推广
  • 模具厂咋做网站百度seo效果
  • 网站制作费用是多少关键字排名优化工具
  • 免费做网站视频企业培训课程ppt
  • 济南做网站多少钱网络推广网站推广方法
  • 深圳网站建设制作哪家便宜seo培训
  • 网站建设维护 知乎百度搜索热度查询
  • 做网站一般图片多大小程序制作