当前位置:网站首页>Dark horse notes - create immutable sets and streams
Dark horse notes - create immutable sets and streams
2022-07-07 01:20:00 【Xiaofu taps the code】
Catalog
1.1 What is an immutable set ?
1.2 How to create immutable sets ?
Case study :Stream The role of flow
Stream The core of flow thinking :
2.3Stream The common use of stream API
Stream The common use of stream API( Intermediate operation method )
Stream Common end operations for streams
2.4Stream Comprehensive application of flow
Stream Stream collection operation
Stream Stream collection methods
Collectors Tool classes provide specific collection methods
1. Immutable set
1.1 What is an immutable set ?
Immutable set , Is a collection that cannot be modified .
At the time of data collection creation , And it's immutable throughout the life cycle . Otherwise, the report will be wrong .
Why create immutable sets ?
If a data cannot be modified , It's a good practice to copy it defensively into immutable sets .
Or when the collection object is called by an untrusted Library , Immutable forms are safe .
1.2 How to create immutable sets ?
stay List、Set、Map Interface , All exist of Method , You can create an immutable collection .
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
The goal is : Immutable set .
*/
public class CollectionDemo {
public static void main(String[] args) {
// 1、 Immutable List aggregate
List<Double> lists = List.of(569.5, 700.5, 523.0, 570.5);
// lists.add(689.0);
// lists.set(2, 698.5);
// System.out.println(lists);
double score = lists.get(1);
System.out.println(score);
// 2、 Immutable Set aggregate
Set<String> names = Set.of(" Delireba ", " Deli hot nine ", " Marzaha ", " Karba " );
// names.add(" Third young master ");
System.out.println(names);
// 3、 Immutable Map aggregate
Map<String, Integer> maps = Map.of("huawei",2, "Java Development ", 1 , " watch ", 1);
// maps.put(" clothes ", 3);
System.out.println(maps);
}
}
This collection cannot be added , Can't delete , Do not modify .
summary :
Characteristics of immutable sets ?
Cannot be modified after the definition is completed , Or add 、 Delete
How to create immutable sets ?
List、Set、Map Interface , All exist of Method can create immutable collections .
2.Stream flow
2.1Stream An overview of flow
What is? Stream flow ?
stay Java 8 in , Thanks to the Lambda The functional programming that comes with it , Introduced a whole new Stream Flow concept .
Purpose : For simplifying set and array operations API.
Case study :Stream The role of flow
demand : Complete the creation and traversal of the collection according to the following requirements
Create a collection , Store multiple string elements
Put all the objects in the set with " Zhang " The first element is stored in a new collection
hold " Zhang " The length in the first set is 3 To a new collection
Traverse the element output in the set obtained in the previous step .
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
The goal is : Preliminary experience Stream Convenient and fast flow
*/
public class StreamTest {
public static void main(String[] args) {
List<String> names = new ArrayList<>();
Collections.addAll(names, " Zhang Sanfeng "," zhang wuji "," Zhou Zhiruo "," Zhao Min "," Zhang Qiang ");
System.out.println(names);
//
// // 1、 Find the one surnamed Zhang from the set and put it in the new set
// List<String> zhangList = new ArrayList<>();
// for (String name : names) {
// if(name.startsWith(" Zhang ")){
// zhangList.add(name);
// }
// }
// System.out.println(zhangList);
//
// // 2、 Find a name whose length is 3 The name of
// List<String> zhangThreeList = new ArrayList<>();
// for (String name : zhangList) {
// if(name.length() == 3){
// zhangThreeList.add(name);
// }
// }
// System.out.println(zhangThreeList);
// 3、 Use Stream Realized
names.stream().filter(s -> s.startsWith(" Zhang ")).filter(s -> s.length() == 3).forEach(s -> System.out.println(s));
}
}
Stream The core of flow thinking :
1. Get the of a set or array first Stream flow ( It's a conveyor belt )
2. Put the elements on it
3. Then use this Stream Flow simplified API To facilitate the operation of elements .
summary :
Stream What is the function of flow , What technology is combined ?
Simplify the set 、 Array operations API. Combined with the Lambda expression .
say something Stream The idea and use steps of flow .
Get the of a set or array first Stream flow ( It's a conveyor belt ).
Put the elements on it .
Then use this Stream Flow simplified API To facilitate the operation of elements .
2.2Stream Stream acquisition
Stream Three methods of flow
obtain Stream flow
Create a pipeline , And put the data on the pipeline, ready to operate
The middle way
Operation on the assembly line . After one operation , You can continue with other operations .
Put an end to the method
One Stream A stream can only have one end method , It's the last operation on the pipeline
Stream The first step in manipulating a set or array is to get Stream flow , Then you can use the function of flow .
Gather to get Stream stream
have access to Collection Default method in interface stream() Generative flow
Array get Stream stream
import java.util.*;
import java.util.stream.Stream;
/**
The goal is :Stream Stream acquisition
Stream The core of flow thinking :
Is to get the set or array first Stream flow ( It's a conveyor belt )
Then use this Stream Stream operates on the elements of a collection or array .
And then use Stream Flow simplifies the process of replacing collection operations API.
Collection gets the name of the stream API:
(1) default Stream<E> stream();
Summary :
Gather to get Stream Circulation : stream();
Array :Arrays.stream( Array ) / Stream.of( Array );
*/
public class StreamDemo02 {
public static void main(String[] args) {
/** --------------------Collection Gather to get the stream ------------------------------- */
Collection<String> list = new ArrayList<>();
Stream<String> s = list.stream();
/** --------------------Map Gather to get the stream ------------------------------- */
Map<String, Integer> maps = new HashMap<>();
// Bond flow
Stream<String> keyStream = maps.keySet().stream();
// Value flow
Stream<Integer> valueStream = maps.values().stream();
// Key value ( Take the whole )
Stream<Map.Entry<String,Integer>> keyAndValueStream = maps.entrySet().stream();
/** --------------------- Array get stream ------------------------------ */
String[] names = {" Zhao Min "," Small zhao "," extinction "," Zhou Zhiruo "};
Stream<String> nameStream = Arrays.stream(names);
Stream<String> nameStream2 = Stream.of(names);
}
}
2.3Stream The common use of stream API
Stream The common use of stream API( Intermediate operation method )
Be careful :
Intermediate methods are also called non terminating methods , After the call is completed, a new Stream Stream can continue to use , Support Chain programming .
stay Stream The collection cannot be modified directly in the stream 、 Data in array .
Stream Common end operations for streams
Be careful : Termination operation method , After the call is completed, the flow can no longer be used , The reason is that it will not return Stream 了 .
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.stream.Stream;
/**
The goal is :Stream The common use of stream API
forEach : One by one processing ( Traverse )
count: Number of Statistics
-- long count();
filter : Filter element
-- Stream<T> filter(Predicate<? super T> predicate)
limit : Take the first few elements
skip : Skip the first few
map : Processing method
concat : Combined flow .
*/
public class StreamDemo03 {
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add(" zhang wuji ");
list.add(" Zhou Zhiruo ");
list.add(" Zhao Min ");
list.add(" Zhang Qiang ");
list.add(" Zhang Sanfeng ");
list.add(" Zhang Sanfeng ");
// Stream<T> filter(Predicate<? super T> predicate)
list.stream().filter(s -> s.startsWith(" Zhang ")).forEach(s -> System.out.println(s));
long size = list.stream().filter(s -> s.length() == 3).count();
System.out.println(size);
// list.stream().filter(s -> s.startsWith(" Zhang ")).limit(2).forEach(s -> System.out.println(s));
System.out.println("--------------------------");
list.stream().filter(s -> s.startsWith(" Zhang ")).limit(2).forEach(System.out::println);
System.out.println("-------------------------------------");
list.stream().filter(s -> s.startsWith(" Zhang ")).skip(2).forEach(System.out::println);
// map Processing method : The first parameter is raw material -> The second parameter is the result of processing .
// Add a... To the front of the set element :zhangsan
list.stream().map(s -> "zhangsan" + s).forEach(a -> System.out.println(a));
// demand : Put all the names All processed into a student object .
list.stream().map(s -> new Student(s)).forEach(s -> System.out.println(s));
// list.stream().map(Student::new).forEach(System.out::println); // Constructor reference Method reference
// Combined flow .
Stream<String> s1 = list.stream().filter(s -> s.startsWith(" Zhang "));
Stream<String> s2 = Stream.of("java1", "java2");
// public static <T> Stream<T> concat(Stream<? extends T> a, Stream<? extends T> b)
Stream<String> s3 = Stream.concat(s1 , s2);
s3.distinct().forEach(s -> System.out.println(s));
}
}
summary :
What is the meaning of terminating and non terminating methods ?
After terminating the method, the stream cannot continue to be used , Non terminating methods will return a new stream , Support chain programming .
2.4Stream Comprehensive application of flow
Case study :
demand : The Development Department of a company , It is divided into development department I and Development Department II , Now we need to settle the mid year data .
analysis :
Employee information includes at least ( name 、 Gender 、 Wages 、 Bonus 、 Punishment record )
Develop a department with 4 Employees 、 The second development department has 5 Employees
Filter out 2 Information about the highest paid employees in a department , Encapsulated as an excellent employee object Topperformer
Count out 2 The average monthly income of each department , Ask for the removal of the maximum and minimum wages .
Statistics 2 The average salary of a development department as a whole , Remove the average of the minimum and maximum wages .
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Stream;
public class StreamDemo04 {
public static double allMoney ;
public static double allMoney2 ; // 2 Remove the maximum wage from each department , The sum of the minimum wages
public static void main(String[] args) {
List<Employee> one = new ArrayList<>();
one.add(new Employee(" Pig eight quit ",' male ',30000 , 25000, null));
one.add(new Employee(" The Monkey King ",' male ',25000 , 1000, " Contradict your boss "));
one.add(new Employee(" Monk sha ",' male ',20000 , 20000, null));
one.add(new Employee(" Small white dragon ",' male ',20000 , 25000, null));
List<Employee> two = new ArrayList<>();
two.add(new Employee(" Wusong ",' male ',15000 , 9000, null));
two.add(new Employee(" Li Kui ",' male ',20000 , 10000, null));
two.add(new Employee(" ximen qing ",' male ',50000 , 100000, " Be beaten "));
two.add(new Employee(" Pan Jinlian ",' Woman ',3500 , 1000, " Be beaten "));
two.add(new Employee(" Wu Da Long ",' Woman ',20000 , 0, " Poison "));
// 1、 The highest paid employees in the development department .(API)
// Specify the size rule
// Employee e = one.stream().max((e1, e2) -> Double.compare(e1.getSalary() + e1.getBonus(), e2.getSalary() + e2.getBonus()))
// .get();
// System.out.println(e);
Topperformer t = one.stream().max((e1, e2) -> Double.compare(e1.getSalary() + e1.getBonus(), e2.getSalary() + e2.getBonus()))
.map(e -> new Topperformer(e.getName(), e.getSalary() + e.getBonus())).get();
System.out.println(t);
// 2、 Count the average wage , Remove the maximum wage and minimum wage
one.stream().sorted((e1, e2) -> Double.compare(e1.getSalary() + e1.getBonus(), e2.getSalary() + e2.getBonus()))
.skip(1).limit(one.size() - 2).forEach(e -> {
// Find the sum : The total salary of the remaining employees
allMoney += (e.getSalary() + e.getBonus());
});
System.out.println(" The average salary for developing a department is :" + allMoney / (one.size() - 2));
// 3、 Merge 2 A collection stream , Re statistics
Stream<Employee> s1 = one.stream();
Stream<Employee> s2 = two.stream();
Stream<Employee> s3 = Stream.concat(s1 , s2);
s3.sorted((e1, e2) -> Double.compare(e1.getSalary() + e1.getBonus(), e2.getSalary() + e2.getBonus()))
.skip(1).limit(one.size() + two.size() - 2).forEach(e -> {
// Find the sum : The total salary of the remaining employees
allMoney2 += (e.getSalary() + e.getBonus());
});
// BigDecimal
BigDecimal a = BigDecimal.valueOf(allMoney2);
BigDecimal b = BigDecimal.valueOf(one.size() + two.size() - 2);
System.out.println(" The average salary of the development department is :" + a.divide(b,2, RoundingMode.HALF_UP));
}
}
2.5 collect Stream flow
Stream Stream collection operation
collect Stream Meaning of flow : Is to put Stream The result data after stream operation is transferred back to the set or array .
Stream flow : Easy to operate set / Array means .
aggregate / Array : Is the purpose of development .
Stream Stream collection methods
Collectors Tool classes provide specific collection methods
summary :
1. collect Stream The role of flow ?
Stream A stream is a collection of operations / Array means
The result data of the operation should eventually be restored to the set or array .
import java.util.*;
import java.util.function.IntFunction;
import java.util.stream.Collectors;
import java.util.stream.Stream;
/**
The goal is : collect Stream Stream data to In a collection or array .
*/
public class StreamDemo05 {
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add(" zhang wuji ");
list.add(" Zhou Zhiruo ");
list.add(" Zhao Min ");
list.add(" Zhang Qiang ");
list.add(" Zhang Sanfeng ");
list.add(" Zhang Sanfeng ");
Stream<String> s1 = list.stream().filter(s -> s.startsWith(" Zhang "));
List<String> zhangList = s1.collect(Collectors.toList()); // Variable set
zhangList.add("java1");
System.out.println(zhangList);
// List<String> list1 = s1.toList(); // Get the immutable set
// list1.add("java");
// System.out.println(list1);
// Pay attention to pay attention to :“ Streams can only be used once ”
Stream<String> s2 = list.stream().filter(s -> s.startsWith(" Zhang "));
Set<String> zhangSet = s2.collect(Collectors.toSet());
System.out.println(zhangSet);
Stream<String> s3 = list.stream().filter(s -> s.startsWith(" Zhang "));
// Object[] arrs = s3.toArray();
String[] arrs = s3.toArray(String[]::new); // Can be either , Expand your thinking !!
System.out.println("Arrays An array of content :" + Arrays.toString(arrs));
}
}
边栏推荐
- Provincial and urban level three coordinate boundary data CSV to JSON
- Wood extraction in Halcon
- 自旋与sleep的区别
- Byte P7 professional level explanation: common tools and test methods for interface testing, Freeman
- Spark TPCDS Data Gen
- Neon Optimization: summary of performance optimization experience
- Oracle: Practice of CDB restricting PDB resources
- 资产安全问题或制约加密行业发展 风控+合规成为平台破局关键
- 安全保护能力是什么意思?等保不同级别保护能力分别是怎样?
- golang中的atomic,以及CAS操作
猜你喜欢
动态规划思想《从入门到放弃》
golang中的Mutex原理解析
Niuke cold training camp 6B (Freund has no green name level)
BFS realizes breadth first traversal of adjacency matrix (with examples)
Gazebo的安装&与ROS的连接
让我们,从头到尾,通透网络I/O模型
Build your own website (17)
UI控件Telerik UI for WinForms新主题——VS2022启发式主题
[HFCTF2020]BabyUpload session解析引擎
[Niuke] [noip2015] jumping stone
随机推荐
[Niuke] b-complete square
MySQL中回表的代价
斗地主游戏的案例开发
Chenglian premium products has completed the first step to enter the international capital market by taking shares in halber international
Neon Optimization: summary of performance optimization experience
【JVM调优实战100例】04——方法区调优实战(上)
[batch dos-cmd command - summary and summary] - view or modify file attributes (attrib), view and modify file association types (Assoc, ftype)
Taro中添加小程序 “lazyCodeLoading“: “requiredComponents“,
NEON优化:性能优化经验总结
Tensorflow GPU installation
Eventbus source code analysis
gnet: 一个轻量级且高性能的 Go 网络框架 使用笔记
Taro 小程序开启wxml代码压缩
让我们,从头到尾,通透网络I/O模型
Installation and testing of pyflink
pyflink的安装和测试
paddlehub应用出现paddle包报错的问题
Neon Optimization: an optimization case of log10 function
UI control telerik UI for WinForms new theme - vs2022 heuristic theme
Installation of gazebo & connection with ROS