【进阶篇-Day12:JAVA中stream流、File类的介绍】

目录

  • 1、stream流
    • 1.1 stream流的作用
    • 1.2 stream流的思想
    • 1.3 获取stream流对象
    • 1.4 stream流中间操作方法
    • 1.5 stream流终结操作方法
    • 1.6 stream收集操作
    • 1.7 stream的综合案例
  • 2、File类
    • 2.1 File类创建文件对象
    • 2.2 File类的常用方法
    • 2.3 File类的创建和删除方法
    • 2.4 File类的遍历方法
      • 练习一:
      • 练习二:
      • 练习三:
      • 练习四:

1、stream流

1.1 stream流的作用

在这里插入图片描述

1.2 stream流的思想

在这里插入图片描述

注:stream流就是流水线工作,即将数据放入流水线(获取流对象),然后加工(中间方法),最后输出(终结方法

1.3 获取stream流对象

在这里插入图片描述

package com.itheima.stream;
import java.util.*;
import java.util.stream.Stream;public class StreamDemo1 {/*** 获取Stream流对象演示:*     - 将数据放在流水线的传送带上**     1、集合获取 Stream 流对象 (使用Collection接口中的默认方法)*             default Stream<E> stream()*             注意:Map集合获取Stream流对象,需要间接获取:*                     - map.entrySet().stream()**     2、数组获取 Stream 流对象 (使用Array数组工具类中的静态方法)*             static <T> Stream<T> stream (T[] array)**     3、零散的数据获取Stream 流对象 (使用Stream类中的静态方法)*             static <T> Stream<T> of(T... values)*/public static void main(String[] args) {//1、集合获取 Stream 流对象//1.1 List集合获取 Stream 流对象List<String> list = new ArrayList<>();list.add("张三丰");list.add("张无忌");list.add("张翠山");list.add("王二麻子");list.add("张良");list.add("谢广坤");list.stream().forEach(s -> {System.out.println(s);});//1.2 Set集合获取 Stream 流对象Set<String> set = new HashSet<>();set.add("张三丰");set.add("张无忌");set.add("张翠山");set.add("王二麻子");set.add("张良");set.add("谢广坤");set.stream().forEach(s -> System.out.println(s));//1.3 Map集合获取 Stream 流对象Map<String, Integer> map = new HashMap<>();map.put("张三丰", 100);map.put("张无忌",98);map.put("张翠山",29);map.put("王二麻子",55);map.put("张良",68);map.put("谢广坤",70);map.entrySet().stream().forEach(s -> System.out.println(s));//2、数组获取 Stream 流对象int[] arr1 = {11,22,33};double[] arr2 = {11.1,22.2,33.3};Arrays.stream(arr1).forEach(s -> System.out.println(s));Arrays.stream(arr2).forEach(s -> System.out.println(s));//3、零散的数据获取Stream 流对象: 零散就是这些数既没有在集合中,也没有在数组中Stream.of(1,2,3,4,5,6).forEach(s -> System.out.println(s));Stream.of("11","22","33","44").forEach(s -> System.out.println(s));}
}

1.4 stream流中间操作方法

在这里插入图片描述

package com.itheima.stream;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;public class StreamDemo2 {/*** Stream流的中间操作方法:*     - 操作后返回Stream流对象,可以继续操作**     Stream<T> filter(Predicate<? super T> predicate) 用于对流中的数据进行过滤*     Stream<T> limit(long maxSize) 获取前几个元素*     Stream<T> skip(long n) 跳过前几个元素*     Stream<T> distinct() 去除流中重复的元素依赖(hashCode 和 equals方法)*     static <T> Stream<T> concat(Stream a, Stream b) 合并a和b两个流为一个流*         - 注意:如果流的对象消费过(使用过),就不允许再消费了。*/public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("张三丰");list.add("张无忌");list.add("张翠山");list.add("王二麻子");list.add("张良");list.add("谢广坤");//需求1:将集合中以【张】开头的数据 和 长度为3,过滤出来并打印在控制台list.stream().filter(v -> v.startsWith("张")).filter(v -> v.length() == 3).forEach(e -> System.out.println(e));System.out.println("-------------------------------------");//需求2:取前3个数据在控制台输出 ---> limit(long maxSize) 获取前几个元素list.stream().limit(3).forEach(e -> System.out.println(e));System.out.println("-------------------------------------");//需求3:跳过3个元素,把剩下的元素在控制台输出  ---> skip(long n) 跳过前几个元素list.stream().skip(3).forEach(e -> System.out.println(e));System.out.println("-------------------------------------");//需求4:跳过2个元素,把剩下的元素中前2个在控制台输出list.stream().skip(2).limit(2).forEach(e -> System.out.println(e));System.out.println("-------------------------------------");//需求5:取前4个数据组成一个流Stream<String> stream1 = list.stream().limit(4);System.out.println("-------------------------------------");//需求6:跳过2个数据组成一个流Stream<String> stream2 = list.stream().skip(2);System.out.println("-------------------------------------");//需求7:合并需求1和需求2得到的流,并把结果在控制台输出Stream<String> stream3 = Stream.concat(stream1, stream2);
//        stream3.forEach(e -> System.out.println(e));//注意:流用过之后,不可以再用了System.out.println("-------------------------------------");//需求8:合并需求1和需求2得到的流,并把结果在控制台输出,要求字符串元素不能重复stream3.distinct().forEach(e -> System.out.println(e));System.out.println("-------------------------------------");}
}

在这里插入图片描述

1.5 stream流终结操作方法

在这里插入图片描述

package com.itheima.stream;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Stream;public class StreamDemo3 {/*** Stream流的终结操作方法*     - 流水线中的最后一道工序* *     public void forEach(Consumer action) 对此流的每个元素执行遍历操作*     public long count() 返回此流中的元素数*/public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("张三丰");list.add("张无忌");list.add("张翠山");list.add("王二麻子");list.add("张良");list.add("谢广坤");//1、forEach(Consumer action) 对此流的每个元素执行遍历操作list.stream().forEach(e -> System.out.println(e));//2、long count() 返回此流中的元素数System.out.println(list.stream().count());//6System.out.println(Stream.of(1, 2, 3, 4, 5, 6, 7, 8, 9).count());//9}
}

1.6 stream收集操作

注意:
Stream不会修改原始的集合,因此在流里的操作后的结果,需要用新的集合来保存。

在这里插入图片描述

package com.itheima.stream;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.stream.Collectors;
import java.util.stream.Stream;public class StreamDemo4 {/*** Stream流的收集操作:*     public R collect (Collector c):将流中的数据收集到集合**         Collectors*             public static <T> Collector toList()*             public static <T> Collector toSet()*             public static <T> Collector toMap(Function keyMapper,Function valueMapper)*/public static void main(String[] args) {//1、toList():将流对象收集到list集合中List<Integer> list = Stream.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10).filter(e -> e % 2 == 0).collect(Collectors.toList());System.out.println(list);//[2, 4, 6, 8, 10]//2、toSet():将流对象收集到set集合中 ---> 注意,收集时set还是会去重Set<Integer> set = Stream.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10,10,10,10).filter(e -> e % 2 == 0).collect(Collectors.toSet());System.out.println(set);//[2, 4, 6, 8, 10]//3、toMap()方法比较复杂,用一个需求来介绍:/*需求:创建一个 ArrayList 集合,并添加以下字符串"张三,23","李四,24","王五,25"保留年龄大于等于24岁的人,并将结果收集到Map集合中,姓名为键,年龄为值*/ArrayList<String> arrayList = new ArrayList<>();arrayList.add("张三,23");arrayList.add("李四,24");arrayList.add("王五,25");Map<String, Integer> map1 = arrayList.stream().filter(s -> Integer.parseInt(s.split(",")[1]) >= 24).collect(Collectors.toMap(new Function<String, String>() {@Overridepublic String apply(String s) {//第一个匿名内部类 ---》指定keyreturn s.split(",")[0];}}, new Function<String, Integer>() {@Overridepublic Integer apply(String s) {//第二个匿名内部类 ---》指定valuereturn Integer.parseInt(s.split(",")[1]);}}));//上述写法可写成lambda表达式,如下:Map<String, Integer> map2 = arrayList.stream().filter(s -> Integer.parseInt(s.split(",")[1]) >= 24).collect(Collectors.toMap(s -> s.split(",")[0], s -> Integer.parseInt(s.split(",")[1])));System.out.println(map1);//{李四=24, 王五=25}}
}

1.7 stream的综合案例

在这里插入图片描述

package com.itheima.stream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import java.util.stream.Stream;public class StreamDemo5 {public static void main(String[] args) {List<String> list1 = new ArrayList<>();list1.add("林菲菲");list1.add("李飞飞");list1.add("林格格");list1.add("黄方面");list1.add("林黛玉十");list1.add("林黛玉");List<String> list2 = new ArrayList<>();list2.add("马大炮");list2.add("猪八戒");list2.add("唐僧");list2.add("孙悟空");list2.add("狗蛋蛋");list2.add("范杰杰");Stream<String> stream1 = list1.stream().filter(v -> v.startsWith("林")).skip(1);Stream<String> stream2 = list2.stream().filter(v -> v.length() == 3).limit(2);List<String> collect = Stream.concat(stream1, stream2).collect(Collectors.toList());//把两个流合并为一个使用concat方法Map<String, Actor> map = new HashMap<>();for (String s : collect) {Actor a = new Actor(s);map.put(s, a);}System.out.println(map);//{林黛玉十=Actor{name='林黛玉十'}, 林格格=Actor{name='林格格'}, 猪八戒=Actor{name='猪八戒'}, 林黛玉=Actor{name='林黛玉'}, 马大炮=Actor{name='马大炮'}}}
}

未完待续。。。。。。

2、File类

在这里插入图片描述

2.1 File类创建文件对象

在这里插入图片描述

package com.itheima.file;
import java.io.File;
import java.io.IOException;public class FileDemo1 {/*** File类介绍 : 文件或文件夹对象** 构造方法 :*         1、public File(String pathname):根据传入的字符串路径封装File对象*         2、public File(String pathname,String child):根据传入的父级路径和子级路径来封装File对象*         3、public File(File parent, String child):根据传入的父级路径(File类型)和子级路径来封装File对象*/public static void main(String[] args) throws IOException {//1、File(String pathname):根据传入的字符串路径封装File对象File f1 = new File("E:\\A.txt");//读取文件对象f1.createNewFile();File f2 = new File("E:\\test");//读取文件夹System.out.println(f2.exists());//存在返回true,不存在返回false//2、File(String pathname,String child):根据传入的父级路径和子级路径来封装File对象File f3 = new File("E:\\", "test");//父路径+子路径,封装File对象System.out.println(f3.exists());//true//3、File(File parent, String child):根据传入的父级路径(File类型)和子级路径来封装File对象File f4 = new File(new File("E:\\"), "test");System.out.println(f4.exists());//true}
}

注意:文件夹路径有相对路径和绝对路径两种写法
在这里插入图片描述

package com.itheima.file;
import java.io.File;
import java.io.IOException;public class FileDemo2 {/*** 路径的写法:*     1、相对路径:相对于当前项目*     2、绝对路径:从盘符根目录开始,一直到某个具体的文件或文件夹*/public static void main(String[] args) throws IOException {//1、相对路径File f1 = new File("A.txt");f1.createNewFile();//2、绝对路径File f2 = new File("E:\\test\\A.txt");}}

2.2 File类的常用方法

在这里插入图片描述

package com.itheima.file;
import java.io.File;
import java.time.LocalDateTime;
import java.util.Date;public class FileDemo3 {/*** File类常见方法:*     1、判断相关*             public boolean isDirectory():判断是否是文件夹*             public boolean isFile():判断是否是文件*             public boolean exists():判断是否存在**     2、获取相关*             public long length():返回文件的大小(字节数量)*                     - 为文件对象时,返回正确的字节数量*                     - 为文件夹对象时,返回错误的字节数量*             public String getAbsolutePath():返回文件的绝对路径*             public String getPath():返回文件使用时的路径*             public String getName():返回文件的名称,带后缀*             public long lastModified():返回文件的最后修改时间(时间毫秒值)*/public static void main(String[] args) {//1、判断相关File f1 = new File("E:\\A.txt");//isDirectory():判断是否是文件夹System.out.println(f1.isDirectory());//isFile():判断是否是文件System.out.println(f1.isFile());//exists():判断是否存在System.out.println(f1.exists());System.out.println("---------------------------------------");//2、获取相关File f2 = new File("E:\\GNN");//length():返回文件的大小(字节数量)System.out.println(f1.length());//为文件对象时,返回正确的字节数量System.out.println(f2.length());//为文件夹对象时,返回错误的字节数量//getAbsolutePath():返回文件的绝对路径System.out.println(f1.getAbsoluteFile());//E:\A.txtSystem.out.println(f2.getAbsoluteFile());//E:\GNN//getPath():返回文件使用时的路径System.out.println(f1.getPath());//E:\A.txtSystem.out.println(f2.getPath());//E:\GNN//getName():返回文件的名称,带后缀System.out.println(f1.getName());//A.txtSystem.out.println(f2.getName());//GNN//lastModified():返回文件的最后修改时间(时间毫秒值)System.out.println(f1.lastModified());//1721657586035System.out.println(f2.lastModified());//1601530884989System.out.println(new Date(f2.lastModified()));//Thu Oct 01 13:41:24 CST 2020}
}

在这里插入图片描述

package com.itheima.file;
import java.io.File;
import java.util.Scanner;public class FileDemo4 {public static void main(String[] args) {File dir = getDir();System.out.println(dir);}public static File getDir(){Scanner sc = new Scanner(System.in);System.out.println("请输入文件路径:");while (true) {String dir = sc.nextLine();File f = new File(dir);if (!f.exists()) {System.out.println("你输入的文件路径不存在,请重新输入!");} else if (f.isFile()) {System.out.println("你输入的是一个文件,请重新输入!");} else {return f;}}}
}

2.3 File类的创建和删除方法

在这里插入图片描述

package com.itheima.file;import java.io.File;
import java.io.IOException;public class FileDemo5 {/*** File类的创建方法和删除方法:*     public boolean createNewFile():创建文件*     public boolean mkdir():创建单极文件夹*     public boolean mkdirs():创建多极文件夹*     public boolean delete():删除文件或文件夹*             - delete 方法删除文件夹时,只能删除空的文件夹*/public static void main(String[] args) throws IOException {//1、createNewFile():创建文件File f1 = new File("A.txt");System.out.println(f1.createNewFile());//不存在则创建文件并返回true,存在则返回false//2、mkdir():创建单极文件夹File f2 = new File("aaa");System.out.println(f2.mkdir());//不存在则创建文件夹并返回true,存在则返回false//3、mkdirs():创建多极文件夹File f3 = new File("bbb\\ccc\\ddd");System.out.println(f3.mkdirs());不存在则创建文件夹并返回true,存在则返回false//4、delete():删除文件或文件夹System.out.println(f1.delete());//存在则删除并返回true,否则返回false}
}

2.4 File类的遍历方法

在这里插入图片描述

注意:
在这里插入图片描述

package com.itheima.file;import java.io.File;public class FileDemo6 {/*** File类的遍历方法:*         public File[] listFiles():获取当前目录下所有的 ”一级文件对象“ 返回File数组*/public static void main(String[] args) {File f1 = new File("C:\\Users\\MSZ\\Desktop\\java_test\\dev\\day12-code");File[] files = f1.listFiles();for (File file : files) {System.out.println(file);}}
}

练习一:

需求:键盘录入一个文件夹路径,找出这个文件夹下所有的 .java 文件

package com.itheima.file;
import java.io.File;
import java.util.Scanner;public class FileDemo7 {/*** 需求:键盘录入一个文件夹路径,找出这个文件夹下所有的 .java 文件*/public static void main(String[] args) {//1、获取文件夹路径File dir = getDir();//2、找出文件夹下的.java文件for (File file : dir.listFiles()) {if (file.isFile() && file.getName().endsWith(".java")){System.out.println(file);}}}public static File getDir(){Scanner sc = new Scanner(System.in);System.out.println("请输文件夹路径:");while (true) {String path = sc.nextLine();File f = new File(path);if (f.isFile()){System.out.println("您输入的是一个文件,请重新输入!");} else if (!f.exists()) {System.out.println("您输入的问价夹不存在,请重新输入!");}else {return f;}}}
}

上述方法如果遇到多级文件夹下还有.java文件,那就获取不到了,于是我们可以使用递归来解决这个问题:

package com.itheima.file;
import java.io.File;
import java.util.Scanner;public class FileDemo7 {/*** 需求:键盘录入一个文件夹路径,找出这个文件夹下所有的 .java 文件*/public static void main(String[] args) {File dir = getDir();printJavaFile(dir);}public static void printJavaFile(File dir){//1、获取当前路径下的文件夹和文件的对象File[] files = dir.listFiles();//2、遍历数组对象for (File file : files) {//3、如果.java文件则打印if (file.isFile() && file.getName().endsWith(".java")){System.out.println(file);} else if (file.isDirectory()) {//4、如果是文件夹,则递归调用自身继续找.java文件if (file.listFiles() != null){printJavaFile(file);}}}}public static File getDir(){Scanner sc = new Scanner(System.in);System.out.println("请输文件夹路径:");while (true) {String path = sc.nextLine();File f = new File(path);if (f.isFile()){System.out.println("您输入的是一个文件,请重新输入!");} else if (!f.exists()) {System.out.println("您输入的问价夹不存在,请重新输入!");}else {return f;}}}
}

练习二:

在这里插入图片描述

package com.itheima.file;
import java.io.File;
import java.util.Collections;public class FileDem8 {/*** 需求:设计一个方法,删除文件夹(delete()只能删除空文件夹)*/public static void main(String[] args) {File f = new File("C:\\Users\\MSZ\\Desktop\\java_test\\dev\\test111");deleteDir(f);}public static void deleteDir(File file){//获取文件夹下所有的文件对象File[] files = file.listFiles();for (File f : files) {if (f.isFile()){//如果是文件则直接删除f.delete();}else {//非空文件夹,递归删除if (f.listFiles() != null){deleteDir(f);}}}//循环结束了,表明已经是空文件夹了,则删除此文件夹file.delete();}
}

练习三:

在这里插入图片描述

package com.itheima.file;
import java.io.File;public class FileDem9 {/*** 需求:键盘录入一个二五年间加路径,统计文件夹的大小*         -length()方法只能获取文件的大小,不能获取文件夹的大小*/public static void main(String[] args) {long dirSize = getDirSize(new File("C:\\Users\\MSZ\\Desktop\\java_test\\dev\\code"));System.out.println(dirSize);}public static long getDirSize(File file){long length = 0L;File[] files = file.listFiles();for (File f : files) {if (f.isFile()){//是文件,则获取文件的大小length += f.length();}else {//是文件夹,则递归获取里面的文件大小if (f.listFiles() != null){length += getDirSize(f);}}}return length;}
}

练习四:

在这里插入图片描述

package com.itheima.file;
import java.io.File;
import java.util.HashMap;
import java.util.Map;public class FileDem10 {/*** 需求:键盘录入一个文件夹路径,统计文件夹中每种文件的个数并打印(考虑子文件夹)* 打印格式如下:*           txt:3个*           doc:4个*           jpg:6个*/static int count = 0;//统计没有后缀名的文件static Map<String, Integer> map = new HashMap<>();//存放结果public static void main(String[] args) {Map<String, Integer> fileNum = getFileNum(new File("C:\\Users\\MSZ\\Desktop\\java_test\\dev\\code"));fileNum.forEach((k, v) -> System.out.println(k + ":" + v + "个"));System.out.println("没有后缀的文件:" + count);}public static Map<String, Integer> getFileNum(File file){//获取当前目录下所有的 ”一级文件对象“ 返回File数组File[] files = file.listFiles();for (File f : files) {if (f.isFile()){//如果是文件,则对应类型的值+1String name = f.getName();if (name.contains(".")){//文件有后缀String[] split = name.split("\\.");String key = split[split.length - 1];if (map.containsKey(key)){map.put(key, map.get(key) + 1);}else {map.put(key, 1);}}else {//文件没有后缀,单独统计count++;}}else {//如果是文件夹,则递归获取if (f.listFiles() != null){getFileNum(f);}}}return map;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/49711.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

埃文科技受邀出席2024年河南省工业领域网络和数据安全政策宣贯会

2024年7月18日&#xff0c;由河南省工业和信息化厅主办&#xff0c;河南省工业信息安全产业发展联盟、河南省信息安全产业协会承办的2024年河南省工业领域网络和数据安全政策宣贯会在郑州召开&#xff0c;活动旨在提升河南省工业领域网络和数据安全保护能力&#xff0c;助力企业…

Fetch请求的取消

在实际开发中&#xff0c;我们常常会遇到根据输入框输入的内容&#xff0c;实时去请求接口并将拿到的数据渲染到页面上&#xff0c;但是由于接口响应时间不可控&#xff0c;简单来说就是请求的顺序和响应的顺序不一致&#xff0c;就会导致你可能输入了12&#xff0c;但实际返回…

PMOS、NMOS 驱动电路和使用方法

下图就是 PMOS 和 NMOS 的简单使用方法。D2 是指示灯&#xff0c;NMOS 的 G 连接单片机 IO&#xff0c;PMOS 的 D 连接 24V 继电器&#xff0c;PMOS 的体二极管作为继电器的反向电动势的吸收二极管 PMOS 和 NMOS 不一样&#xff0c;在远超单片机电压下控制 PMOS 必须依靠一个 N…

CSS相关记录

文章目录 backgroundposition文字displayflexjustify-contentalign-itemsflex-directionflex-wrap gridimportant transformtranslate&#xff08;位移&#xff09;scale&#xff08;缩放&#xff09;rotate&#xff08;旋转&#xff09;origin (旋转中心点)skew (倾斜 ) borde…

C# 知识点总结

入门 C#程序在.NET上运行&#xff0c;.NET framework包含两个部分&#xff1a; ①&#xff1a;.NET framework类库 ②&#xff1a;公共语言运行库CLR&#xff08;.NET虚拟机&#xff09; CLS&#xff08;公共语言规范&#xff09; CTS&#xff08;通用类型系统&#xff09; .N…

【分布式系统】 单机架构 | 分布式架构 | 集群 | 主从架构 | 分库分表 | 冷热分离 | 微服务

文章目录 [toc] 分布式系统一、单机架构二、分布式系统三、应用服务器集群四、读写分离 / 主从分离架构五、引入缓存/冷热分离架构六、垂直分库七、微服务架构——业务拆分代价优势 八、名词解释1.应用&#xff08;Application&#xff09;/系统(System)2.模块&#xff08;Mode…

Mysql9安装

目录 一、下载mysql 二、安装 三、配置mysql环境变量 四、mysql初始化和启动 1.以管理员身份运行cmd 2.cd到mysql的安装目录 3.初始化mysql的数据库 4.为Windows系统安装MySQL服务 5.查看一下名为mysql的服务&#xff1a; 6.启动MySQL服务 五、附录 1.系统变量还在&…

CentOS 8中 更新或下载时报错:为仓库 ‘appstream‘ 下载元数据失败 : Cannot prepare internal mirrorlist

一、错误重现 CentOS Stream 8 - AppStream 0.0 B/s | 0 B 00:00 Errors during downloading metadata for repository appstream: - Curl error (6): Couldnt resolve host name for http://mirrorlis…

昇思25天学习打卡营第18天|生成式-GAN图像生成

打卡 目录 打卡 GAN 博弈函数 博弈过程 GAN 案例 数据集 数据加载与可视化 隐码构造 模型构建 生成器 判别器 损失函数和优化器 模型训练 输出展示-1w张训练样本 输出展示-6w张训练样本 输出展示-6w张-100 epoch 效果展示 部分展示如图-12epoch-6w张 部分展…

Windows系统上Git详细图文安装及使用教程

Git 是一种高效、分布式的版本控制系统&#xff0c;用于代码的跟踪、分支管理和协同工作&#xff0c;支持快速提交、合并和回滚操作。它是开发者工具箱中必不可少的工具之一&#xff0c;广泛应用于软件开发和其他需要版本控制的领域。 1. Git的安装 1.1 Git下载 可以通过以下…

Qt SQLite数据库学习总结

到此为止&#xff0c;就使用Qt进行SQLite数据库的操作&#xff0c;做一次总结 1. Qt中数据库操作的相关概念和类 Qt 数据库编程相关基本概念https://blog.csdn.net/castlooo/article/details/140497177 2.表的只读查询--QSqlQueryModel QSqlQueryModel单表查询的使用总结htt…

微信小程序--点击按钮可新增可删除

案例: html: <view ><view ><view class="guzhang" wx:for="{{inputs}}" wx:key="id" wx:for-item="item" wx:for-index="index"><view class="huanhang"><view class="fontBo…

员工网络监控软件:把控员工网络活动的标尺

在竞争激烈的漩涡之中&#xff0c;企业如同一只不断旋转的陀螺&#xff0c;努力保持着自身的平衡和稳定&#xff0c;而员工的网络活动则是那无形却强大的力量&#xff0c;时刻影响着企业的运转。员工网络监控软件仿佛一根坚固无比的轴心&#xff0c;以其精准的标尺帮助企业实现…

Mindspore框架循环神经网络RNN模型实现情感分类|(六)模型加载和推理(情感分类模型资源下载)

Mindspore框架循环神经网络RNN模型实现情感分类 Mindspore框架循环神经网络RNN模型实现情感分类|&#xff08;一&#xff09;IMDB影评数据集准备 Mindspore框架循环神经网络RNN模型实现情感分类|&#xff08;二&#xff09;预训练词向量 Mindspore框架循环神经网络RNN模型实现…

顶级 Vue 管理仪表板和模板

Vue.js 是当今繁忙的 Web 开发领域中最受欢迎的 JavaScript 框架之一&#xff0c;用于创建交互式动态用户界面。Vue.js 的组件反应性及其流畅的数据绑定使其在管理仪表板设计方面占据了主导地位。 本文讨论了一些领先的 ​​Vue 管理员仪表板&#xff0c;它们可以节省您制作 We…

计算机网络之http和https的区别(外加http详解)

http协议和各种协议之间的关系 1、DNS解析&#xff0c;获取到访问服务器的IP 2、HTTP生成请求报文请求&#xff0c;请求访问页面资源 3、TCP协议将报文切割成一份一份报文段后&#xff0c;以可靠的方式进行传输 4、IP协议边搜索边中转&#xff0c;将这些数据包传输给接受方…

k8s 公共服务

修改named.conf。修改第13行和第21行 下面是 named.rfc1912 修改位置&#xff0c;在最后 所以用cp -p 复制文件&#xff0c;保留权限 nslookup 回车&#xff0c;server是看哪个dns 在起作用 dns服务器要配置给所有公共服务节点和 k8s 节点 就在网络文件加个DNS2就行了&…

CSS3雷达扫描效果

CSS3雷达扫描效果https://www.bootstrapmb.com/item/14840 要创建一个CSS3的雷达扫描效果&#xff0c;我们可以使用CSS的动画&#xff08;keyframes&#xff09;和transform属性。以下是一个简单的示例&#xff0c;展示了如何创建一个类似雷达扫描的动画效果&#xff1a; HTM…

docker笔记4-镜像理解

docker笔记4-镜像理解 一、镜像原理之联合文件系统二、镜像原理之分层理解三、commit镜像 一、镜像原理之联合文件系统 UnionFS&#xff08;联合文件系统&#xff09;: Union文件系统&#xff08;UnionFS&#xff09;是一种分层、轻量级并且高性能的文件系统&#xff0c;它支持…

vue2使用univerjs

1、univerjs Univer 提供了一个全面的企业级文档与数据协同的解决方案&#xff0c;支持电子表格、文本文档和演示幻灯片三大核心文档类型。通过灵活的 API 和插件机制&#xff0c;开发者可以在 Univer 的基础上进行个性化功能的定制和扩展&#xff0c;以适应不同用户在不同场景…