网络编程和lambda表达式

网络编程概述

Java是 Internet 上的语言,它从语言级上提供了对网络应用程 序的支持,程序员能够很容易开发常见的网络应用程序。
Java提供的网络类库,可以实现无痛的网络连接,联网的底层 细节被隐藏在 Java 的本机安装系统里,由 JVM 进行控制。并 且 Java 实现了一个跨平台的网络库,程序员面对的是一个统一 的网络编程环境
在这里插入图片描述

lambda表达式

基本使用

package test;

import java.util.Arrays;
import java.util.List;
import java.util.stream.IntStream;
import java.util.stream.Stream;
/**
 * 23	
 * 通过Stream.generate : 是一个无限流(无限大),	
 * 再操作的时候,通过limit进行最大数量控制
 * 常用的转换算子 : filter,distinct,map,limit,skip,flatMap
 * 
 * filter : 对元素进行过滤筛选,不符合条件的不要
 * 
 * distinct : 去除重复
 * 
 * skip : 跳过多少个元素
 * 
 * limit : 取一个集合中的 前几个数据
 * 
 * map : 在集合的遍历中对数据进行操作,比如更改,公司所有员工薪水涨10%
 * 
 * flatMap : 解决字符串数组
 */
public class Stream_01 {
	public static void main(String[] args) {
		//数组 创建 Stream.of
		String[] strings = {"a","s","d","f","g","h"};
		Stream<String> stream1 = Stream.of(strings);
		
		//通过集合
		List<String>  strings2 = Arrays.asList(strings);
		Stream<String> stream2 = strings2.stream();
		
	
		// 参数 Supplier,有一个get方法,是无参有返回值
		// get方法的返回值 就作为集合中的数据,下面这中就等于都赋值为1
		Stream<Integer> generate  = Stream.generate(()->1);
		//使用limit 设置元素个数
		generate.limit(4).forEach(x->System.out.println(x));
		
		//Stream.Iterate 来创建
		// 是一个有序的无限流,所以建议使用limit进行最大数量控制
		// 第一个参数是数据的起始值,第二个参数是Function,所以是有参有返回值
		// 1 就是起始值是1 , x+2 步长为2 , 就类似于一个死循环,起始值是1,步长为2
		Stream<Integer> iterate = Stream.iterate(1, x->x+2);
		iterate.limit(3).forEach(x->System.out.println(x));
		
		//通过已有类API
		String str = "badsfasd";
		IntStream chars = str.chars();
		chars.forEach(x->System.out.println(x));
	}
}


应用

package test;

/**
 24 1. 找出2011年发生的所有交易,并按交易额排序(从低到高)
 2. 交易员都在哪些不同的城市工作过
 3. 查找所有来自剑桥的交易员,并按姓名排序
 4. 返回所有交易员的姓名字符串,按字母顺序排序
 5. 有没有交易员是在米兰工作的?
 6. 所有交易中,最高的交易额是多少
 7. 找到交易额最小的交易
 */
import java.util.Arrays;
import java.util.Comparator;
import java.util.List;
import java.util.Optional;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class Work_01 {
	public static List<Transaction> transactions = null;
	static {
		Trader raoul = new Trader("Raoul", "Cambridge");
		Trader mario = new Trader("Mario", "Mqilan");
		Trader alan = new Trader("Alan", "Cambridge");
		Trader brian = new Trader("Brian", "Cambridge");
		transactions = Arrays.asList(new Transaction(brian, 2011, 300),
				new Transaction(raoul, 2012, 1000), new Transaction(raoul,
						2011, 400), new Transaction(mario, 2012, 710),
				new Transaction(mario, 2012, 700), new Transaction(alan, 2012,
						950));
	}

	public static void main(String[] args) {
		// 1. 找出2011年发生的所有交易,并按交易额排序(从低到高)
		Stream<Transaction> stream1 = transactions.stream();
		stream1.filter(tran -> tran.getYear() == 2011)
				.sorted((x, y) -> x.getValue() - y.getValue())
				.forEach(x -> System.out.println(x));
		System.out.println("------------------------------");
		// 2. 交易员都在哪些不同的城市工作过
		stream1 = transactions.stream();
		stream1.map(x -> x.getTrader().getCity()).distinct()
				.collect(Collectors.toList())
				.forEach(x -> System.out.print(x + " "));
		System.out.println();
		System.out.println("---------------------------------");
		// 3. 查找所有来自剑桥的交易员,并按姓名排序
		stream1 = transactions.stream();
		List<Transaction> value1 = stream1.filter(
				x -> x.getTrader().getCity().equals("Cambridge")).collect(
				Collectors.toList());
		System.out.println(value1);
		System.out.println("---------------------------------");
		// 4. 返回所有交易员的姓名字符串,按字母顺序排序
		stream1 = transactions.stream();
		List<String> value2 = stream1.map(x -> x.getTrader().getName())
				.distinct().collect(Collectors.toList());
		value2.sort((x, y) -> x.compareTo(y));
		System.out.println(value2);
		System.out.println("---------------------------------");
		// 5. 有没有交易员是在米兰工作的?anyMatch
		stream1 = transactions.stream();
		if (stream1.anyMatch(x -> x.getTrader().getCity().equals("Milan"))) {
			System.out.println("有");
		} else {
			System.out.println("没有");
		}
		System.out.println("---------------------------------");
		// 6. 打印生活在剑桥的交易员的所有交易额
		stream1 = transactions.stream();
		List<Integer> value3 = stream1
				.filter(x -> x.getTrader().getCity().equals("Cambridge"))
				.map(x -> x.getValue()).collect(Collectors.toList());
		System.out.println(value3);
		System.out.println("---------------------------------");
		// 7. 所有交易中,最高的交易额是多少max
		Integer value4  = transactions.stream().map(x -> x.getValue())
				.max((x, y) -> Integer.compare(x, y)).get();
		System.out.println(value4);
		System.out.println("---------------------------------");
		// 8. 找到交易额最小的交易 min
		Optional<Transaction> value5 = transactions.stream().min(
				(x, y) -> x.getValue() - y.getValue());
		System.out.println(value5);
	}
}

// 商人
class Trader {
	private String name;
	private String city;

	public Trader() {
	}

	public Trader(String name, String city) {
		this.name = name;
		this.city = city;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getCity() {
		return city;
	}

	public void setCity(String city) {
		this.city = city;
	}

	@Override
	public String toString() {
		return "Trader{" + "name='" + name + '\'' + ", city='" + city + '\''
				+ '}';
	}
}

// 交易
class Transaction {
	private Trader trader;
	private int year;
	private int value;

	public Transaction() {
	}

	public Transaction(Trader trader, int year, int value) {
		this.trader = trader;
		this.year = year;
		this.value = value;
	}

	public Trader getTrader() {
		return trader;
	}

	public void setTrader(Trader trader) {
		this.trader = trader;
	}

	public int getYear() {
		return year;
	}

	public void setYear(int year) {
		this.year = year;
	}

	public int getValue() {
		return value;
	}

	public void setValue(int value) {
		this.value = value;
	}

	@Override
	public String toString() {
		return "Transaction{" + "trader=" + trader + ", year=" + year
				+ ", value=" + value + '}';
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值