8.1Stream_部分

合集下载

C++流的概念

C++流的概念
错误信息从屏幕显示,而是重定向到其它地方,这时 使用cerr流显示信息。
例8.1 在除法操作不能进行时显示一条错误信息。 #include <iostream.h> void fn(int a,int b) {
第8章 I/O流
if(b==0) cerr << "zero encountered. " << "The message can not
fstreambase
文件流基础类
strstreambase
串流基础类
iostream
多目的输入/输出流类的基础类
fstream
文件流输入/输出类
strstream
串流输入/输出类
第8章 I/O流
在iostream.h 头文件中定义有cin、cout和cerr等流 类对象,分别表示标准输入设备键盘、标准输出设备 显示器和保存错误信息的设备显示器。标准设备见表 8.2。
(1) 把数据作为单字符流处理。可以处理简单的数据, 也可以处理复杂的数据结构。
(2) 直接调用操作系统的底层功能实现输入/输出操作。 这两种输入/输出功能都含文件和标准的输入/输出功能。 这里着重讨论流类的标准输入/输出、标准错误输出以及文 件输入/输出。
第8章 I/O流
8.2.1 标准输入输出 C++ 用 istream_withassign 类 和 ostream_withassign 类
第8章 I/O流
在每一个文件被打开时,都有一个FILE型文件指 针与之关联,以便保存文件的相关信息,完成文件的 读写操作。
对文件的操作一般分为3个步骤: l 使用文件打开函数打开文件,并与文件指针建立关系; l 利用文件指针和写文件、读文件函数对文件进行操作; l 使用文件关闭函数后再关闭文件。 1. 打开文件函数fopen 可使用fopen函数完成文件操作第一步,该函数定义为: FILE *fopen(const char * filename,const char * mode);

.stream()的用法

.stream()的用法

.stream()的用法`.stream()` 是Java 8 中引入的一个方法,用于将集合(如List、Set 等)转换为一个流(Stream)。

流是Java 8 中引入的一个新特性,它允许你以声明式方式处理数据集合,比如过滤、映射、排序等。

下面是`.stream()` 方法的一些常见用法:1. **过滤元素**:使用`filter()` 方法来过滤流中的元素。

例如,从整数列表中过滤出所有的偶数:```javaList<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);List<Integer> evenNumbers = numbers.stream().filter(n -> n % 2 == 0).collect(Collectors.toList());```2. **映射元素**:使用`map()` 方法将流中的元素映射到另一个对象。

例如,将整数列表中的每个元素都乘以2:```javaList<Integer> doubledNumbers = numbers.stream().map(n -> n * 2).collect(Collectors.toList());```3. **排序元素**:使用`sorted()` 方法对流中的元素进行排序。

例如,对一个字符串列表按长度进行排序:```javaList<String> words = Arrays.asList("apple", "banana", "cherry", "date"); List<String> sortedWords = words.stream().sorted(paringInt(Strin g::length)).collect(Collectors.toList());```4. **查找元素**:使用`findFirst()` 或`findAny()` 方法查找流中的第一个元素。

Java8新特性之Steam流式编程

Java8新特性之Steam流式编程

Java8新特性之Steam流式编程特地感谢鲁班⼤叔的分享,原学习地址:以下是学习过程整理的笔记1、简介Stream 流处理,⾸先要澄清的是 java8 中的 Stream 与 I/O 流 InputStream 和 OutputStream 是完全不同的概念。

Stream 机制是针对集合迭代器的增强。

流允许你⽤声明式的⽅式处理数据集合(通过查询语句来表达,⽽不是临时编写⼀个实现)2、创建对象流的三种⽅式1. 由集合对象创建流。

对⽀持流处理的对象调⽤ stream()。

⽀持流处理的对象包括 Collection 集合及其⼦类List<Integer> list = Arrays.asList(1,2,3);Stream<Integer> stream = list.stream();2. 由数组创建流。

通过静态⽅法 Arrays.*stream()* 将数组转化为流(Stream)IntStream stream = Arrays.stream(new int[]{3, 2, 1});3. 通过静态⽅法 Stream.of() ,但是底层其实还是调⽤ Arrays.stream()Stream<Integer> stream = Stream.of(1, 2, 3);注意:还有两种⽐较特殊的流空流:Stream.empty()⽆限流:**Stream.generate() ** 和 **Stream.iterate() **。

可以配合 limit() 使⽤可以限制⼀下数量// 接受⼀个 Supplier 作为参数Stream.generate(Math::random).limit(10).forEach(System.out::println);// 初始值是 0,新值是前⼀个元素值 + 2Stream.iterate(0, n -> n + 2).limit(10).forEach(System.out::println);3、流处理的特性1. 不存储数据2. 不会改变数据源3. 不可以重复使⽤测试⽤例:package com.godfrey.stream.features;import org.junit.Assert;import org.junit.Test;import java.util.ArrayList;import java.util.List;import java.util.stream.Collectors;import java.util.stream.Stream;/*** 流特性** @author godfrey* @since 2021-08-15*/class StreamFeaturesTest {/*** 流的简单例⼦*/@Testpublic void test1() {List<Integer> list = Stream.of(1, 2, 5, 9, 7, 3).filter(val -> val > 2).sorted().collect(Collectors.toList());for (Integer item : list) {System.out.println(item);}}/*** 流不会改变数据源*/@Testpublic void test2() {List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);list.add(1);Assert.assertEquals(3, list.stream().distinct().count());Assert.assertEquals(4, list.size());}/*** 流不可以重复使⽤*/@Test(expected = IllegalStateException.class)public void test3() {Stream<Integer> integerStream = Stream.of(1, 2, 3);Stream<Integer> newStream = integerStream.filter(val -> val > 2);integerStream.skip(1);}}⾸先,test1() 向我们展⽰了流的⼀般⽤法,由下图可见,源数据流经管道,最后输出结果数据。

java中stream流的中间操作方法

java中stream流的中间操作方法

java中stream流的中间操作方法Java中的Stream流提供了丰富的中间操作方法,可以对流进行各种操作和处理。

下面是一些常用的中间操作方法:1. filter(Predicate<T> predicate):根据指定的谓词(Predicate)过滤流中的元素,只保留满足谓词的元素。

2. map(Function<T, R> mapper):将流中的每个元素通过给定的函数(Function)进行映射,返回一个包含映射结果的新流。

3. flatMap(Function<T, Stream<R>> mapper):将每个元素映射为一个流,然后将这些流合并成一个新的流。

4. distinct():去除流中重复的元素,保留唯一的元素。

5. sorted():对流中的元素进行排序,默认使用元素的自然顺序进行排序。

6. peek(Consumer<T> action):对流中的每个元素执行指定的操作,返回一个新的流,可以用于调试或观察流中的元素。

7. limit(long maxSize):返回一个新的流,只包含前N个元素。

8. skip(long n):返回一个新的流,跳过前N个元素。

9. takeWhile(Predicate<T> predicate):从开头开始获取连续满足指定谓词(Predicate)的元素,直到遇到第一个不满足谓词的元素为止。

10. dropWhile(Predicate<T> predicate):从开头开始丢弃连续满足指定谓词(Predicate)的元素,直到遇到第一个不满足谓词的元素为止。

11. parallel():将流转换为并行流,可以加速流的处理。

12. sequential():将并行流转换回顺序流。

13. unordered():取消流中的元素顺序,可以提高性能。

这些中间操作方法可以根据具体的需求进行组合和链式调用,非常灵活和强大。

第八章输入输出处理输入输出处理是...

第八章输入输出处理输入输出处理是...

第八章输入/输出处理输入/输出处理是程序设计中非常重要的一部分,比如从键盘读取数据、从文件中读取数据或向文件中写数据等等,而键盘、监视器、磁盘存储设备都称为输入、输出源。

Java把这些不同类型的输入、输出源抽象为流(stream)。

Java程序可以用输入流从一些输入源读数据,用输出流向一些输出源写数据。

Jdk 提供了包java.io,其中包括一系列的类来实现输入/输出处理。

从jdk1.1开始,java.io包中的流包括字节流和字符流。

§8.1输入/输出字节流概述§8.1.1 I/O字节流的层次结构在java中,所有的输入流都是从抽象类InputStream继承而来,所有的输出流都是从OutputStream 继承而来。

以下给出了java语言IO包中输入/输出处理类之间的继承关系。

输入、输出字节流的类层次一、简单的输入、输出流1.FileInputStream和FileOutputStream:用于本地文件系统的文件读写。

2.PipedInputStream和PipedOutputStream:用于完成管道的输入和输出。

管道用于将一个程序(或线程或代码块)的输出引导进另一个程序(或线程或代码块)的输入,所有PipedInputStream必须连接到一个PipedOutputStream所有PipedOutputStream必须连接到一个PipedInputStream。

3.ByteArrayInputStream和ByteArrayOutputStream:读写内存数据。

4.SequenceInputStream:用于将多个输入流连接到一个输出流。

5.StringBufferInputStream:用于读取StringBuffer类可变字符串中的数据。

二、过滤流1.DataInputStream和DataOutputStream:用一种与机器无关的格式读写java语言的基本数据类型。

java08(第8章输入输出流)

java08(第8章输入输出流)

在java.io包中定义了很多这二个基本类具体实现 包中定义了很多这二个基本类具体实现 输入输出功能的子类, 输入输出功能的子类,表8.1为部分常用字节输入 为部分常用字节输入 流类和字节输出流子类的功能。 流类和字节输出流子类的功能。
表8.1
类 名 FileInputStream 和 FileOutputStream ByteArrayInputStream和 ByteArrayOutputStream ObjectInputStream 和 ObjectOutputStream FilterInputStream 和 FilterOutputStream DataInputStream 和 DataOutputStream BufferedInputStream 和 BufferedOutputStream
【例8-1 】
1. /* 读取文件 */ 2. import java.io.FileInputStream; 3. import javax.swing.JOptionPane; 4. class Example8_1 5. { public static void main( String args[ ]) 6. { byte buffer[ ] = new byte[2056]; 7. String str; 8. try{ 9. File file=new File("d:/jtest/test.dat"); 10. FileInputStream fileInput = new FileInputStream(file); 11. int bytes = fileInput.read( buffer, 0, 2056 ); //读到的字节数 读到的字节数 12. str = new String( buffer, 0, bytes ); 13. } 14. catch(Exception e) 15. { 16. str= e.toString(); 17. } 18. JOptionPane.showMessageDialog(null,str); 19. System.exit(0); //退出程序 退出程序 20. } 21. }

java中stream流的用法

java中stream流的用法

Java中Stream流的用法介绍Stream是Java 8中引入的一个新的API,用于对集合中的元素进行各种操作。

它可以让我们以一种声明式的方式处理数据,提供了更简洁、更高效的编程方式。

本文将详细介绍Java中Stream流的用法。

Stream的基本特性•Stream是用来对集合进行处理的工具,它并不存储数据,而是通过函数式编程的方式对数据进行操作。

•Stream的操作分为两类:Intermediate(中间操作)和Terminal(终端操作)。

•Intermediate操作是对数据进行处理、转换或过滤等操作,它们可以被连接起来形成一个操作链。

•Terminal操作是对Intermediate操作链进行执行的操作,它会返回一个结果或一个最终的数据。

创建Stream要使用Stream,首先需要将一个数据源(如集合、数组等)转换为Stream。

在Java中,可以通过以下几种方式来创建Stream:1. 通过集合创建Stream可以通过集合的stream()方法将集合转换为Stream。

例如:List<String> list = Arrays.asList("a", "b", "c", "d");Stream<String> stream = list.stream();2. 通过数组创建Stream可以通过Stream.of()方法来创建一个包含数组元素的Stream。

例如:String[] array = {"a", "b", "c", "d"};Stream<String> stream = Stream.of(array);3. 通过数值范围创建Stream可以使用IntStream、LongStream或DoubleStream来创建包含特定范围内数值的Stream。

linux stream用法

linux stream用法

linux stream用法"stream" 可以指代多个在Linux 系统中使用的命令或工具,它们主要用于处理、转换和操作数据流。

下面列举几个常见的"stream" 命令及其用法:1、cat:用于连接文件并打印到标准输出。

例如,cat file.txt 将文件file.txt 的内容显示在终端上。

2、grep:用于搜索文本中与模式匹配的行。

例如,grep "keyword" file.txt 将在file.txt 中搜索包含"keyword" 的行。

3、sed:用于对文本进行替换、删除、插入等处理。

例如,sed 's/old/new/g' file.txt 将file.txt 文件中所有出现的"old" 替换为"new"。

4、awk:用于处理和分析文本数据。

它支持自定义脚本来提取、转换和计算数据。

例如,awk '{print $1}' file.txt 将打印出file.txt 文件中每一行的第一个字段。

5、cut:用于从文件或标准输入中剪切字段。

例如,cut -d"," -f1,3 file.csv 将从逗号分隔的file.csv 文件中提取第1 和第3 列。

6、tee:用于同时输出到文件和标准输出。

例如,command | tee output.txt 将命令的输出同时重定向到文件output.txt 和标准输出。

这些是"stream" 相关命令的一些常见用法,它们对于在Linux 系统中处理和操作数据流非常有用。

可以根据具体需求和情况使用相应的命令来实现所需的功能。

stream的用法总结大全2篇

stream的用法总结大全2篇

stream的用法总结大全stream的用法总结大全精选2篇(一)stream是一种用于处理集合的概念,它可以让我们以声明性的方式对集合进行各种操作。

Java中的Stream用于对集合对象进行高效且函数式的操作,它提供了一种更简洁、更可读且更灵活的方式来处理集合数据。

下面是stream的一些常见用法总结:1. 创建Stream:- 通过集合创建:可以使用`stream()`方法将集合转换为Stream,例如:`List.stream()`、`Set.stream()`等。

- 通过数组创建:`Arrays.stream(array)`。

- 通过值创建:`Stream.of(value1, value2, ...)`。

2. 集合操作:- 过滤:`filter(predicate)`,根据指定的条件过滤集合中的元素。

- 映射:`map(function)`,将集合中的每个元素进行映射操作,并返回一个新的Stream。

- 排序:`sorted()`,对集合中的元素进行排序。

- 去重:`distinct()`,去除集合中的重复元素。

- 截取:`limit(n)`,返回前n个元素。

- 跳过:`skip(n)`,跳过前n个元素。

- 匹配:`anyMatch(predicate)`、`allMatch(predicate)`、`noneMatch(predicate)`,判断集合中的元素是否满足指定条件。

3. 聚合操作:- 统计个数:`count()`,返回集合中的元素个数。

- 求和、求平均、求最大值、求最小值:`sum()`、`average()`、`max()`、`min()`。

- 归约:`reduce(identity, accumulator)`,根据指定的累加器对集合中的元素进行归约操作。

4. 收集结果:- 转换为集合:`collect(Collectors.toList())`、`collect(Collectors.toSet())`等。

Flotherm V8.1 练习题 6 添加散热器

Flotherm V8.1 练习题 6 添加散热器
将该网格约束Attach(应用)于改区域的‘Override All’。
在项目管理窗口(PM)中选择“Detail Component”组件并点击‘Toggle Localize Grid’(局部网格)图标 ,使“Detail Component”组件内所有元件的周围都布满网格线。
您还可以通过选中物体或组件后按键盘热键"l"的方法来激活或取消局部网格。
内部3齿,齿高22 mm,齿宽1.25 mm。
齿间的网格单元数=3。
请确保您刚刚创建的散热器在“Detail Component”组件中。
在+Y视图中查看散热器,保证散热器的齿沿Z轴正方向排列。如果不是这样就要通过点击绘图板中的旋转图标 对散热器进行旋转,以使其置于正确的方向。
查看绘图板(DB)中的不同视图(+X或+Z),检查散热器是否正确放置在7W的元件上部。如果没有,将其拖动到正确位置。
将‘System Grid’(系统网格)设置为‘Coarse’(粗糙)。
保存此项目。在项目管理窗口(PM)菜单中选择[Solve/Re-initialize ](求解/重新初始化),然后点击图标 开始求解。
一旦明显发现模型不能收敛,请点击图标 停止求解。这样,您可以尽早停止求解以免浪费时间。
此模型有错误,因而需要执行以下纠错步骤:
在多数强制对流系统中,主要的热量是通过对流来传递,所以辐射的影响可以忽略,不需要求解。
右键点击“Chassis”进入‘Construction’菜单。将‘Modeling Level’(建模级别)项由‘Thick’(厚)改为‘Thin’(薄)。
由于不计算辐射,我们不再需要机箱壁的固体温度,所以可将它建模为‘Thin’ (薄)。另一个可这样建模的原因是通过机箱壁传导的热量很少。这样建模还有一个优势,即可减少网格数量。

stream流的map用法

stream流的map用法

stream流的map用法Java 8引入了Stream API,这是一个非常强大的工具,可以用来处理集合类数据。

在处理集合类数据时,map操作是一个非常常见的操作,它可以将集合中的每个元素都映射(transform)成一种新的类型或格式。

这篇文章将详细介绍Stream流的map用法。

一、什么是Stream流首先,我们需要了解什么是Stream流。

在Java 8中,Stream流是一个抽象概念,它代表了一个序列的数据。

这个数据可以是任何集合类数据(如List、Set、Map等),也可以是自定义的对象数组。

Stream流提供了一种简洁而强大的方式来处理这些数据。

二、map操作map操作是Stream流中一个非常重要的操作,它可以将集合中的每个元素都映射(transform)成一种新的类型或格式。

map操作接受一个函数(通常是Lambda表达式或方法引用)作为参数,并将这个函数应用到集合中的每个元素上。

例如,假设我们有一个整数列表,我们想要将其中的每个元素都乘以2,那么就可以使用map操作来完成这个任务:```javaList<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);List<Integer> doubledNumbers = numbers.stream().map(n -> n * 2);```在这个例子中,map操作将列表中的每个元素都乘以2,并将结果存储在新的列表中。

三、Lambda表达式和方法的引用在Java 8中,Lambda表达式是一种简洁而强大的方式来定义函数式接口的方法。

Lambda表达式可以用来表示一个只有一个参数并返回一个结果的可选操作。

因此,在map操作中,我们通常会使用Lambda表达式或方法引用来定义一个函数,并将其应用到集合中的每个元素上。

例如,假设我们有一个Person对象的列表,我们想要将其中的每个Person对象都映射成一个新的Person对象,其中新对象的name属性是原对象的name属性的首字母大写,age属性是原对象的age属性的两倍。

stream用法

stream用法

stream用法
左右
stream是java8中添加的一种新的抽象数据结构,它可以支持顺序和并行的对原始数据进行操作,可以通过实现一系列步骤来转换数据,这个过程就叫流水线。

stream的操作分为两种:中间操作和终止操作。

中间操作定义了流水线的处理步骤,常见的中间操作有:filter(过滤)、map(映射)、skip(跳过)、limit(限制)等。

而终止操作定义了流水线处理的最终结果,常见的终止操作有:forEach(遍历)、
collect(收集)、reduce(聚合)、max、min等。

stream的使用非常简单,只需要利用链式调用即可实现:先调用中间操作,再调用终止操作,Stream本身不会存储元素,它只是把操作连接起来形成一条流水线,每一个中间操作都返回一个新的Stream,流水线的最后是终止操作,它的返回值或结果就是Stream
结束的结果。

要把流水线中的中间操作及终止操作有效的执行,必须调用terminal函数。

stream是一个强大的数据操作的工具,可以对集合中的元素进行一系列的操作,不用再去思考复杂的算法,只需要利用现有的API即可快速实现。

另外,stream是懒加载,只有在终止操作发生时才会实际去执行所有转换操作,从而节约资源,使用stream可以提
高性能和代码的可读性。

stream parallelstream原理

stream parallelstream原理

一、stream及parallelstream的定义1.1 stream是Java 8引入的用于处理集合数据的抽象概念,它可以对集合进行过滤、映射、排序、归约等操作。

1.2 parallelstream是stream的并行版本,可以充分利用多核处理器的优势,在处理大量数据时提高效率。

二、stream和parallelstream的使用方法2.1 使用stream对集合进行串行操作时,可以通过调用sequential()方法将其转换为串行流。

2.2 使用parallelstream时,可以通过调用parallel()方法将stream转换为并行流,以实现并行处理。

三、stream与parallelstream的原理比较3.1 stream的原理:在串行模式下,stream通过单线程对数据进行处理,适合处理数据量较小的集合。

3.2 parallelstream的原理:在并行模式下,parallelstream会将数据分成多个子任务,并行处理,通过Fork/Join框架实现任务的划分和合并。

四、stream与parallelstream的适用场景4.1 适用stream的场景:对于数据量较小且操作简单的集合,可以使用stream进行串行处理,简单高效。

4.2 适用parallelstream的场景:对于数据量较大且处理复杂的集合,可以使用parallelstream进行并行处理,提高处理效率。

五、stream与parallelstream的性能比较5.1 在小数据量的情况下,串行操作可能会更快,因为并行操作存上线程切换和任务划分的开销。

5.2 在大数据量的情况下,parallelstream通常具有更好的性能,可以充分利用多核处理器的优势,提高处理效率。

六、使用注意事项6.1 在使用parallelstream时,需要注意并发安全性,避免出现线程安全问题。

6.2 在选择stream还是parallelstream时,需要根据具体的业务场景和数据量来决定,不可一概而论。

stream流的foreach用法

stream流的foreach用法

stream流的foreach用法
stream流是Java8新增的一种用于操作集合的工具,可以方便地对集合进行过滤、排序、映射等操作。

其中,foreach方法是stream 流中常用的一个方法,用于对集合中的元素进行遍历,并执行相应的操作。

具体来说,foreach方法接受一个函数式接口作为参数,该接口可以是Lambda表达式、方法引用或匿名内部类。

在遍历集合的过程中,foreach方法会依次将集合中的每个元素传给函数式接口,然后执行接口中定义的操作。

例如,我们可以使用foreach方法来遍历一个整型数组,并打印出数组中所有元素的值:
int[] nums = {1, 2, 3, 4, 5};
Arrays.stream(nums).forEach(System.out::println);
在上述代码中,我们首先使用Arrays.stream()方法将整型数组转换为stream流,然后使用forEach方法对流中的元素进行遍历,最后使用System.out::println语法糖将每个元素的值打印到控制
台上。

除了打印元素值之外,foreach方法还可以执行各种其他操作,例如过滤元素、计算元素的和、求出最大值等等。

总之,通过掌握stream流的foreach方法,我们可以更加灵活地操作集合,提高代码的可读性和可维护性。

- 1 -。

jdk8中stream中limit方法

jdk8中stream中limit方法

(原创实用版3篇)编制人员:_______________审核人员:_______________审批人员:_______________编制单位:_______________编制时间:____年___月___日序言下面是本店铺为大家精心编写的3篇《jdk8中stream中limit方法》,供大家借鉴与参考。

下载后,可根据实际需要进行调整和使用,希望能够帮助到大家,谢射!(3篇)《jdk8中stream中limit方法》篇1在 JDK8 中,Stream API 是一个新的处理集合数据的方式,它提供了一种函数式编程的方式来处理集合数据。

Stream API 中,limit 方法是一个用来限制流中元素数量的方法。

具体来说,limit 方法接受一个参数,表示限制流中元素的数量。

例如,下面的代码将只返回前 5 个元素:```List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); List<Integer> limitedNumbers = numbers.stream().limit(5).collect(Collectors.toList());```在这个例子中,我们首先创建了一个整数列表。

然后,我们使用 stream 方法将这个列表转换为一个流。

接着,我们使用 limit 方法限制流的元素数量为 5。

最后,我们使用 collect 方法将限制后的流收集到一个新的列表中。

需要注意的是,limit 方法并不会修改原始的流,而是返回一个新的流。

此外,如果流的元素数量小于指定的数量,那么 limit 方法将不会对流进行任何修改。

除了 limit 方法之外,Stream API 还提供了其他一些方法来处理流的元素,例如 filter、map、reduce 等等。

《jdk8中stream中limit方法》篇2在 JDK8 中,Stream API 是一个新的处理集合数据的方式,它提供了一种函数式编程的方式来处理集合数据。

Android8.1MTK6739修改文档

Android8.1MTK6739修改文档

Android8.1MTK6739修改⽂档1. 信息-设置-通知-重要程度-中(不发出提⽰⾳),⾮锁屏界⾯下⽆提⽰通知框弹出vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/phone/StatusBar.javamethod:shouldPeek@@ -7578,8 +7578,8 @@ private PowerManager.WakeLock mNotificationWakeLock;}// Allow peeking for DEFAULT notifications only if we're on Ambient Display.- int importanceLevel = isDozing() ? NotificationManager.IMPORTANCE_DEFAULT- : NotificationManager.IMPORTANCE_HIGH;+ int importanceLevel = NotificationManager.IMPORTANCE_LOW/*devin.20180510 isDozing() ? NotificationManager.IMPORTANCE_DEFAULT+ : NotificationManager.IMPORTANCE_HIGH;*/if (mNotificationData.getImportance(sbn.getKey()) < importanceLevel) {if (true/**DEBUG*/) Log.d(TAG, "No peeking: unimportant notification: " + sbn.getKey());return false;2. 关机动画播放时长/关机时长/关机动画播放不全vendor/mediatek/proprietary/frameworks/base/services/core/java/com/mediatek/server/MtkShutdownThread.javamethod:showCustomizedShutdownAnimation- private static final int MIN_SHUTDOWN_ANIMATION_PLAY_TIME = 5 * 1000;+ private static final int MIN_SHUTDOWN_ANIMATION_PLAY_TIME = 10 * 1000;//devin.20180510beginAnimationTime = 0;boolean mShutOffAnimation = configShutdownAnimation(context);- int screenTurnOffTime = getScreenTurnOffTime(context);+ int screenTurnOffTime = MIN_SHUTDOWN_ANIMATION_PLAY_TIME;//getScreenTurnOffTime(context);devin.20180510 synchronized (mEnableAnimatingSync) {if (mEnableAnimating) {if (mShutOffAnimation) {3. 灭屏状态下收到短信、蓝⽛收到⽂件,屏幕亮屏vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/phone/StatusBar.java+private PowerManager.WakeLock mNotificationWakeLock;public void onAsyncInflationFinished(Entry entry) {mPendingNotifications.remove(entry.key);// If there was an async task started after the removal, we don't want to add it back to// the list, otherwise we might get leaks.boolean isNew = mNotificationData.get(entry.key) == null;+ //devin.20180424+ mNotificationWakeLock = mPowerManager.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP + | PowerManager.ON_AFTER_RELEASE, TAG);+ //end+ mNotificationWakeLock.setReferenceCounted(false);if (isNew && !entry.row.isRemoved()) {protected void addNotificationViews(Entry entry) {if (entry == null) {return;}// Add the expanded view and icon.mNotificationData.add(entry);Log.d(TAG, "packgename:"+entry.key);+ //devin.20180424+ if (!mPowerManager.isScreenOn() && entry.key != null && (entry.key.contains("com.google.android.apps.messaging")+ || entry.key.contains("com.android.bluetooth"))){+ mNotificationWakeLock.acquire(5000);+ Log.d(TAG, "special app notification turn screen on");+ }+ //endupdateNotifications();}public void updateNotification(StatusBarNotification notification, RankingMap ranking)throws InflationException {......if (entry == null) {return;}mNotificationData.add(entry);+ //devin.20180424+ if (!mPowerManager.isScreenOn() && entry.key != null && (entry.key.contains("com.google.android.apps.messaging")+ || entry.key.contains("com.android.bluetooth"))){+ mNotificationWakeLock.acquire(5000);+ Log.d(TAG, "special app notification turn screen on");+ }+ //endmHeadsUpEntriesToRemoveOnSwitch.remove(entry);mRemoteInputEntriesToRemoveOnCollapse.remove(entry);......4. 默认⾳量frameworks/base/media/java/android/media/AudioSystem.java@@ -866,11 +866,11 @@ public class AudioSystem*/public static int[] DEFAULT_STREAM_VOLUME = new int[] {4, // STREAM_VOICE_CALL- 15, // STREAM_SYSTEM- 15, // STREAM_RING- 15, // STREAM_MUSIC- 15, // STREAM_ALARM- 15, // STREAM_NOTIFICATION+ 12, // STREAM_SYSTEM+ 12, // STREAM_RING+ 12, // STREAM_MUSIC+ 12, // STREAM_ALARM+ 12, // STREAM_NOTIFICATION多媒体⾳量frameworks/base/services/core/java/com/android/server/audio/AudioService.java@@ -712,7 +712,7 @@ public class AudioService extends IAudioService.StubMAX_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] / 4;} else {AudioSystem.DEFAULT_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] =- MAX_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] / 3;+ /*MAX_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] / 3*/ 12;//devin.20180509}}5. 默认亮度vendor/mediatek/proprietary/packages/apps/SettingsProvider/res/values/defaults.xml+ <integer name="def_screen_brightness">158</integer>6. 去掉设置-应⽤和通知-查看全部23个应⽤-信息-应⽤通知-应⽤中的其他设置vendor/mediatek/proprietary/packages/apps/MtkSettings/src/com/android/settings/notification/NotificationSettingsBase.java protected void addAppLinkPref() {- if (mAppRow.settingsIntent != null && mAppLink == null) {+ Log.i("joyatel","pkg:"+mAppRow.pkg);+ if (mAppRow.settingsIntent != null && mAppLink == null && !mAppRow.pkg.equals("com.google.android.apps.messaging")/*devin.20180507*/) { addPreferencesFromResource(R.xml.inapp_notification_settings);mAppLink = (Preference) findPreference(KEY_APP_LINK);7. 打开设置-存储中的默认存储器菜单及功能vendor/mediatek/proprietary/packages/apps/MtkSettings/src/com/mediatek/settings/deviceinfo/StorageSettingsExts.java@@ -57,13 +57,14 @@ public class StorageSettingsExts {mDiskCategory = (PreferenceCategory) mRoot.findPreference(KEY_DEFAULT_WRITE_DISK);- if (!FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) {+ if (FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) {mRoot.removePreference(mDiskCategory);}}private void updateDefaultWriteDiskCategory() {- if (!FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) {+ Log.i("devin","MTK_A1_FEATURE:"+FeatureOption.MTK_A1_FEATURE);+ if (FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) {return;}vendor/mediatek/proprietary/frameworks/base/core/java/com/mediatek/storage/StorageManagerEx.java@@ -101,8 +101,15 @@ public class StorageManagerEx {boolean supportMultiUsers = false;// Modifications for O1.BSP+ as default path feature is not supported.- path = Environment.getExternalStorageDirectory().getAbsolutePath();+ //devin.20180424+ // path = Environment.getExternalStorageDirectory().getAbsolutePath();+ path = SystemProperties.get(PROP_SD_DEFAULT_PATH);+ Log.i(TAG,"path1:"+path);+ if(path.equals("")){+ path = Environment.getExternalStorageDirectory().getAbsolutePath();+ }Log.i(TAG, " Default path taken as primary storage, path=" + path);+ //devin.20180424// Modifications complete for O1.BSP+.return path;通话录⾳、FM录⾳默认存储跟随设置vendor/mediatek/proprietary/packages/apps/FMRadio/src/com/android/fmradio/FmUtils.java+import com.mediatek.storage.StorageManagerEx;@@ -201,7 +202,8 @@ public class FmUtils {* @return The phone storage path*/public static String getDefaultStoragePath() {- return Environment.getExternalStorageDirectory().getPath();+ // return Environment.getExternalStorageDirectory().getPath();+ return StorageManagerEx.getDefaultPath(); //devin.20180424}vendor/mediatek/proprietary/packages/services/CallRecorderService/src/com/mediatek/callrecorder/Recorder.java @@ -116,8 +116,8 @@ public abstract class Recorder implements OnErrorListener {SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd_HH.mm.ss");String prefix = dateFormat.format(new Date());- //File sampleDir = new File(StorageManagerEx.getDefaultPath());- File sampleDir = Environment.getExternalStorageDirectory();+ File sampleDir = new File(StorageManagerEx.getDefaultPath());//devin.20180424+ //File sampleDir = Environment.getExternalStorageDirectory();8. 相机设置拍照预览默认4:3vendor/mediatek/proprietary/packages/apps/Camera/src/com/android/camera/bridge/CameraDeviceExt.java@@ -190,7 +190,8 @@ public class CameraDeviceExt implements ICameraDeviceExt {mParametersExt);if (supportedRatios != null && supportedRatios.size() > 0) {SharedPreferences.Editor editor = mPreferences.edit();- String ratioString = supportedRatios.get(supportedRatios.size() - 1);+ //String ratioString = supportedRatios.get(supportedRatios.size() - 1);+ String ratioString = supportedRatios.get(0);//devin.2018420editor.putString(SettingConstants.KEY_PICTURE_RATIO, ratioString);editor.apply();pictureRatio = ratioString;vendor/mediatek/proprietary/packages/apps/Camera/src/com/mediatek/camera/setting/SettingUtils.java@@ -259,7 +259,8 @@ public class SettingUtils {String ratioString = null;if (supportedRatios != null && supportedRatios.size() > 0) {SharedPreferences.Editor editor = sharedPreferences.edit();- ratioString = supportedRatios.get(supportedRatios.size() - 1);+ //ratioString = supportedRatios.get(supportedRatios.size() - 1);+ ratioString = supportedRatios.get(0);//devin.20180420editor.putString(SettingConstants.KEY_PICTURE_RATIO, ratioString);editor.apply();9. ⽂件默认显⽰内部存储设备public static boolean mustShowDeviceRoot(Intent intent) {/// M: Discussed with QA, this option should always be shown- return false;+ return true;//devin.20180423//return intent.getBooleanExtra(DocumentsContract.EXTRA_SHOW_ADVANCED, false);}10. Camera 屏蔽⾼温报警和连拍vendor/mediatek/proprietary/packages/apps/Camera/src/com/mediatek/camera/AdditionManager.java@@ -78,12 +78,12 @@ public class AdditionManager {mIContinuousShotAddition = new ContinuousShot(cameraContext);mDistanceInfo = new DistanceInfo(cameraContext);mRemoteCameraAddition = new RemoteCameraAddition(cameraContext);- mNormalAddition.add(new ThermalThrottle(cameraContext));+ // mNormalAddition.add(new ThermalThrottle(cameraContext));mPhotoAddtion.add(new Asd(cameraContext));- mPhotoAddtion.add(mIContinuousShotAddition);+ //mPhotoAddtion.add(mIContinuousShotAddition);mNormalAddition.add(mDistanceInfo);mPhotoAddtion.add(mRemoteCameraAddition);- mDenoiseAddition.add(mIContinuousShotAddition);+ // mDenoiseAddition.add(mIContinuousShotAddition);}vendor/mediatek/proprietary/packages/apps/Camera/src/com/mediatek/camera/addition/thermalthrottle/ThermalThrottle.java @@ -148,7 +148,7 @@ public class ThermalThrottle extends CameraAddition {private void updateCountDownTime(final Activity activity) {Log.d(TAG, "[updateCountDownTime]mCountDown = " + mWatingTime + ",mIsResumed = "+ mIsResumed);- if (isTemperTooHigh()) {+ if (false/**isTemperTooHigh()**/) {if (mWatingTime > 0) {mWatingTime--;mAlertDialog.setCountDownTime(String.valueOf(mWatingTime));11. 低电量不能开启⼿电筒vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/policy/FlashlightControllerImpl.java +import android.os.BatteryManager;+import android.widget.Toast;public void setFlashlight(boolean enabled) {+ BatteryManager batteryManager=(BatteryManager)mContext.getSystemService(mContext.BATTERY_SERVICE);+ int counter = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CHARGE_COUNTER);+ int averge = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CURRENT_AVERAGE);+ int current_now = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CURRENT_NOW);+ Log.d(TAG,"FlashlightControllerImpl::setFlashlight...counter:"+counter+", averge:"+averge+", current_now:"+current_now);++ boolean enoughtBatteryLevel = counter >= 3;+ if(!enoughtBatteryLevel){+ Toast.makeText(mContext, "low battery level", 3000).show();+ }++ enabled = enabled&enoughtBatteryLevel;boolean pendingError = false;synchronized (this) {if (mCameraId == null) return;12. 添加虚拟键振动功能frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java@@ -6097,7 +6097,7 @@ public class PhoneWindowManager implements WindowManagerPolicy {}boolean useHapticFeedback = down- && (policyFlags & WindowManagerPolicy.FLAG_VIRTUAL) != 0+ // && (policyFlags & WindowManagerPolicy.FLAG_VIRTUAL) != 0&& event.getRepeatCount() == 0;13. 去掉关闭⽹络数据时的叉号vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/policy/TelephonyIcons.java- static final int ICON_DATA_DISABLED = R.drawable.stat_sys_data_disabled;+ static final int ICON_DATA_DISABLED = -1/**R.drawable.stat_sys_data_disabled**/;- static final int QS_ICON_DATA_DISABLED = R.drawable.ic_qs_data_disabled;+ static final int QS_ICON_DATA_DISABLED = -1/**R.drawable.ic_qs_data_disabled**/;14. 切换语⾔后设置中的"勿扰偏好设置"菜单下的⾃动规则字符串不刷新frameworks/base/services/core/java/com/android/server/notification/NotificationManagerService.java@@ -818,8 +818,9 @@ public class NotificationManagerService extends SystemService {@Overridepublic void onReceive(Context context, Intent intent) {if (Intent.ACTION_LOCALE_CHANGED.equals(intent.getAction())) {- mZenModeHelper.updateDefaultZenRules();+ //mZenModeHelper.updateDefaultZenRules(); devin.2018419mRankingHelper.onLocaleChanged(context, ActivityManager.getCurrentUser());+ mZenModeHelper = new ZenModeHelper(getContext(), mHandler.getLooper(), mConditionProviders);//devin.2018419}}};15. 客制化BT,WiFi direct,WLAN热点名称BT:device/generic/common/bluetooth/bdroid_buildcfg.h-#define BTM_DEF_LOCAL_NAME "Android Bluedroid"+#define BTM_DEF_LOCAL_NAME "Vox_5S"WiFi direct:vendor/mediatek/proprietary/packages/apps/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java @@ -2659,6 +2659,8 @@ class DatabaseHelper extends SQLiteOpenHelper {loadSetting(stmt, Settings.Global.ENHANCED_4G_MODE_ENABLED,ImsConfig.FeatureValueConstants.ON);+ loadSetting(stmt, Settings.Global.WIFI_P2P_DEVICE_NAME,"Vox_5S");+/// M: Load MTK added Global providers before Android M.mUtils.loadCustomGlobalSettings(stmt);WLAN热点:frameworks/opt/net/wifi/service/java/com/android/server/wifi/WifiApConfigStore.java@@ -207,8 +207,9 @@ public class WifiApConfigStore {*/private WifiConfiguration getDefaultApConfiguration() {WifiConfiguration config = new WifiConfiguration();- config.SSID = mContext.getResources().getString(- R.string.wifi_tether_configure_ssid_default) + "_" + getRandomIntForDefaultSsid();+ //config.SSID = mContext.getResources().getString(+ // R.string.wifi_tether_configure_ssid_default) + "_" + getRandomIntForDefaultSsid();+ config.SSID = "Vox_5S";config.allowedKeyManagement.set(KeyMgmt.WPA2_PSK);String randomUUID = UUID.randomUUID().toString();//first 12 chars from xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx16. 12⼩时制,锁屏/状态栏增加A/PM显⽰锁屏:vendor/mediatek/proprietary/packages/apps/SystemUI/res-keyguard/values/strings.xml- <string name="keyguard_widget_12_hours_format" translatable="false">h:mm</string>+ <string name="keyguard_widget_12_hours_format" translatable="false">aa</string>vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/keyguard/KeyguardStatusView.java@@ -308,9 +308,9 @@ public class KeyguardStatusView extends GridLayout {clockView12 = DateFormat.getBestDateTimePattern(locale, clockView12Skel);// CLDR insists on adding an AM/PM indicator even though it wasn't in the skeleton// format. The following code removes the AM/PM indicator if we didn't want it.- if (!clockView12Skel.contains("a")) {+ /* meng if (!clockView12Skel.contains("a")) {clockView12 = clockView12.replaceAll("a", "").trim();- }+ }*/clockView24 = DateFormat.getBestDateTimePattern(locale, clockView24Skel);状态栏:vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/policy/Clock.java@@ -108,8 +108,9 @@ public class Clock extends TextView implements DemoMode, Tunable, CommandQueue.Ctry {mSystemUIFactoryBase = OpSystemUICustomizationFactoryBase.getOpFactory(context);mStatusBarExt = mSystemUIFactoryBase.makeSystemUIStatusBar(context);- mAmPmStyle = mStatusBarExt.getClockAmPmStyle(a.getInt(R.styleable.Clock_amPmStyle,- AM_PM_STYLE_GONE));+ //mAmPmStyle = mStatusBarExt.getClockAmPmStyle(a.getInt(R.styleable.Clock_amPmStyle,+ // AM_PM_STYLE_GONE));+ mAmPmStyle = AM_PM_STYLE_NORMAL;mShowDark = a.getBoolean(R.styleable.Clock_showDark, true);} finally {a.recycle();17. 长按Home键取消屏幕固定frameworks/base/core/res/res/values/strings.xml- <string name="lock_to_app_toast">To unpin this screen, touch &amp; hold Back and Overview- buttons</string>+ <string name="lock_to_app_toast">To unpin this screen, touch &amp; hold Home buttons</string>vendor/mediatek/proprietary/packages/apps/SystemUI/res/values/strings.xml- <string name="screen_pinning_description">This keeps it in view until you unpin. Touch &amp; hold Back and Overview to unpin.</string>+ <string name="screen_pinning_description">This keeps it in view until you unpin. Touch &amp; hold Home to unpin.</string>frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java+import android.app.IActivityManager;+import android.view.accessibility.AccessibilityManager;+import android.view.accessibility.AccessibilityManager.AccessibilityServicesStateChangeListener;+import android.app.ActivityManagerNative;+ private void onLongPressBackMenu(){+ IActivityManager activityManager = ActivityManagerNative.getDefault();+ boolean touchExplorationEnabled = mAccessibilityManager.isTouchExplorationEnabled();+ try {+ boolean inLockTaskMode = activityManager.isInLockTaskMode();+ Log.d("joyatel","onLongPressBackMenu......inLockTaskMode:"+inLockTaskMode+", touchExplorationEnabled:"+touchExplorationEnabled);+ if (inLockTaskMode && !touchExplorationEnabled) {+ activityManager.stopLockTaskMode();+ }+++ } catch (RemoteException e) {+ Log.d(TAG, "Unable to reach activity manager", e);+ }+++ }@@ -3488,6 +3511,7 @@ public class PhoneWindowManager implements WindowManagerPolicy {} else if ((event.getFlags() & KeyEvent.FLAG_LONG_PRESS) != 0) {if (!keyguardOn) {handleLongPressOnHome(event.getDeviceId());+ onLongPressBackMenu();}}18. 联系⼈-任意联系⼈-设置-设置铃声-默认铃声的状态下点击添加铃声,返回后没有焦点packages/providers/MediaProvider/src/com/android/providers/media/RingtonePickerActivity.ja+ ///devin.20180518 @{+ protected void onResume() {+ super.onResume();+ requeryForAdapter();+ }+ ///@}private void requeryForAdapter() {// Refresh and set a new cursor, closing the old one.initRingtoneManager();mAdapter.changeCursor(mCursor);// Update checked item location.- int checkedPosition = POS_UNKNOWN;+ int checkedPosition = /*POS_UNKNOWN*/getCheckedItem();//devin.20180518for (int i = 0; i < mAdapter.getCount(); i++) {if (mAdapter.getItemId(i) == mCheckedItemId) {checkedPosition = getListPosition(i);19.主界⾯hotseat打开相机,底部有⽩线packages/apps/Launcher3/src/com/android/launcher3/Launcher.java@@ -2672,6 +2672,7 @@ public class Launcher extends BaseActivity// private contract between launcher and may be ignored in the future).boolean useLaunchAnimation = (v != null) &&!intent.hasExtra(INTENT_EXTRA_IGNORE_LAUNCH_ANIMATION);+ useLaunchAnimation = false; //andyBundle optsBundle = useLaunchAnimation ? getActivityLaunchOptions(v) : null;UserHandle user = item == null ? null : er;20. 默认SIM卡短信设置去掉每次都询问 vendor/mediatek/proprietary/packages/apps/MtkSettings/ext/src/com/mediatek/settings/ext/DefaultRCSSettings.java public boolean isNeedAskFirstItemForSms() {Log.d("@M_" + TAG, "isNeedAskFirstItemForSms");- return true;+ return false;///mh.20180523 default=true}vendor/mediatek/proprietary/packages/apps/MtkSettings/src/com/android/settings/sim/SimDialogActivity.javaprivate int getPickSmsDefaultSub(final List<SubscriptionInfo> subInfoList,int value) {int subId = SubscriptionManager.INVALID_SUBSCRIPTION_ID;if (value < 1) {int length = subInfoList == null ? 0 : subInfoList.size();//if (length == 1) {mh.20180528subId = subInfoList.get(value).getSubscriptionId();//} else {// subId = MtkDefaultSmsSimSettings.ASK_USER_SUB_ID;//}} else if (value >= 1 && value < subInfoList.size() + 1) {subId = subInfoList.get(value).getSubscriptionId();}subId = mRCSExt.getDefaultSmsClickContentExt(subInfoList, value, subId);Log.d(TAG, "getPickSmsDefaultSub, value: " + value + ", subId: " + subId);return subId;}。

jdk18stream用法

jdk18stream用法

jdk18stream用法Java 8引入了新的Stream API,它提供了一种非常方便的方法来处理集合数据。

下面是一些关于jdk 8 Stream的用法。

1. 创建Stream可以通过集合类的stream(方法来创建Stream对象,如List.stream(、Set.stream(等。

也可以通过Arrays类的stream(方法来创建数组的Stream对象。

2. 遍历Stream可以使用forEach(方法来遍历Stream对象中的元素。

例如:```List<String> list = Arrays.asList("Java", "Python", "C++", "JavaScript");list.stream(.forEach(System.out::println);```3. 过滤Stream可以使用filter(方法来过滤Stream对象中的元素,只保留满足其中一种条件的元素。

例如:```List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);numbers.stream(.filter(n -> n % 2 ==0).forEach(System.out::println);```4. 映射Stream可以使用map(方法将一个Stream对象中的元素映射为另一个值,返回一个新的Stream对象。

例如:```List<String> list = Arrays.asList("apple", "banana", "orange");list.stream(.map(String::toUpperCase).forEach(System.out::pr intln);```5. 排序Stream可以使用sorted(方法对Stream对象中的元素进行排序。

使用stream流将对象按部分字段去重,并合并部分字段的方法

使用stream流将对象按部分字段去重,并合并部分字段的方法

在Java中,如果你想使用Stream来根据对象的某个字段进行去重,同时合并另一个字段,你可以使用`distinct()`方法配合`Collectors.mapping()`和`Collectors.toList()`。

以下是一个例子:假设你有一个名为`Person`的类,有两个字段:`name`和`age`。

你想根据`name`字段去重,并将相同的`name`的`age`字段相加。

```javaimport java.util.*;import java.util.stream.*;class Person {String name;int age;Person(String name, int age) { = name;this.age = age;}public String getName() {return name;}public int getAge() {return age;}}public class Main {public static void main(String[] args) {List<Person> people = Arrays.asList(new Person("Alice", 20), new Person("Bob", 30), new Person("Alice", 25));Map<String, Integer> distinctAndSummed = people.stream().collect(Collectors.groupingBy(Person::getName, Collectors.summingInt(Person::getAge)));System.out.println(distinctAndSummed);}```在这个例子中,`groupingBy()`方法根据`Person::getName`对流进行分组,然后使用`Collectors.summingInt()`方法将每个分组中的`Person::getAge`相加。

java8 stream sorted 用法

java8 stream sorted 用法

java8 stream sorted 用法Java 8中的Stream API提供了一种非常强大的方式来处理集合。

其中的`sorted()`方法允许你按照指定的顺序对集合进行排序。

以下是如何使用`sorted()`方法的一些示例:1. **自然排序**:如果你有一个`List<Integer>`,你可以使用`sorted()`方法对其进行自然排序(升序):```javaList<Integer> numbers = Arrays.asList(3, 1, 4, 1, 5, 9);List<Integer> sortedNumbers = numbers.stream().sorted().collect(Collectors.to List());System.out.println(sortedNumbers); // 输出: [1, 1, 3, 4, 5, 9]```2. **自定义排序**:如果你想按照自定义的顺序进行排序,你可以提供一个比较器(Comparator)。

例如,按照绝对值进行排序:```javaList<Integer> numbers = Arrays.asList(-3, 1, -5, 4, -1, 2);List<Integer> sortedNumbers = numbers.stream().sorted(Comparator.comparingInt(Math::abs)).collect(Collectors.to List());System.out.println(sortedNumbers); // 输出: [-1, 1, -3, 2, -5, 4]```3. **降序排序**:默认情况下,`sorted()`方法执行升序排序。

如果你想进行降序排序,可以结合使用`Comparator.reverseOrder()`:```javaList<Integer> numbers = Arrays.asList(3, 1, 4, 1, 5, 9);List<Integer> sortedNumbersDesc = numbers.stream().sorted(Compar ator.reverseOrder()).collect(Collecto rs.toList());System.out.println(sortedNumbersDesc); // 输出: [9, 5, 4, 3, 1, 1] ```4. **根据集合中的元素进行排序**:如果你有一个`List<String>`,并且你想根据字符串的长度进行排序,你可以这样做:```javaList<String> words = Arrays.asList("apple", "banana", "cherry","date");List<String> sortedWords = words.stream().sorted(pa ringInt(String::length)).collect(Collectors.toList());System.out.println(sortedWords); // 输出: [date, apple, cherry, banana]```以上只是`sorted()`方法的一些基本用法示例。

stream() 用法

stream() 用法

stream() 用法
`stream()`函数是Python 3中引入的一个内置函数,用于创建一个可迭代对象,通常用于处理字符串、列表、元组等序列数据。

`stream()`函数的主要作用是将一个可迭代对象转换为一个生成器,这样在处理大量数据时可以节省内存,提高程序运行效率。

以下是`stream()`函数的基本用法:
1. 直接应用于字符串、列表、元组等序列数据:
```python
# 示例:计算列表中每个元素的平方
squares = (x ** 2 for x in range(10))
for square in squares:
print(square)
```
2. 结合`map()`函数使用:
```python
# 示例:计算列表中每个元素的平方
squares = list(map(lambda x: x ** 2, range(10)))
print(squares)
```
3. 应用在生成器表达式中:
```python
# 示例:生成斐波那契数列
def fibonacci():
a, b = 0, 1
while True:
yield a
a, b = b, a + b
fib = fibonacci()
for i in range(10):
print(next(fib))
```
注意:在使用`stream()`函数时,应确保迭代器有无限个元素,否则可能会导致程序陷入无限循环。

在生成器表达式中,可以通过在函数内部使用`yield`关键字来控制生成器的执行流程。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Multiple, continuous, rapid, time-varying, ordered streams
Main memory computations
Queries are often continuous

Evaluated continuously as stream data arrives Answer updated over time Beyond element-at-a-time processing Beyond stream-at-a-time processing Beyond relational queries (scientific, data mining, OLAP) Most stream data are at pretty low-level or multi-dimensional in nature
Data Mining:
Principles and Research Frontiers
— Chapter 8.1 — — Stream Data Mining — © Jiawei Han
Department of Computer Science
University of Illinois at Urbana-Champaign
STREAM (Stanford): A general-purpose DSMS Cougar (Cornell): sensors Aurora (Brown/MIT): sensor monitoring, dataflow Hancock (AT&T): telecom streams Niagara (OGI/Wisconsin): Internet XML databases OpenCQ (Georgia Tech): triggers, incr. view maintenance Tapestry (Xerox): pub/sub content-based filtering Telegraph (Berkeley): adaptive engine for sensors Tradebot (): stock tickers & streams

Sampling if update is slow but computing is fast


Synopsis data structures


Blocking operators, e.g., sorting, avg, min, etc.

Blocking if unable to produce the first output until seeing the entire input
Multiple streams
Stream Query Processor
Scratch Space (Main memory and/or Disk)
2014-10-1 Data Mining: Principles and Algorithms 5
Challenges of Stream Data Processing

What is stream data? Why Stream Data Systems? Stream data management systems: Issues and solutions Stream data cube and multidimensional OLAP analysis Stream frequent pattern analysis Stream classification


Tribeca (Bellcore): network monitoring
MAIDS (UIUC/NCSA): Mining Alarming Incidents in Data Streams
Data Mining: Principles and Algorithms 9
2014-10-1
Stream Data Mining


Approximate query answering


Sketches, random sampling, histograms, wavelets, etc.
Data Mining: Principles and Algorithms 7
2014-10-1
Methods for Approximate Query Answering
Data stream captures nicely our data processing needs of today Random access is expensive—single linear scan algorithm (can only have one look) Store only the summary of the data seen thus far Most stream data are at pretty low-level or multi-dimensional in nature, needs multi-level and multi-dimensional processing


Stream cluster analysis
Research issues
2014-10-1
Data Mining: Principles and Algorithms
10
Frequent Patterns for Stream Data

Frequent pattern mining is valuable in stream applications

Traditional DBMS—data stored in finite, persistent data sets
Huge volumes of continuous data, possibly infinite

Characteristics

Fast changing and requires fast, real-time response


Unbounded memory requirements

Memory requirement is unbounded if one will join future tuples
With bounded memory, it is not always possible to produce exact answers High-quality approximate answers are desired Data reduction and synopsis construction methods

e.g., network intrusion mining (Dokas, et al‘02)

Mining precise freq patterns in stream data: unrealistic


Stream cluster a来自alysisResearch issues
2014-10-1
Data Mining: Principles and Algorithms
2
Characteristics of Data Streams

Data Streams

Data streams—continuous, ordered, changing, fast, huge amount
Data Mining: Principles and Algorithms 4
2014-10-1
Architecture: Stream Query Processing
SDMS (Stream Data Management System)
User/Application
Continuous Query Results
Data Mining: Principles and Algorithms 3

2014-10-1
Stream Data Applications


Telecommunication calling records Business: credit card transaction flows Network monitoring and traffic engineering Financial market: stock exchange Engineering & industrial processes: power supply & manufacturing Sensor, monitoring & surveillance: video streams, RFIDs Security monitoring Web logs and Web page click streams Massive data sets (even saved but random access is too expensive)
Data Mining: Principles and Algorithms 8
2014-10-1
Projects on DSMS (Data Stream Management System)

Research projects and system prototypes

/~hanj
2014-10-1 Data Mining: Principles and Algorithms 1
Stream Data Mining

What is stream data? Why Stream Data Systems? Stream data management systems: Issues and solutions Stream data cube and multidimensional OLAP analysis Stream frequent pattern analysis Stream classification
相关文档
最新文档