花几千上万学习Java,真没必要!(三十八)
测试代码1:
package iotest.com;
import java.nio.charset.StandardCharsets;
import java.io.UnsupportedEncodingException; public class StringByteConversion { public static void main(String[] args) throws UnsupportedEncodingException { // 原始字符串 String originalString = "Hello, 世界!"; byte[] defaultBytes = originalString.getBytes(); String defaultDecodedString = new String(defaultBytes); System.out.println("默认字符集编码后解码: " + defaultDecodedString); // 使用指定的字符集(UTF-8)编码字符串 byte[] utf8Bytes = originalString.getBytes(StandardCharsets.UTF_8.name()); String utf8DecodedString = new String(utf8Bytes, StandardCharsets.UTF_8.name()); System.out.println("UTF-8编码后解码: " + utf8DecodedString); // 尝试使用ISO-8859-1(不支持中文)编码和解码字符串,以展示可能的乱码 try { byte[] isoBytes = originalString.getBytes("ISO-8859-1"); String isoDecodedString = new String(isoBytes, "ISO-8859-1"); System.out.println("ISO-8859-1编码后解码(可能导致乱码): " + isoDecodedString); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } }
}
运行结果如下:
测试代码2:
package iotest.com;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter; public class StreamMergerExample { public static void main(String[] args) { try { // 创建一个ByteArrayOutputStream捕获写入的字节 ByteArrayOutputStream byteStream = new ByteArrayOutputStream(); // 使用UTF-8字符编码创建OutputStreamWriter OutputStreamWriter writer = new OutputStreamWriter(byteStream, "UTF-8"); // 写入文本 writer.write("Hello, 世界!"); // 刷新OutputStreamWriter,确保所有内容都被写入到底层ByteArrayOutputStream writer.flush(); // 关闭OutputStreamWriter// writer.close(); // 如果不打算重用byteStream,可以调用close() // 读取需要将其转换为ByteArrayInputStream InputStream inputStream = new ByteArrayInputStream(byteStream.toByteArray()); // 使用UTF-8字符编码(与写入时相同)创建InputStreamReader InputStreamReader reader = new InputStreamReader(inputStream, "UTF-8"); // 可以用BufferedReader读取 int c; while ((c = reader.read()) != -1) { // 打印int的字符表示 if (c >= 0 && c <= 0xFFFF) { // 有效性检查(Java中的char是16位的) System.out.print((char) c); } } //如果使用的是包装流的类(如BufferedReader),则应该关闭。 System.out.println("\n读取完成。"); } catch (IOException e) { e.printStackTrace(); } }
}
运行结果如下:
测试代码3:
package iotest.com;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
public class WriterExample {public static void main(String[] args) {try {// 创建一个BufferedWriter对象写入文件BufferedWriter writer = new BufferedWriter(new FileWriter("output.txt"));// 写一个字符writer.write('A');// 写入一个字符数组char[] charArray = {'B', 'C', 'D'};writer.write(charArray);// 写入字符数组的一部分writer.write(charArray, 1, 2);// 刷新流writer.flush();// 关闭流writer.close();} catch (IOException e) {e.printStackTrace();}}
}
测试代码4:
package iotest.com;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter; public class FileReadWriteUTF8Example { public static void main(String[] args) { // 指定文件路径 String filePath = "E:\\Test\\a.txt"; // 写入文件,使用UTF-8编码 try (BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath), "UTF-8"))) { String content = "这是一段测试文本,使用UTF-8编码写入。默认使用平台的默认字符编码。如果需要在不同平台间共享文件,或者文件包含特殊字符(如中文),使用显式的字符编码,如UTF-8。"; writer.write(content); System.out.println("写入成功。"); } catch (IOException e) { e.printStackTrace(); } // 读取文件,使用UTF-8编码,并打印到控制台 try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(filePath), "UTF-8"))) { String line; while ((line = reader.readLine()) != null) { System.out.println(line); } } catch (IOException e) { e.printStackTrace(); } }
}
运行结果如下:
测试代码5:
package iotest.com;
import java.io.FileReader;
import java.io.IOException;
public class FileReaderTest { public static void main(String[] args) { try { // 创建一个FileReader对象读取文件 FileReader reader = new FileReader("E:\\Test\\a.txt"); // 使用read方法一次读取一个字符数据 int charData; while ((charData = reader.read()) != -1) { System.out.print((char) charData); // 打印读取的字符 } System.out.println(); //方法换行 // 使用read一次读取一个字符数组数据 char[] charArray = new char[3]; int numCharsRead; //使用read方法逐个读取字符并打印出来,直到文件末尾(-1)。while ((numCharsRead = reader.read(charArray)) != -1) { // 只打印实际读取的字符数 for (int i = 0; i < numCharsRead; i++) { System.out.print(charArray[i]); } } // 关闭流 reader.close(); } catch (IOException e) { e.printStackTrace(); } }
}
测试代码6:Copy文本。
package iotest.com;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException; //readLine()方法读取一行文本。//它读取字符直到遇到换行符(\n)、回车符(\r)、回车后紧跟换行符(\r\n)或到达文件末尾。//返回包含该行内容的字符串,但不包括任何行终止符。//如果已到达流的末尾且没有更多的行可供读取,则返回null。//readLine()为按行读取文本文件内容的理想选择。
public class FileCopyTest { public static void main(String[] args) { String sourceFile = "E:\\Test\\a.txt"; String destFile = "D:\\AA\\destination.txt"; BufferedReader br = null; BufferedWriter bw = null; try { br = new BufferedReader(new FileReader(sourceFile)); bw = new BufferedWriter(new FileWriter(destFile)); String line; //readLine()按行读取源文件的内容while ((line = br.readLine()) != null) { bw.write(line); bw.newLine(); // 写入行分隔符 } System.out.println("文件复制成功!"); } catch (IOException e) { e.printStackTrace(); System.out.println("文件复制失败!"); } finally { try { if (br != null) { br.close(); } if (bw != null) { bw.close(); } } catch (IOException e) { e.printStackTrace(); } } }
}
测试代码7:字符缓冲流复制文件
package iotest.com;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class FileCopyExample { public static void main(String[] args) { String sourceFile = "D:\\AA\\a.txt"; String destFile = "E:\\Test\\a.txt"; // 确保目标目录存在FileReader fileReader = null; FileWriter fileWriter = null; try { fileReader = new FileReader(sourceFile); fileWriter = new FileWriter(destFile); char[] buffer = new char[1024]; // 使用一个缓冲区存储读取的字符 int numCharsRead; // 循环读取文件直到到达末尾 while ((numCharsRead = fileReader.read(buffer)) != -1) { // 写入实际读取的字符数到目标文件 fileWriter.write(buffer, 0, numCharsRead); } System.out.println("文件复制成功!"); } catch (IOException e) { e.printStackTrace(); System.out.println("文件复制失败!"); } finally { // 关闭资源 try { if (fileReader != null) { fileReader.close(); } if (fileWriter != null) { fileWriter.close(); } } catch (IOException e) { e.printStackTrace(); } } }
}
相关文章:
花几千上万学习Java,真没必要!(三十八)
测试代码1: package iotest.com; import java.nio.charset.StandardCharsets; import java.io.UnsupportedEncodingException; public class StringByteConversion { public static void main(String[] args) throws UnsupportedEncodingException { // 原始字…...
Zilliz 2025届校园招聘正式启动,寻找向量数据库内核开发工程师
为了解决非结构化数据处理问题,我们构建了向量数据库-Milvus! Milvus 数据库不仅是顶级开源基金会 LF AI&Data 的毕业项目,还曾登上数据库顶会SIGMOD、VLDB,在全球首届向量检索比赛中夺冠。目前,Milvus 项目已获得超过 2.8w s…...
TwinCAT3 新建项目教程
文章目录 打开TwinCAT 新建项目(通过TcXaeShell) 新建项目(通过VS 2019)...
大模型算法面试题(十九)
本系列收纳各种大模型面试题及答案。 1、SFT(有监督微调)、RM(奖励模型)、PPO(强化学习)的数据集格式? SFT(有监督微调)、RM(奖励模型)、PPO&…...
应用地址信息获取新技巧:Xinstall来助力
在移动互联网时代,应用获取用户地址信息的需求越来越普遍。无论是为了提供个性化服务,还是进行精准营销,地址信息都扮演着至关重要的角色。然而,如何合规、准确地获取这一信息,却是许多开发者面临的挑战。今天…...
图的最短路径算法:Dijkstra、Floyd-Warshall、Bellman-Ford
本文意在探讨图中最短路径算法 Dijkstra、Floyd-Warshall、Bellman-Ford 的对比和细节 整体分为如下四部分 总结性的比较了 Dijkstra、Floyd-Warshall、Bellman-FordDijkstra 算法介绍Floyd-Warshall 算法介绍Bellman-Ford 算法介绍 其中1、2、3 算法介绍部分会比较简洁&…...
Camera的pipline(TODO)
(TODO)...
非关系数据库-非关系数据库入门指南
非关系数据库入门指南 1. 引言:非关系数据库的兴起 在互联网技术飞速发展的今天,传统的关系型数据库面对海量数据和高并发访问时逐渐显得力不从心。于是,非关系数据库(NoSQL,Not Only SQL)应运而生&…...
看门狗IWDG、WWDG(速记版)
内置的看门狗有 独立看门狗 IWDG 和 窗口看门狗 WWDG 都用来在程序卡死的时候复位程序。 独立看门狗只有一个最晚时间界限。窗口看门狗有一个最早界限和最晚界限。独立看门狗有独立的时钟,一般设置来源时钟LSI40KHz。窗口看门狗挂靠在APB1总线上36MHz。 IWDG IWDG处于VDD供…...
ETL工程师角度下的SQL优化
作为ETL(Extract, Transform, Load)工程师,SQL优化是提高数据处理和分析效率的关键一环。优化SQL查询可以显著降低数据处理时间,提高ETL过程的性能。本文将从 合理设计数据模型:在ETL过程中,正确的数据模型…...
阿里云实时计算Flink在多行业的应用和实践
摘要:本文整理自 Flink Forward Asia 2023 中闭门会的分享。主要分享实时计算在各行业的应用实践,对回归实时计算的重点场景进行介绍以及企业如何使用实时计算技术,并且提供一些在技术架构上的参考建议。内容分为以下四个部分: 业…...
开源项目与工具:C++中的高性能并发库 - Intel Threading Building Blocks (TBB)
在C++的世界里,随着多核处理器成为常态,如何有效利用这些多核资源以实现高性能的并发编程成为了开发者们关注的焦点。Intel Threading Building Blocks (TBB) 作为一个专为并行编程设计的C++库,凭借其易用性、高效性和可扩展性,在高性能计算、游戏开发、金融分析等多个领域…...
Chapter 22 数据可视化——折线图
欢迎大家订阅【Python从入门到精通】专栏,一起探索Python的无限可能! 文章目录 前言一、Pyecharts介绍二、安装Pyecharts三、全局配置项四、绘制折线图 前言 在大数据时代,数据可视化成为了分析和展示数据的重要手段。Pyecharts 是一个基于 …...
管理流创建schema流程源码解析
一、简析 schema是pulsar重要的功能之一,现在就一起从源码的视角看下管理流创建schema时客户端和服务端的表现 客户端 客户端主要经历以下四个步骤 创建Schema实例 根据数据类型创建相对应的实例,例如Avro创建AvroSchema、JSON创建JSONSchema等 获取…...
【iOS】iOS内存五大分区
iOS内存五大分区 总揽 iOS中,内存主要分为五大区域:栈区,堆区,全局区/静态区,常量区和代码区。总览图如下。 这个图我觉得更好记,因为下面是低地址,上面是高地址,是比较符合日常…...
【项目实战】—— 高并发内存池
文章目录 什么是高并发内存池?项目介绍一、项目背景二、项目目标三、核心组件四、关键技术五、应用场景六、项目优势 什么是高并发内存池? 高并发内存池是一种专门设计用于高并发环境下的内存管理机制。它的原型是Google的一个开源项目tcmallocÿ…...
二叉搜索树的第 k 大的节点
题目描述 给定一棵二叉搜索树,请找出其中第 k 大的节点。 解题基本知识 二叉搜索树(Binary Search Tree)又名二叉查找树、二叉排序树。它是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子…...
利用langchain 做大模型 Few-shot Learning 提示,包括固定和向量相似的动态样本筛选
文章目录 few-shotFixed Examples 固定样本Dynamic few-shot prompting 动态样本提示辅助参考资料 few-shot 相比大模型微调,在有些情况下,我们更想使用 Few-shot Learning 通过给模型喂相关样本示例,让模型能够提升相应任务的能力。 固定样…...
基于python的百度迁徙迁入、迁出数据分析(五)
终于在第五篇文章我们进入了这个系列的正题:数据分析 这里我选择上海2024年5月1日——5月5日的迁入、迁出数据作为分析的基础,首先选择节假日的数据作为分析的原因呢,主要是节假日人们出行目的比较单一(出游、探亲)&a…...
SpringBoot 如何处理跨域请求
SpringBoot 处理跨域请求,通常是通过配置全局的 CORS(跨源资源共享)策略来实现的。CORS 是一种机制,它使用额外的 HTTP 头部来告诉浏览器,让运行在一个 origin (domain) 上的 web 应用被准许访问来自不同源服务器上的指…...
大数据技术基础编程、实验和案例----大数据课程综合实验案例
一、实验目的 (1)熟悉Linux系统、MySQL、Hadoop、HBase、Hive、Sqoop、R、Eclipse等系统和软件的安装和使用; (2)了解大数据处理的基本流程; (3)熟悉数据预处理方法; (4)熟悉在不同类型数据库之…...
微信小程序-获取手机号:HttpClientErrorException: 412 Precondition Failed: [no body]
问题: 412 异常就是你的请求参数获取请求头与服务器的不符,缺少请求体! 我的问题: 我这里获取微信手机号的时候突然给我报错142,但是代码用的是原来的代码,换了一个框架就噶了! 排查问题&am…...
大数据核心概念与技术架构简介
大数据基本概念 大数据是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。 大数据特征: 数据量大:一般以P(1000个TB&a…...
快排 谁在中间
原题 Whos in the Middle FJ is surveying his herd to find the most average cow. He wants to know how much milk this median cow gives: half of the cows give as much or more than the median; half give as much or less. FJ正在调查他的牛群,以找到最…...
ORA-00911: invalid character
场景: 调用接口查询oracle的数据库数据时报错ORA-00911: invalid character,但是sql语句没有问题放在navicat控制台中运行也没有问题,但是代码中跑就会报无效字符集 分析: 代码中Oracle的语法解析器比较严格,比如句…...
Pytorch实现线性回归Linear Regression
借助 PyTorch 实现深度神经网络 - 线性回归 - 第 2 周 | Coursera 线性回归预测 用PyTorch实现线性回归模块 创建自定义模块(内含一个线性回归) 训练线性回归模型 对于线性回归,特定类型的噪声是高斯噪声 平均损失均方误差函数:…...
十八次(虚拟主机与vue项目、samba磁盘映射、nfs共享)
1、虚拟主机搭建环境准备 将原有的nginx.conf文件备份 [rootserver ~]# cp /usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.conf.bak[rootserver ~]# grep -Ev "#|^$" /usr/local/nginx/conf/nginx.conf[rootserver ~]# grep -Ev "#|^$"…...
P1340 兽径管理 题解|最小生成树
题目大意 洛谷中链接 推荐文章:并查集入门 原文 约翰农场的牛群希望能够在 N N N 个草地之间任意移动。草地的编号由 1 1 1 到 N N N。草地之间有树林隔开。牛群希望能够选择草地间的路径,使牛群能够从任一 片草地移动到任一片其它草地。 牛群可在…...
Python,Maskrcnn训练,cannot import name ‘saving‘ from ‘keras.engine‘ ,等问题集合
Python版本3.9,tensorflow2.11.0,keras2.11.0 问题一、module keras.engine has no attribute Layer Traceback (most recent call last):File "C:\Users\Administrator\Desktop\20240801\代码\test.py", line 16, in <module>from mrc…...
Linux常用工具
文章目录 tar打包命令详解unzip命令:解压zip文件vim操作详解netstat详解df命令详解ps命令详解find命令详解 tar打包命令详解 tar命令做打包操作 当 tar 命令用于打包操作时,该命令的基本格式为: tar [选项] 源文件或目录此命令常用的选项及…...
君和网站建设/优化加速
转载于:https://www.cnblogs.com/fycn01/p/5852304.html...
网站制作报价大约/阳泉seo
[转载博客](http://blog.csdn.net/pyfysf/article/details/72598518) 已经安装好了AndroidStudio,安装教程 本教程是作者自己摸索出来的,有不足之处还请大家海涵。多多拍砖,互相学习。 第一步:下载git,安装git客户端 …...
wordpress手动更新插件/百度推广的方式
我有点困惑,我无法使用MSVC在Windows上进行C开发设置Visual Studio Code . 网络上的所有人都说他们对设置和使用一切都很容易感到高兴,但我找不到任何简单的指南;他们中的大多数只是跳过设置部分,并显示一切有效,包括代码完成/智能…...
宁夏建设网站公司/免费培训机构
如果你遇到同事编写的难以阅读的代码会怎么处理?反正我是遇到过。这些代码很难维护,还会影响开发进度。而如果对相关源码了解透彻,就可以快速定位到问题。最近一直在研究MyBatis源码,作为国内经常使用的持久层框架,其内…...
ppt的网站导航栏怎么做/百度app下载官方免费下载最新版
连续一个多星期了,我始终对一个广告有疑问,至今也没听懂到底是什么意思。 早上听FM97.7,有一个广告,开头是一段相当惊心动魄的音乐,然后跳出一个男声,大喊一声:“你被了!” 然后广告…...
微网站做下载链接/成都优化官网公司
在前面一篇文章中介绍了fastfds的简单安装和文件上传功能,以及使用fastdfs自带的http下载功能等;本文中将介绍如何使用fastdfs-apache-module模块整合fastdfs和apahce;整合完毕后,客户端访问apache,apache根据配置&…...