• JAVA实训第三天


    目录

    方法引用

    示例

    接口

    测试类

    Stream

    ​编辑 Stream 的操作三个步骤

     创建 Stream 的 4 种方法

     常见Stream接口的继承关系

    Stream的中间操作

     中间操作常用方法

     Stream的终止操作

     Stream的终止操作-collect()

     示例代码演示

     作业


    方法引用

            在Lamda新特性的支持下,JAVA8中可以使用lamda表达式来创建匿名方法。然而,有时候我们仅仅是需要调用一个已存在的方法(如java中已经定义好的方法),在这时候java8新特性“方法引用”将会进一步简化操作(注意:需要有Lamda的支持)。

    方法引用的四种形式:
    引用静态方法 --> 类名称 ::static 方法名称;
    引用某个对象的实例的普通方法 --> 实例化对象 :: 普通方法;
    引用 特定类型 任意对象 的实例方法 --> 特定类 :: 普通方法;
    引用构造方法 --> 类名称 ::new

    定义一个方法获取供给型接口类型的参数,调用 get 方法获取返回对象,并执行普通方法

     

     

    示例

    接口

    1. package part4;
    2. /**
    3. * @date : 2022/11/23 9:36
    4. */
    5. @FunctionalInterface
    6. public interface PersonInterface {
    7. public static final String name = "tidy";
    8. public static final Integer age =18;
    9. public void methodA();
    10. }

    1. package part4;
    2. /**
    3. * @date : 2022/11/23 9:31
    4. */
    5. public class Person {
    6. String name;
    7. Integer age;
    8. public static int method1() {
    9. System.out.println("static静态方法...");
    10. return 0;
    11. }
    12. public static int method2(int a) {
    13. System.out.println("static静态方法..."+a);
    14. return 0;
    15. }
    16. public Person() {
    17. }
    18. public Person(String name, Integer age) {
    19. this.name = name;
    20. this.age = age;
    21. }
    22. public String getName() {
    23. return name;
    24. }
    25. public void setName(String name) {
    26. this.name = name;
    27. }
    28. public Integer getAge() {
    29. return age;
    30. }
    31. public void setAge(Integer age) {
    32. this.age = age;
    33. }
    34. @Override
    35. public String toString() {
    36. return "Person{" +
    37. "name='" + name + '\'' +
    38. ", age=" + age +
    39. '}';
    40. }
    41. }

    测试类

    1. package part4;
    2. import java.util.ArrayList;
    3. import java.util.List;
    4. import java.util.function.BiFunction;
    5. import java.util.function.Consumer;
    6. import java.util.function.Function;
    7. import java.util.function.Supplier;
    8. /**
    9. * @date : 2022/11/23 9:29
    10. */
    11. public class MethodReferenceDemo {
    12. public static void main(String[] args) {
    13. /* 方法引用的四种形式:
    14. 引用静态方法-->类名称::static 方法名称;
    15. 引用某个对象的实例的普通方法-->实例化对象::普通方法;
    16. 引用特定类型的任意对象的实例方法-->特定类::普通方法;
    17. 引用构造方法-->类名称::new
    18. */
    19. // 1)引用构造方法-->类名称::new
    20. /*Person person = new Person();
    21. System.out.println(person);*/
    22. // 注意事项1:方法引用 前提要使用lambda表达式--》功能性函数
    23. // Person person = Person::new;
    24. // 注意事项2:接口中没有构造方法 调用不成
    25. // PersonInterface personInterface = PersonInterface::new;
    26. // 借助于供给型接口 实例化对象
    27. Supplier<Person> supplier = Person::new;
    28. Person person = supplier.get();
    29. System.out.println(person);
    30. // 2) 引用静态方法-->类名称::static 方法名称;
    31. Supplier<Integer> method1 = Person::method1;
    32. Integer result = method1.get();
    33. System.out.println("result:"+result);
    34. System.out.println("==================");
    35. // 调用静态方法时:选定和这个静态方法相匹配的功能性函数(是否匹配:是否有参数 是否有返回值--》使用哪个功能性函数)
    36. Function<Integer,Integer> function = Person::method2;
    37. Integer apply = function.apply(66);
    38. System.out.println("applay:"+apply);
    39. System.out.println("==================");
    40. // 3)引用某个对象的实例的普通方法-->实例化对象::普通方法;
    41. Person person1 = new Person("tidy",18);
    42. Supplier<String> stringSupplier =person1::getName;
    43. String name = stringSupplier.get();
    44. System.out.println("name:"+name);
    45. // 4)引用特定类型的任意对象的实例方法-->特定类::普通方法;
    46. // String equals方法 比较两个字符串是否相等 2个字符串
    47. // BiFunction
    48. BiFunction<String,String,Boolean> biFunction = String::equals;
    49. Boolean resultFlg = biFunction.apply("hello", "hello");
    50. System.out.println("resultFlg:"+resultFlg);
    51. System.out.println("6666666666666666666:");
    52. List<Integer> list = new ArrayList();
    53. list.add(10);
    54. list.add(30);
    55. list.add(30);
    56. // 内部类
    57. /* Consumer<Integer> consumer = new Consumer<Integer>() {
    58. @Override
    59. public void accept(Integer integer) {
    60. System.out.println(integer);
    61. }
    62. };
    63. list.forEach(consumer);*/
    64. /*list.forEach(new Consumer<Integer>() {
    65. @Override
    66. public void accept(Integer integer) {
    67. System.out.println(integer);
    68. }
    69. });*/
    70. // list.forEach(t-> System.out.println(t));
    71. // println(..):有参数没有返回值
    72. /*Consumer consumer = System.out::println;
    73. // 方法引用
    74. list.forEach(consumer);*/
    75. list.forEach(System.out::println);
    76. }
    77. }

    Stream

     Stream 的操作三个步骤

    创建 Stream :一个数据源(如:集合、数组),获取一个流

    中间操作 :一个中间操作链,对数据源的数据进行处理

    终止操作(终端操作) :一个终止操作,执行中间操作链,并产生结果

     创建 Stream 4 种方法

    •通过Collection中的steam()方法创建流
    •通过Collection中的parallelSteam()方法创建流
    •通过Arrays中的steam()方法创建流
    •通过Stream中的of()静态方法创建流
    •通过Stream中的iterate()方法创建流
    •通过Steam中的generate()方法创建流

     常见Stream接口的继承关系

    Stream的中间操作

           多个中间操作可以连接起来形成一个流水线,除非流水线上触发终止操作,否则中间操作不会执行任何的处理而在终止操作时一次性全部处理,称为“惰性求值”。

     上面这个例子主要是对一组String数据进行操作,主要涉及到的中间操作方法有filter(),limit(),skip(),distinct()终止操作方法有forEach(),下面我们对这些常用方法进行简单介绍

     中间操作常用方法

    分类

    方法

    描述

    筛选和切片

    filter(Predicate p)

    接收Lambda,从流中排除某些元素

    limit(long maxSize)

    截断流,使其元素不超过给定数量

    skip(long n)

    跳过元素,返回一个跳过前n个元素的流。若流中元素不足n个,则返回一个空流。与limit(n)互补

    distinct()

    筛选,通过流所生成元素的hashCode()equals()去除重复元素

    映射

    map(Function f)

    接收一个函数作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素

    mapToDouble(ToDoubleFunction f)

    接收一个函数作为参数,该函数会被应用到每个元素上,产生一个新的DoubleStream

    mapTolnt(ToIntFunction f)

    同上

    mapToLong(ToLongFunction f)

    同上

    flatMap(Function f)

    接收一个函数作为参数,将流中的每一个值都换成另一个流,然后把所有流连接成一个流

    排序

    sorted()

    产生一个新流,其中按自然顺序排序

    sorted(Comparator c)

    产生一个新流,其中按比较器顺序排序

     Stream的终止操作

    分类

    方法

    描述

    查找与匹配

    allMatch(Predicate p)

    检查是否匹配所有元素

    anyMatch(Predicate p)

    检查是否至少匹配一个元素

    findFirst()

    检查是否没有匹配所有元素返回第一个元素

    findAny()

    返回当前流中的任意元素

    count()

    返回流中元素总数

    max(Comparator c)

    返回流中最大值

    min(Comparator c)

    返回流中最小值

    forEach()

    内部迭代

    归约

    reduce(T iden, BinaryOperator b)

    可以将流中元素反复结合起来,得到一个值。返回T

    reduce(BinaryOperator b)

    可以将流中元素反复结合起来,得到一个值。返回 Optional

    收集

    collect(Collector c)

    将流转换为其他形式。接收一个 Collector 接口的实现,用于给 Stream 中元素做汇总的方法

     演示

     Stream的终止操作-collect()

      Collector 接口中方法的实现决定了如何对流执行收集操作(如收集到 ListSet/Map)。但是 Collectors 实用类提供了很多静态方法,可以方便地创建常见收集器实例,具体方法与实例如下表:

    方法

    返回类型

    作用

    toList

    List

    把流中元素收集到 List

    toSet

    Set

    把流中元素收集到 Set

    toCollection

    Collection

    把流中元素收集到 Collection

    counting

    Long

    计算流中元素的个数

    summingInt

    Integer

    对流中元素的整数属性求和

    averagingInt

    Double

    计算流中元素Integer属性的平均值

    summarizingInt

    IntSummaryStatistics

    收集流中Integer属性的统计值,如:平均值

    joining

    String

    连接流中每个字符串

    maxBy

    Optional

    根据比较器选择最大值

    minBy

    Optional

    根据比较器选择最小值

    reducing

    归约产生的类型

    收集流中Integer属性的统计值,如:平均值

    collectingAndThen

    转换函数返回的类型

    包裹另一个收集器,对其结果转换函数

    groupingBy

    Map

    根据某属性值对流分组,属性为K,结果为V

    partitioningBy

    Map

    根据truefalse进行分区

     

     

     

     示例代码演示

    1. package part5;
    2. import org.junit.Test;
    3. import java.util.*;
    4. import java.util.stream.Collectors;
    5. import java.util.stream.Stream;
    6. /**
    7. * @date : 2022/11/23 14:30
    8. */
    9. public class JunitStream {
    10. /**
    11. * 数据源(集合、数组、变量、字符串。。。)---》Stream流对象
    12. * 1、创建Stream流对象
    13. */
    14. @Test
    15. public void createStream() {
    16. // list1数据源
    17. List<Integer> list1 = new ArrayList<>();
    18. list1.add(10);
    19. list1.add(30);
    20. list1.add(20);
    21. // 1)集合对象中 stream()
    22. Stream<Integer> stream = list1.stream();
    23. stream.forEach(t -> System.out.println(t));
    24. // 2)集合中方式2
    25. Stream<Integer> stream2 = list1.parallelStream();
    26. stream2.forEach(t -> System.out.println(t));
    27. // 3)数组数据源--》Stream
    28. Integer[] arr = {1, 3, 5, 7};
    29. Stream<Integer> stream3 = Arrays.stream(arr);
    30. // 4)Stream中的of方法
    31. Stream<Integer> stream4 = Stream.of(1, 2, 3, 4, 5);
    32. stream4.forEach(t-> System.out.println(t));
    33. // 5)Stream中iterate
    34. // 数据进行计算:从0开始 让他每次+2 :0 2 4 6 8 10.....
    35. // iterate无限流
    36. // Stream<Integer> stream5 = Stream.iterate(0, t -> t + 2);
    37. // limit(3) 获取前3个数据
    38. Stream<Integer> stream6 = Stream.iterate(0, t -> t + 2).limit(3);
    39. stream6.forEach(t -> System.out.println(t));
    40. System.out.println("===================");
    41. // 6)Stream.generate
    42. // Math.random()--double
    43. // Stream.generate(()->{return Math.random();});
    44. // Stream.generate(()-> Math.random());
    45. // Stream<Double> generate = Stream.generate(Math::random);
    46. Stream<Double> stream7 = Stream.generate(Math::random).limit(2);
    47. stream7.forEach(t -> System.out.println(t));
    48. // stream7.forEach(System.out::println);
    49. }
    50. /**
    51. * 2、流操作:
    52. * 中间操作
    53. */
    54. @Test
    55. public void operation() {
    56. Stream<String> stream = Stream.of("Tom", ",", "Hello", " ", "Hello", "World");
    57. // 1)中间操作-->新Stream流
    58. // filter:过滤流 返回true条件都会添加到这个新流当中
    59. Stream<String> newStream = stream.filter(str -> {
    60. if (",".equals(str)) {
    61. return false;
    62. } else {
    63. return true;
    64. }
    65. });
    66. newStream.forEach(t -> System.out.println(t));
    67. System.out.println("---------------------------");
    68. Stream<String> stream2 = Stream.of("Tom", ",", "Hello", " ", "Hello", "World");
    69. // 中间操作--limit 获取前X个数据
    70. Stream<String> newStream2 = stream2.limit(2);
    71. newStream2.forEach(t -> System.out.println(t));
    72. System.out.println("------1111111111----------------------------");
    73. Stream<String> stream3 = Stream.of("Tom", ",", "Hello", " ", "Hello", "World");
    74. // 中间操作---skip跳过前多少个数据
    75. Stream<String> streamNew = stream3.skip(2);
    76. streamNew.forEach(t -> System.out.println(t));
    77. System.out.println("----distict:-----------------------------");
    78. Stream<Integer> streamDistinct = Stream.of(10, 20, 30, 10, 5);
    79. // 中间操作去重--distinct
    80. Stream<Integer> newDistinctStream = streamDistinct.distinct();
    81. newDistinctStream.forEach(t -> System.out.println(t));
    82. // 数组 1,3,7,8,9,2,4,7,2----去重后求其数据个数
    83. Integer[] arr2 = {1, 3, 7, 8, 9, 2, 4, 7, 2};
    84. Stream<Integer> stream1 = Arrays.stream(arr2);
    85. long count = stream1.distinct().count();
    86. System.out.println("count:" + count);
    87. Stream<String> stream4 = Stream.of("Tom", ",", "Hello", " ", "Hello", "World");
    88. // Stream<String> count1 = stream.filter(str -> !",".equals(str) ? true : false).limit(3).skip(1).distinct();
    89. // 中间流 可以使用连续操作---链式编程
    90. long count1 = stream4.filter(str -> !",".equals(str) ? true : false).limit(3).skip(1).distinct().count();
    91. System.out.println("count1:" + count1);
    92. System.out.println("=========sorted=============");
    93. Integer[] arr = {1, 3, 7, 8, 9, 2, 4, 7, 2};
    94. // 使用流的操作:数组去重 按照升序进行输出
    95. Stream<Integer> stream5 = Arrays.stream(arr);
    96. // 按照升序进行输出
    97. // stream5.distinct().sorted().forEach(t-> System.out.println(t));
    98. // 降序进行输出
    99. stream5.distinct().sorted((a1, a2) -> a2.compareTo(a1)).forEach(t -> System.out.println(t));
    100. System.out.println("flatMap:===================");
    101. // 需求:"e", "d", "c", "a", "f", "b"--->"edcafb"
    102. Stream<String> stream6 = Stream.of("e", "d", "c", "a", "f", "b");
    103. stream6.flatMap(t -> Stream.of(t)).forEach(t -> System.out.print(t));
    104. System.out.println("=============================");
    105. Integer[] arr66 = {1, 3, 7, 8, 9, 2, 4, 7, 2, 60, 70};
    106. // 分类:>=10归为一类数据 ----》999 <10归为两类----》0
    107. Stream<Integer> stream66 = Arrays.stream(arr66);
    108. Stream<Integer> stream661 = stream66.map(t -> t >= 10 ? 999 : 0);
    109. stream661.forEach(t -> System.out.println(t));
    110. }
    111. /**
    112. * 流操作注意事项:
    113. * Stream 自己不会存储元素----》:数据源--》转换为流
    114. * Stream 不会改变源对象。相反,他们会返回一个持有结果的新 Stream
    115. * Stream 操作是延迟执行的。这意味着他们会等到需要结果的时候才执行
    116. * Stream 只能被"消费"一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
    117. */
    118. @Test
    119. public void operation2() {
    120. Integer[] arr = {1, 3, 7, 8, 9, 2, 4, 7, 2};
    121. Stream<Integer> stream = Arrays.stream(arr);
    122. /*Stream<Integer> stream = Arrays.stream(arr);
    123. Stream<Integer> newStream = stream.skip(2).distinct();
    124. long count = newStream.count();*/
    125. // Stream 只能被"消费"一次,一旦遍历过就会失效
    126. stream.forEach(t -> System.out.println(t));
    127. // java.lang.IllegalStateException: stream has already been operated upon or closed
    128. long count = stream.distinct().count();
    129. }
    130. /**
    131. * 2、流操作:
    132. * 终止操作
    133. */
    134. @Test
    135. public void operation3() {
    136. // Integer[] arr = {11, 3, 17};
    137. // Stream<Integer> stream = Arrays.stream(arr);
    138. // 判断数组中至少含有一个大于10数据
    139. // anyMatch:至少含有一个
    140. /* boolean result1 = stream.anyMatch(t -> t > 10);
    141. System.out.println("result1:"+result1);*/
    142. // 判断数组中所有的数据都大于5 true
    143. /* boolean resultALl = stream.allMatch(t -> t >5);
    144. System.out.println("resultALl:"+resultALl);*/
    145. // 求 数组中所有元素之和
    146. /* Optional<Integer> reduce = stream.reduce((num1, num2) -> num1 + num2);
    147. Integer sum = reduce.get();
    148. System.out.println("sum:"+sum);*/
    149. // 求 数组中所有数据乘积
    150. /*Optional<Integer> reduce2 = stream.reduce((num1, num2) -> num1 * num2);
    151. Integer result = reduce2.get();
    152. System.out.println("result:"+result);
    153. Stream<String> streamNew = Stream.of("a", "b", "c");
    154. Optional<String> reduce3 = streamNew.reduce((str1, str2) -> str1 + str2);
    155. String str = reduce3.get();
    156. System.out.println(str);*/
    157. /* Integer[] arr1 = {1, 2, 3, 4, 5};
    158. Stream<Integer> stream1 = Arrays.stream(arr1);
    159. // 求 数组中所有奇数和
    160. Optional<Integer> reduce7 = stream1.filter(t -> t % 2 != 0).reduce((a, b) -> a + b);
    161. Integer result77 = reduce7.get();
    162. System.out.println(result77);*/
    163. // System.out.println("=======collect:=流--》集合对象转换===============");
    164. /*Stream<String> stream2 = Stream.of("e", "d", "c", "a", "f", "b"); //把流中元素收集到
    165. List<String> list = stream2.collect(Collectors.toList()); // 调用终止操作的方法后需要重新定义
    166. Stream stream = Stream.of("e", "d", "c", "a", "f", "b"); // 把流中元素收集到
    167. Set<String> set = stream2.collect(Collectors.toSet());
    168. stream = Stream.of("e", "d", "c", "a", "f", "b");
    169. // 把流中元素收集到 Collection(ArrayList)
    170. // ArrayList::new 等同于()->new ArrayList()
    171. // ArrayList::new 可以是list,set接口下的任意实现类
    172. ArrayList<String> alist = stream2.collect(Collectors.toCollection(ArrayList::new));
    173. System.out.println(list); // [e, d, c, a, f, b]
    174. System.out.println(set); // [a, b, c, d, e, f]
    175. System.out.println(alist); // [e, d, c, a, f, b]
    176. */
    177. System.out.println("====collect===Collectors:功能===============");
    178. Integer[] arr2 = {1, 2, 3, 4, 5};
    179. Stream<Integer> stream1 = Arrays.stream(arr2);
    180. // 计数
    181. /*Long count = stream1.collect(Collectors.counting());
    182. System.out.println("count:"+count);*/
    183. // 求和
    184. Integer sum = stream1.collect(Collectors.summingInt(t -> t));
    185. System.out.println("sum:"+sum);
    186. System.out.println("========================");
    187. // groupingBy: 分班 java314 精英班 成绩要求都是80分(含)以上 80分以下分数---java00
    188. Integer[] scores = {85, 90, 100, 70, 80,75};
    189. // java314---》 85 90 100 80
    190. // java00--->70 75
    191. Stream<Integer> stream = Arrays.stream(scores);
    192. Map<String, List<Integer>> map = stream.collect(Collectors.groupingBy(t -> t >= 80 ? "java314" : "java00"));
    193. map.forEach((k,v)-> System.out.println(k+"----"+v));
    194. }
    195. }

     作业

    1. package part5;
    2. import java.util.*;
    3. import java.util.stream.Collectors;
    4. import java.util.stream.Stream;
    5. /**
    6. * @author : cqq
    7. * @date : 2022/11/23 13:13
    8. */
    9. public class Task {
    10. public static void main(String[] args) {
    11. // 1. 给一个整数集合,分别求集合中偶数和与奇数和
    12. List<Integer> list1 = new ArrayList<>();
    13. list1.add(1);
    14. list1.add(2);
    15. list1.add(3);
    16. list1.add(4);
    17. list1.add(5);
    18. list1.add(6);
    19. list1.add(7);
    20. list1.add(8);
    21. list1.add(9);
    22. list1.add(10);
    23. // list1.stream().filter(t->t%2==0).forEach(a-> System.out.println(a));
    24. Optional<Integer> reduce = list1.stream().filter(t -> t % 2 == 0).reduce((x, y) -> x + y);
    25. Integer ou = reduce.get();
    26. System.out.println("ou和:"+ou);
    27. // list1.stream().filter(t->t%2!=0).forEach(a-> System.out.println(a));
    28. Optional<Integer> ji = list1.stream().filter(t -> t % 2 != 0).reduce((x, y) -> x + y);
    29. System.out.println("ji和:"+ji.get());
    30. //
    31. //
    32. //
    33. //
    34. //
    35. System.out.println("---------------------");
    36. // 2. 给一个整数集合,将集合分成偶数集合和奇数集合
    37. ArrayList<Integer> li = new ArrayList<>();
    38. li.add(1);
    39. li.add(2);
    40. li.add(3);
    41. li.add(4);
    42. li.add(5);
    43. li.add(6);
    44. List<Integer> ou1 = li.stream().filter(t->t%2==0).collect(Collectors.toList());
    45. System.out.println("ou:"+ou1);
    46. List<Integer> ji1 = li.stream().filter(t->t%2!=0).collect(Collectors.toList());
    47. System.out.println("ji:"+ji1);
    48. /*// List<Integer> list22 = list1.stream().filter(t -> t % 2 == 0).collect(Collectors.toList());
    49. List<String> list66 = list1.stream().map(t -> t + "").collect(Collectors.toList());
    50. System.out.println(list66);
    51. System.out.println("---------888888888888------------");
    52. List list7 = new ArrayList<>();
    53. list7.add("hello");
    54. list7.add(2);
    55. System.out.println(list7);
    56. System.out.println("===========999999999:=============");
    57. //
    58. //*/
    59. //
    60. // 3. 集合转换:[[1, 2, 3, 4, 5], [2, 1, 9, 3, 6, 7], [3, 1, 6]] -> ["1", "2", "4", "5", "2", …… "3", "1","6"]
    61. List<Integer> list4 = new ArrayList<>();
    62. List<Integer> list2 = new ArrayList<>();
    63. List<Integer> list3 = new ArrayList<>();
    64. Collections.addAll(list4,1,2,3,4,5);
    65. Collections.addAll(list2,3,1,6);
    66. Collections.addAll(list3,2,1,9,3,6,7);
    67. List<String> list = new ArrayList<>();
    68. list1.stream().map(t -> list.add("“"+t+"”")).collect(Collectors.toList());
    69. list2.stream().map(t -> list.add("“"+t+"”")).collect(Collectors.toList());
    70. list3.stream().map(t -> list.add("“"+t+"”")).collect(Collectors.toList());
    71. System.out.println(list);
    72. /* List<Integer> list99 = new ArrayList<>();
    73. list99.add(1);
    74. list99.add(2);
    75. list99.add(3);
    76. List<Integer> list5 = new ArrayList<>();
    77. list5.add(11);
    78. list5.add(21);
    79. list5.add(31);
    80. List<Integer> list88 = new ArrayList<>();
    81. list88.add(88);
    82. list88.add(99);
    83. list5.stream().map(t -> list99.add(t)).collect(Collectors.toList());
    84. System.out.println(list99);
    85. System.out.println("list................");
    86. list88.stream().map(t -> list99.add(t)).collect(Collectors.toList());
    87. System.out.println(list99);
    88. // Stream<String> stringStream = Stream.of("e", "d", "c", "a", "f", "b");
    89. // String st = stringStream.reduce("", (str1, str2) -> str1 = str1 + str2);
    90. // System.out.println(st);*/
    91. }
    92. }

  • 相关阅读:
    另一个博客
    力扣labuladong——一刷day39
    java计算机毕业设计-人事管理系统-源码+数据库+系统+lw文档+mybatis+运行部署
    2022最新版-李宏毅机器学习深度学习课程-P51 BERT的各种变体
    C语言结构体大小分析
    【ML on Kubernetes】第 7 章:模型部署和自动化
    MIPI CSI-2笔记(19) -- 数据格式(用户自定义数据格式)
    LeetCode 数据结构与算法:最大子数组和
    awk,gawk基本用法笔记221107
    【Azure 环境】【Azure Developer】使用Python代码获取Azure 中的资源的Metrics定义及数据
  • 原文地址:https://blog.csdn.net/qq_63202674/article/details/128029124