Java的IO流(二)

目录

Java的IO流(二)

字节缓冲流

基本使用

使用缓冲流复制文件

字符缓冲流

缓冲流读取数据原理

字符编码

字符集

转换流

序列化流与反序列化流

基本使用

禁止成员被序列化

序列号不匹配异常

打印流

基本使用

系统打印流与改变流向

Properties集合结合IO流

Commons-io工具包

介绍与引入工具包

使用工具包的静态方法

IOUtils工具类

FileUtils工具类

整章结构


Java的IO流(二)

字节缓冲流

基本使用

字节缓冲输入流对应BufferedInputStream类,字节输出缓冲流对应BufferedOutputStream类,各自常用的构造方法如下:

  1. BufferedOutputStream(OutputStream out):使用OutputStream对象进行构造
  2. BufferedInputStream(InputStream in):使用InputStream对象进行构造
BufferedOutputStreamBufferedInputStream都是 OutPutStreamInputStream的实现类

因为对应的字节流中的两个类 FileOutputStream类和 FileInputStream类也是 OutPutStreamInputStream的实现类,所以此处可以使用多态的向上转型将 FileOutputStream对象或者 FileInputStream对象给 OutputStream对象引用或者 InputStream对象引用,从而构造 BufferedOutputStream对象和 BufferedInputStream对象

使用如下:

public class Test {public static void main(String[] args) throws IOException {// 字节输出缓冲流BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(new FileOutputStream("./a.txt"));// 字节输入缓冲流BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream("./a.txt"));}
}

使用方法和方式与字节流一致,基本使用如下:

public class Test {public static void main(String[] args) throws IOException {BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(new FileOutputStream("./a.txt"));bufferedOutputStream.write(98);bufferedOutputStream.flush();BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream("./a.txt"));int word = bufferedInputStream.read();System.out.println((char)word);bufferedInputStream.close();bufferedOutputStream.close();}
}
需要注意的是,在关流时,尽管创建缓冲流相关对象时使用到了基本流对象,但是关流只需要关闭缓冲流相关对象,因为缓冲流关闭流方法底层会先关闭基本流,再关闭缓冲流

使用缓冲流复制文件

public class Test01 {public static void main(String[] args) throws IOException {// 创建字节输入缓冲流BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream("./1.mp3"));// 创建字节输出缓冲流BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(new FileOutputStream("./1-copy.mp3"));// 读取数据int len = 0;byte[] bytes = new byte[1024];while((len = bufferedInputStream.read(bytes)) != -1) {bufferedOutputStream.write(bytes, 0, len);}// 关流bufferedOutputStream.close();bufferedInputStream.close();}
}

字符缓冲流

字符缓冲输入流对应BufferedReader类,字节输出缓冲流对应BufferedWriter类,各自常用的构造方法如下:

  1. BufferedWriter(Writer w):使用OutputStream对象进行构造
  2. BufferedReader(Reader r):使用InputStream对象进行构造
BufferedWriterBufferedReader都是 WriterReader的实现类

因为对应的字节流中的两个类 FileWriter类和 FileReader类也是 WriterReader的实现类,所以此处可以使用多态的向上转型将 FileWriter对象或者 FileReader对象给 Writer对象引用或者 Reader对象引用,从而构造 BufferedWriter对象和 BufferedReader对象

基本使用与字节缓冲流基本一致,不再演示

常用方法与基本流一致,下面只关注BufferedWriterBufferedReader的特有方法

  1. BufferedWriter中的特有方法:void newLine(),作用:换行效果
  2. BufferedReader中的特有方法:String readLine(),作用:一次读取一行数据,如果读到内容结尾则返回null

基本使用如下:

public class Test02 {public static void main(String[] args) throws IOException {BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter("./b.txt"));bufferedWriter.write(99);bufferedWriter.newLine();bufferedWriter.write(100);bufferedWriter.flush();BufferedReader bufferedReader = new BufferedReader(new FileReader("./b.txt"));String s = bufferedReader.readLine();System.out.println(s);String s1 = bufferedReader.readLine();System.out.println(s1);}
}

缓冲流读取数据原理

缓冲流之所以比基本流读取快,本质原因就是缓冲流在内存中开辟的缓冲区。

在从硬盘读取数据过程中,先使用基本流读取数据,再将数据交给缓冲流读入到缓冲流对应的缓冲区,因为缓冲区大小为8192字节,所以每一次缓冲流从基本流读取数据到缓冲区直到读取到8192字节才会停止。

在从内存写数据到硬盘过程中,因为输入缓冲区当前已经读取到了8192个字节的数据,就需要一个载体将输入缓冲区中的数据输送到输出缓冲区,同样输出缓冲区也是8192个字节的大小,在没有调用flush方法(或close方法)情况下,除非输出缓冲区满了,内容会由输出缓冲流传输到基本流,再由基本流输出到硬盘中,否则内容会一直留在输出缓冲区

整个过程如下图:

字符编码

计算机中储存的信息都是用二进制数表示的,而我们在屏幕上看到的数字、英文、标点符号、汉字等字符是二进制数转换之后的结果。[按照某种规则,将字符存储到计算机中,称为编码] 。反之,将存储在计算机中的二进制数按照某种规则解析显示出来,称为解码 。比如说,按照A规则存储,同样按照A规则解析,那么就能显示正确的文本f符号。反之,按照A规则存储,再按照B规则解析,就会导致乱码现象。

字符编码Character Encoding : 一套自然语言的字符与二进制数之间的对应规则。

字符集

字符集 Charset:也叫编码表。是一个系统支持的所有字符的集合,包括各国家文字、标点符号、图形符号、数字等。

计算机要准确的存储和识别各种字符集符号,需要进行字符编码,一套字符集必然至少有一套字符编码。常见字符集有ASCII字符集、GBK字符集、Unicode字符集等。

可见,当指定了编码,它所对应的字符集自然就指定了,所以编码才是我们最终要关心的。

  • ASCII字符集
    • ASCII(American Standard Code for Information Interchange,美国信息交换标准代码)是基于拉丁字母的一套电脑编码系统,用于显示现代英语,主要包括控制字符(回车键、退格、换行键等)和可显示字符(英文大小写字符、阿拉伯数字和西文符号)。
    • 基本的ASCII字符集,使用7位(bits)表示一个字符,共128字符。ASCII的扩展字符集使用8位(bits)表示一个字符,共256字符,方便支持欧洲常用字符。
  • ISO-8859-1字符集
    • 拉丁码表,别名Latin-1,用于显示欧洲使用的语言,包括荷兰、丹麦、德语、意大利语、西班牙语等。
    • ISO-8859-1使用单字节编码,兼容ASCII编码。
  • GBxxx字符集
    • GB就是国标的意思,是为了显示中文而设计的一套字符集。
    • GB2312:简体中文码表。一个小于127的字符的意义与原来相同。但两个大于127的字符连在一起时,就表示一个汉字,这样大约可以组合了包含7000多个简体汉字,此外数学符号、罗马希腊的字母、日文的假名们都编进去了,连在ASCII里本来就有的数字、标点、字母都统统重新编了两个字节长的编码,这就是常说的"全角"字符,而原来在127号以下的那些就叫"半角"字符了。
    • GBK:最常用的中文码表。是在GB2312标准基础上的扩展规范,使用了双字节编码方案,共收录了21003个汉字,完全兼容GB2312标准,同时支持繁体汉字以及日韩汉字等。
    • GB18030:最新的中文码表。收录汉字70244个,采用多字节编码,每个字可以由1个、2个或4个字节组成。支持中国国内少数民族的文字,同时支持繁体汉字以及日韩汉字等。
  • Unicode字符集
    • Unicode编码系统为表达任意语言的任意字符而设计,是业界的一种标准,也称为统一码、标准万国码。
    • 它最多使用4个字节的数字来表达每个字母、符号,或者文字。有三种编码方案,UTF-8、UTF-16和UTF-32。最为常用的UTF-8编码。
    • UTF-8编码,可以用来表示Unicode标准中任何字符,它是电子邮件、网页及其他存储或传送文字的应用中,优先采用的编码。互联网工程工作小组(IETF)要求所有互联网协议都必须支持UTF-8编码。所以,我们开发Web应用,也要使用UTF-8编码。它使用一至四个字节为每个字符编码,编码规则:
      1. 128个US-ASCII字符,只需一个字节编码。
      2. 拉丁文等字符,需要二个字节编码。
      3. 大部分常用字(含中文),使用三个字节编码。
      4. 其他极少使用的Unicode辅助字符,使用四字节编码。

转换流

转换流主要解决的问题是:读取文本文件和写入文本文件两个过程中的字符编码不同,因为尽管是字符流读取字符,也只能保证代码文件的编码和文本文件编码一致情况下的读取正常,为了更广泛性得保证读取文本文件编码正常,就可以使用转换流

转换流有两类:

  1. 输入转换流:对应InputStreamReader
  2. 输出转换流:对应OutputStreamWriter

对应的构造方法如下:

  1. InputStreamReader(InputStream in, String charsetName):通过InputStream对象构造,第二个参数代表读取内容时解码采用的字符集
  2. OutputStreamWriter(OutputStream out, String charsetName):通过OutputStream对象构造,第二个参数代表写入内容时采用的字符集

常用方法与字符流一致

基本使用如下:

public class Test {public static void main(String[] args) throws IOException {OutputStreamWriter outputStreamWriter = new OutputStreamWriter(new FileOutputStream("./a.txt"), "utf-8");outputStreamWriter.write("你好");outputStreamWriter.flush();InputStreamReader inputStreamReader = new InputStreamReader(new FileInputStream("./a.txt"), "utf-8");char[] chars = new char[2];int len = 0;while ((len = inputStreamReader.read(chars)) != -1) {System.out.println(new String(chars, 0, len));}inputStreamReader.close();outputStreamWriter.close();}
}

序列化流与反序列化流

在Java中,如果需要将对象的属性输出到文件中并且再读取到内存中就需要用到序列化流和反序列化流

序列化流对应的类为ObjectOutputStream,反序列化流对应的类为ObjectInputStream

需要注意,序列化流和反序列化流写入到文件中的数据并不是让人可以看懂的,所以出现奇怪的字符都是正常的

基本使用

序列化流主要作用是向硬盘写对象,构造方法:ObjectOutputStream(OutputStream out),常用方法:void writeObject(Object obj)

反序列化流主要作用是从硬盘读对象,构造方法:ObjectInputStream(InputStream in),常用方法:Object readObject(),返回读取到的对象

需要注意,要写入类对象属性,需要确保对象对应的类实现了Serializable接口,否则会抛出NotSerializableException异常

// 自定义类
public class Person implements Serializable {private String name;private int age;public Person() {}public Person(String name, int age) {this.name = name;this.age = age;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}@Overridepublic String toString() {return "Person{" +"name='" + name + '\'' +", age=" + age +'}';}
}// 测试
public class Test {public static void main(String[] args) throws Exception {ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("b.txt"));// 写入一个ArrayList<Person>ArrayList<Person> people = new ArrayList<>();people.add(new Person("张三", 23));people.add(new Person("李四", 24));people.add(new Person("王五", 25));// 写入people列表objectOutputStream.writeObject(people);objectOutputStream.flush();// 读取people列表ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("./b.txt"));Object o = objectInputStream.readObject();for (Person person : (ArrayList<Person>) o) {System.out.println(person);}}
}输出结果:
Person{name='张三', age=23}
Person{name='李四', age=24}
Person{name='王五', age=25}

禁止成员被序列化

如果不想指定的成员被序列化,可以使用transient关键字修饰对应成员,例如Person类中的age成员修饰为transient

// 自定义类
public class Person implements Serializable {private String name;private transient int age;// ...
}// 测试
public class Test {public static void main(String[] args) throws Exception {ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("b.txt"));// 写入一个ArrayList<Person>ArrayList<Person> people = new ArrayList<>();people.add(new Person("张三", 23));people.add(new Person("李四", 24));people.add(new Person("王五", 25));// 写入people列表objectOutputStream.writeObject(people);objectOutputStream.flush();// 读取people列表ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("./b.txt"));Object o = objectInputStream.readObject();for (Person person : (ArrayList<Person>) o) {System.out.println(person);}}
}输出结果:
Person{name='张三', age=0}
Person{name='李四', age=0}
Person{name='王五', age=0}

序列号不匹配异常

序列号不匹配异常一般出现于向硬盘写入对象属性值时创建的序列号与从硬盘读取对象数值时的序列号不同,而造成这种不同的原因一般是写入对象后修改了源码

如果不想出现上面的异常,可以在对象对应的类中创建成员:

public static final long serialVersionUID = 指定具体值;
需要注意,这个成员代表序列号,必须是 long类型,且被 finalstatic修饰

打印流

基本使用

打印流表示向某一个文件输出内容

打印流对应类为PrintStream类,构造方法:PrintStream(String fileName)

常用方法有:

  1. println(...):向文件中输出参数内容,并且自带换行
  2. print(...):向文件中输出参数内容,不换行

基本使用如下:

public class Test {public static void main(String[] args)throws Exception{PrintStream ps = new PrintStream("./a.txt");ps.println("1");ps.println("2");ps.close();}
}

系统打印流与改变流向

前面经常使用System.out.println()输出数据,实际上就是在使用打印流,只是这个out成员是System类中的静态PrintStream类成员,此时调用println方法,默认向控制台打印数据

在实际开放中,程序在运行过程中,控制台的内容会被每一次新打印语句覆盖,导致内容不具有持久性,所以需要改变内容流向,使其不打印在控制台,而打印到文件中

当需要改变流向,可以使用System类中的静态方法:static void setOut(PrintStream out),该方法是静态方法,所以可以被直接调用

基本使用如下:

public class Test01 {public static void main(String[] args) throws Exception{System.setOut(new PrintStream("./b.txt"));System.out.println("这是一个日志文件");System.out.println("现在是"+ new Date());}
}文件内容:
这是一个日志文件
现在是Sun Sep 22 21:15:47 CST 2024

Properties集合结合IO流

前面介绍Properties集合时介绍到一个方法:void load(InputStream inStream),该方法和结合InputStream对象使用

因为Properties集合一般存储的是配置文件信息,所以可以考虑从文件中读取配置信息,原因是:将来不能将很多的硬数据放到源码中,比如用户名和密码这些数据,因为之后有可能换用户名或者密码,如果一换,我们就需要去源码中修改,而因为类和类之间都有联系,有可能牵一发动全身,所以需要将这些数据提取出来,放到文件中,改的时候直接去文件中改,源码不需要改动

配置文件xxx.properties创建方式:

  1. 在需要创建配置文件的父文件夹右键 -> File -> 取名为xxx.properties
  2. xxx.properties文件中写配置数据
    1. keyvalue都是key=value形式
    2. keyvalue都是String的,但是不要加双引号
    3. 每个键值对写完之后,需要换行再写下一对
    4. 键值对之间最好不要有空格(空格可以有,但是不建议写)
    5. 键值对中建议不要使用中文(中文可以有,但是直接读取会乱码,需要转换流转码)

基本使用如下:

public class Test {public static void main(String[] args)throws Exception {Properties properties = new Properties();FileInputStream fis = new FileInputStream("jdbc.properties");properties.load(fis);Set<String> set = properties.stringPropertyNames();for (String key : set) {System.out.println(key+"..."+properties.getProperty(key));}}
}

Commons-io工具包

介绍与引入工具包

Commons-io解决的问题:IO技术开发中,代码量很大,而且代码的重复率较高。如果我们要遍历目录,拷贝目录就需要使用方法的递归调用,也增大了程序的复杂度。

Apache软件基金会,开发了IO技术的工具类commons-IO,大大简化IO开发。

Commons-io工具包是第三方包,所以使用前需要导入包,但是这个包是jar包,需要先解压,下面是IDEA下的引入和解压方式:

  1. 在指定位置创建文件夹,取名为lib或者libs
  2. 将准备好的jar包,放到此文件夹下
  3. 对着jar包,右键 -> Add as library (如果想将lib下所有的jar包一起解压,我们就直接对着lib文件夹右键)
  4. level可以选择module,此时上面name位置会变成空,可以不用考虑
  5. 直接点OK
上面引包的方式后面会被Maven项目管理工具替代,具体见后面Maven工具使用介绍

使用工具包的静态方法

IOUtils工具类

IOUtils工具类是Commons-io工具包下的关于IO的一个类,里面提供了一些文件操作的方法:

  1. IOUtils.copy(InputStream in, OutputStream out):拷贝文件内容到另一个文件中
  2. IOUtils.closeQuietly(任意流对象):作用同close方法,但是不需要额外处理异常

基本使用如下:

public class Test {public static void main(String[] args) /*throws Exception*/{//- 静态方法:IOUtils.copy(InputStream in,OutputStream out)IOUtils.copy(new FileInputStream("./1.jpg"),new FileOutputStream("./1-copy.jpg"));//- 静态方法:IOUtils.closeQuietly(任意流对象)FileWriter fw = null;try{fw = new FileWriter("module22\\commons.txt");fw.write("你好");}catch (Exception e){e.printStackTrace();}finally {if (fw!=null){IOUtils.closeQuietly(fw);}}}
}
FileUtils工具类

常用方法如下:

  1. FileUtils.copyDirectoryToDirectory(File src, File dest):将src下的文件夹拷贝到dest下的文件夹中,整个过程中不需要对src内部的文件夹进行显式递归遍历
  2. writeStringToFile(File file, String str):向文件中写入str字符串内容
  3. String readFileToString(File file):读取文件中所有的内容

基本使用如下:

public class Test01 {public static void main(String[] args)throws Exception {// FileUtils.copyDirectoryToDirectory(File src, File dest)FileUtils.copyDirectoryToDirectory(new File("./test"), new File("./test1"));//- 静态方法:writeStringToFile(File file,String str)写字符串到文本文件中。FileUtils.writeStringToFile(new File("./a.txt"),"haha");//- 静态方法:String readFileToString(File file)读取文本文件,返回字符串。String s = FileUtils.readFileToString(new File("./a.txt"));System.out.println(s);}
}

整章结构

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【Windows】快速帮你解决如何找到 Windows 上的 .condarc 文件

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 专栏介绍 在软件开发和日常使用中&#xff0c;BUG是不可避免的。本专栏致力于为广大开发者和技术爱好者提供一个关于BUG解决的经…

【VLM小白指北 (1) 】An Introduction to Vision-Language Modeling

开一个新坑Vision-Language Modeling (VLM) &#xff0c;原文76页&#xff0c;慢慢更&#xff0c;for beginners&#xff0c;但也不能之前啥都不会啊。 原文链接&#xff1a;An Introduction to Vision-Language Modeling Introduction 存在的问题&#xff1a;将语言与视觉相…

算法-K个一组翻转链表

// 要实现没k个节点进行翻转的操作&#xff0c;可以按照一下步骤进行 // 1.计算链表长度 // 2.分组反转 // 3. 使用一个虚拟头节点来处理边界情况 // 4.每次处理k个节点进行反转 // 5.如果剩余节点不足k个 则保持原有顺序 // 6.依次反转每组中的节点 // 1.使用prevGroupEEnd追…

【测试】——JUnit

&#x1f4d6; 前言&#xff1a;JUnit 是一个流行的 Java 测试框架&#xff0c;主要用于编写和运行单元测试&#xff0c;用来管理测试用例。本文采用JUnit 5 目录 &#x1f552; 1. 添加依赖&#x1f552; 2. 注解&#x1f558; 2.1 Test&#x1f558; 2.2 BeforeAll AfterAll&…

OceanBase 3.X 高可用 (一)

OceanBase 3.X 高可用&#xff08;一&#xff09; 一、分布式核心 OceanBase 3.x 采用的是paxos 协议&#xff0c;与raft协议相比。其复杂程度高&#xff0c;实现技术难度大。 Paxos 协议允许事务日志乱序发送&#xff0c;顺序提交。raft允许事务顺序发送&#xff0c;顺序提…

Windows Internals 7th Edition English Download

天翼云盘 珍藏美好生活 家庭云|网盘|文件备份|资源分享天翼云盘是中国电信推出的云存储服务&#xff0c;为用户提供跨平台的文件存储、备份、同步及分享服务&#xff0c;是国内领先的免费网盘&#xff0c;安全、可靠、稳定、快速。天翼云盘为用户守护数据资产。https://cloud.1…

高并发内存池(四):查缺补漏 与 申请内存过程的调试

目录 查缺补漏 问题&#xff1a;min函数的冲突问题 申请内存过程的调试 当前文件展示 Common.h ObjectPool.h ConcurrentAlloc.h ThreadCache.h CentralCache.h PageCache.h ThreadCache.cpp CentralCache.cpp PageCache.cpp UnitTest.cpp 单进程单span 单进程…

谷歌收录批量查询,怎么查看批量查询谷歌收录情况

在SEO&#xff08;搜索引擎优化&#xff09;领域&#xff0c;确保网站内容被谷歌等搜索引擎有效收录是提升网站可见性和流量的关键步骤。批量查询谷歌收录情况&#xff0c;能够帮助网站管理员快速了解哪些页面已被搜索引擎识别并编入索引&#xff0c;哪些页面可能存在问题需要优…

【python】石头剪刀布,模拟十次并统计获胜次数

解决问题 下面是一个使用Python编写的剪刀、石头、布游戏的程序&#xff0c;包含玩家与计算机对战和模拟计算机对战10次的功能。 import random def get_computer_choice(): return random.randint(0, 2) def get_user_choice(): choice input("请输入剪刀(0)…

Spring高手之路24——事务类型及传播行为实战指南

文章目录 1. 编程式事务&#xff08;不推荐&#xff09;2. 声明式事务&#xff08;推荐&#xff09;3. 事务的传播行为&#xff08;复杂混合事务场景及时序图说明&#xff09;3.1 NESTED和REQUIRES_NEW传播行为的区别 1. 编程式事务&#xff08;不推荐&#xff09; 定义&#…

MAC激活Typora以及禁止成功激活弹窗的方法

激活 Typora 首先在官网下载 Typora 的最新版 并且安装。 打开以下目录 /Applications/Typora.app/Contents/Resources/TypeMark/page-dist/static/js/ 注意在 Applications 中&#xff0c;需要对 Typora 右键选择 Show Packages Contents 即可进入 Typora.app。 在该目录的文…

C++自动驾驶面试核心问题整理

应用开发 概述&#xff1a;比较基础&#xff0c;没啥壁垒&#xff0c;主要有linux开发经验即可 问题&#xff1a;基础八股&#xff0c;如计算机网络、操作系统、c11等基础三件套&#xff1b;中等难度算法题1-2道。 中间件开发&#xff08;性能优化&#xff09; 概述&am…

快递物流查询-快递查询-快递单号查询-快递物流单号查询-快递物流轨迹查询-快递物流查询接口

快递物流查询接口&#xff08;API&#xff09;是一种允许开发者通过编程方式实时查询快递物流信息的服务。这些接口通常集成了多家快递公司的物流数据&#xff0c;为电商平台、物流管理系统、个人用户等提供便捷的物流查询服务。以下是关于快递物流查询接口的一些详细介绍&…

哪有什么三教九流,物以类聚罢了——kmeans聚类算法

观察人类社会&#xff0c;亦或说车水马龙中的光怪陆离&#xff0c;不难发现《马原》中介绍的人类社会中的个体&#xff0c;总是通过某种方面的“类似”聚在一起&#xff0c;文学上称这种现象叫做物以类聚&#xff0c;人以群分。 一.引言 前文提到&#xff0c;每个数据项&#x…

SpringBoot项目License证书生成与验证(TrueLicense) 【记录】

SpringBoot项目License证书生成与验证(TrueLicense) 【记录】 在非开源产品、商业软件、收费软件等系统的使用上&#xff0c;需要考虑系统的使用版权问题&#xff0c;不能随便一个人拿去在任何环境都能用。应用部署一般分为两种情况&#xff1a; 应用部署在开发者自己的云服务…

Qt笔记(十七)cmake编译Qt项目

Qt笔记&#xff08;十七&#xff09;cmake编译Qt项目 1. 文件内容与文件结构1.1.文件目录1.2. CMakeLists.txt内容1.3. main.cpp文件1.4. mouseevent.h1.5. mouseevent.cpp1.6. 生成Visual Studio项目后编译报错1.7. 界面显示中文乱码问题 1. 文件内容与文件结构 1.1.文件目录…

jdk11特性介绍

JDK 11&#xff08;也称为Java 11&#xff09;是Java平台的一个重要版本&#xff0c;它引入了许多新特性和改进&#xff0c;旨在提高开发者的生产力和Java平台的性能。以下是一些JDK 11的主要特性&#xff1a; 局部变量类型推断&#xff08;Local-Variable Syntax for Lambda P…

2009考研数学真题解析-数二:

第一题&#xff1a; 解析&#xff1a;先找间断点&#xff1a;分母不能等于0&#xff0c;分母是sinΠx&#xff0c; 因此不难看出间断点是x0&#xff0c;-1&#xff0c;-2&#xff0c;-3。。。。。 接着一个一个来算这些点是什么间断点。 &#xff0c;从x趋于2开始&#xff0c;分…

JavaScript是如何来的~~

文章目录 前言一、网络的诞生 ( The birth of the Web )二、Mosaic 浏览器三、Netscape 浏览器四、JavaScript的诞生 ~ 千呼万唤始出来总结 前言 例如&#xff1a;想要了解一门语言的发展历程&#xff0c;首先你得知道它是怎么来的&#xff0c;所以本文开篇介绍了网络的基本发…

智能BI平台项目

1.项目介绍 BI商业智能&#xff1a;数据可视化、报表可视化系统 4&#xff09;发布订阅 Resource 是基于名称进行查找的&#xff0c;而Spring框架中更常用的 Autowired 则是基于类型进行查找的。如果找不到匹配的bean&#xff0c;Autowired 会抛出异常&#xff0c;而 Resource…