计算机系统应用教程网站

网站首页 > 技术文章 正文

阿里P7大神,Java学习之路-IO流与XML,超赞分享

btikc 2024-09-22 01:11:22 技术文章 22 ℃ 0 评论

其实在笔者学习数据库之前,数据的可视化,曾经用的是io+正则表达式+字符串处理等等类似的操作,敢信?io操作很重要的!!!

1、IO概述

IO:Input(输入:将磁盘中的文件读到内存中) | Output(将内存中的数据写入磁盘);

文件:磁盘中数据的组织单位(一堆字节数据)

流(Stream):将磁盘中的静态字节数据变成流动中的字节数据;(字节的序列形成流)

文件进行读写的操作的所有接口与类放在:java.io包中;

2、File类

探测文件|文件夹的信息,再进一步对文件|文件夹进行操作;

File :获取文件的信息 | 创建|删除|重命名|移动 ,等操作

对目录: 提供删除|创建目录以及获取目录下所有文件和文件夹等

获取指定目录下所有的资源(文件或者文件夹 -- 递归获取)

public static void getFileAndDirectory(File path) {
    try{
		File[] files = path.listFiles();
		for(File f :files) {
			if(f.isDirectory()) {
				//打印目录 信息;
				System.out.println(f.getPath());
				//再递归调用;
				getFileAndDirectory(f);
			}else {
				System.out.println(f.getPath());
			}
		 }
		}catch(Exception e){}
	}

3、IO流

A、字节流【重要】

对文件进行读写操作最底层的,字节流可以对任意格式 的文件进行操作;

public abstract class InputStream :读操作的字节流父类(抽象类)
public class FileInputStream extends InputStream ; 

InputStream
   -- FileInputStream
一次可以从流中读一个字节(read方法),如果返回-1,表示已到流的末尾(读完)
批量读取字节流数据:read(byte[] data) | read(byte[] data,int startindex,int len)

字节写入流

public abstract class OutputStream
public class FileOutputStream extends OutputStream
write(byte[] datas)
write(int data)
write(byte[] datas,int startindex,int len)

如何复制一个文件

//复制文件;
	public static void copy(String src,String dest) {
		InputStream in = null;
		OutputStream out = null;
		try {
			//1.创建一个读|写的流对象
			in = new FileInputStream(src);
			out = new FileOutputStream(dest);
			//一次读多少 ? -- 4k |8k;
			byte[] buffer =new byte[1024*4];
			int len = -1;
			while((len=in.read(buffer))!=-1) { //read方法的返回值是实际读的流长度 ;
				//将buffer中的数据写入到输出流中;
				out.write(buffer,0,len);
			}
		}catch (IOException e) {
			e.printStackTrace();
		}finally {
			//一定要先关输出流,再关输入流;
			if(out!=null) {
				try {
					out.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
			if(in!=null) {
				try {
					in.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
			
		}
	}

B、字符流[重要]

对磁盘文本文件的读写,用字节流可以实现,但不太方便;SUN设计专业的一组流(字符流),对文本格式的文件进行读写操作,相对字节流,要方便一些;为了提供效率,再用上SUN设计的缓冲流

通过字符流读 文本格式文件 (不能通过字符流来读图片文件,声音文件,视频文件等)

public abstract class Reader
public class FileReader extends InputStreamReader extends Reader


read()
read(char[] data) | read(char[] data,int index,int len)
public abstract class Writer
public class FileWriter extends OutputStreamWriter extends Writer

write(int c) | writer(String str)
writer(char[] chars) | writer(char[] chars,int index,int len)

C、字符缓冲流[重要]

字符缓冲流只能对字符流进行缓冲 ,字符缓冲流有2个:BufferedReader , BufferedWriter

public class BufferedReader extends Reader

public class BufferedWriter extends Writer

D、标准输入流与标准备输出流[了解]

System.in : 获取键盘的数据;
System.out:输出 --- 显示器|控制台
public final class System {
	 public final static InputStream in = null; 键盘数据
	 public final static PrintStream out = null;
}

E、转换流

将字节流 变成 字符流 (单向)

public class InputStreamReader extends Reader
public class OutputStreamWriter extends Writer

F、对象流

对象流:如何将一个对象持久化(对象流的作用)

序列化:将对象转为流,用来存贮或者网络传输;

反序列化:将流中的数据转为对象

**注:**一个类创建的对象要能够被序列化,此类必须实现Serializable接口(是一个标识,没有任何设计)

public class ObjectOutputStream extends OutputStream
public class ObjectInputStream extends InputStream
transient :如果某一属性不需要被持化,添加此标识即可
private transient String nick;

G、数据流

数据流:将基本数据类型的数据及字符串持久化;

public class DataInputStream extends FilterInputStream extends InputStream
public class DataOutputStream extends FilterOutoputStream extends OutputStream

4、XML[重要]

XML:Extensible Markup Language (可扩展的标签语言),xml是一个纯文本格式的文件,相对文本文件,文档的内容一般用标签包裹(解析方便); XML在项目主要用来存放配制信息(每一个项目都有配制文件(xml文件))

XML文档作用 :存贮数据 (项目配制信息)

XML文档编写规范:

  • 第1行为文档声明(写法固定,一般不需手写,开发工具自动生成)
  • xml有且只一个根元素(节点)
  • 标签(元素)需要用一对尖括号包裹起来; 标签一般是成对出现的,起始标签与结束标签只差“/"
  • xml区分大小写的(一般用小写)
  • 元素可以有属性,多个属性需要用空格分开,属性值需要用双引号括起来(属性需要放到起始标签中)

XML文档一般3 三种写法

<?xml version="1.0" encoding="UTF-8"?>
<users>
 	<user>
		<name>张二</name>
		<job>C程序员</job>
		<nick>高级程序员</nick>
		<email>zhanger@qq.com</email>
	</user>
</users>
<?xml version="1.0" encoding="UTF-8"?>
<users>
	<user name="张一" job="菜鸟" nick="初级程序员" email="zhang@qq.com"  />
	<user name="张二" job="老鸟" nick="高级程序员" email="zhanger@qq.com"/>
</users>
<?xml version="1.0" encoding="UTF-8"?>
<users>
	<user id="1">
		<name>张一</name>
		<job>程序员</job>
		<nick>高级</nick>
		<email>zhang@qq.com</email>
	</user>
</users>

解析XML:在JDK中SUN设计了一组类与接口,用来解析XML文档(书中);SUN设计的解析XML的组件用起来不太方便,所以在实际应用,一般彩第三方解析组件(jar) ---- DOM4J

DOM4J核心组件 (org.dom4j | org.dom4j.io)
SAXReader : 读取器
Document:XML文档类
Element : XML元素
XMLWriter :写入数据类
OutputFormat:格式化类
DocumentHelper:Document助手类

默认,没添加任意约束的XML文档的编写是随意的(标签名任意,标签包含的标签设计也是随意的),这样带来的最大缺点:不好解析(不能写一段程序来解析任意结构的XML文件),文档结构混乱的,所以就需要一个结构确定的XML文件 ----- 给当前XML设计文档结构**(约束)** ------ 目前,文档结构的设计可以有2种方式

DTD:(Document Type Definition) 是一套定义语法规范; DTD可以写在文档内部(内部DTD),也可以写在文档外部(外部DTD),对外部DTD,只要在当前文档中引入进来即可

引入的语法:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE users SYSTEM "txl.dtd" >
SYSTEM:表示私有 DTD ,当前DTD只服务于本项目(某一个XML文档)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
	PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
	"http://mybatis.org/dtd/mybatis-3-config.dtd">
PUBLIC :表示公开的(所有项目都可以引入此约束),公开的DTD一般在框架中使用

了解DTD的语法(如何写一个DTD)

<!ELEMENT users (user*)> :ELEMENT元素设置 (根元素为users,根元素子元素名称为user,数量0个或多个)
<!ELEMENT user(name,job?,email*) :user元素有3个子元素,name元素必须有,job 0个或者1个,email0个或者多个
<!ELEMENT name (#PCDATA)> name元素的类型  #PCDATA:表示字符类型
<!ELEMENT job (#PCDATA)> 
<!ELEMENT email (#PCDATA)> 

XML Schema :

XML架构 ,相对DTD,Schema提供的设计更复杂,更全面. Schema约束本身也是一个xml文件(xsd)

<schema xmlns="http://www.w3.org/2001/XMLSchema"
	targetNamespace="http://localhost/txl"
	xmlns:tns="http://www.example.org/txl" elementFormDefault="qualified">
</schema>
xmlns="http://www.w3.org/2001/XMLSchema" : 设置本文件元素类型来自的名称空间(值不能修改)
targetNamespace="http://www.example.org/txl" :为引入此schema的xml文件服务的
elementFormDefault="qualified" :设置元素默认是否还名称空间
element :定义元素
complexType:定义复合元素|复杂元素
sequence:元素顺序出现
minOccurs="0"  :最小下线
maxOccurs="unbounded" :最大上线
......
<users 
	xmlns="http://localhost/txl"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://localhost/txl txl.xsd ">
</users>
xmlns="http://localhost/txl"  值与targetNamespace的值一致
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" :告诉xml解析器,本xml使用一个xmlschema实例
xsi:schemaLocation="http://localhost/txl txl.xsd " :schema地址

5、分层开发[重要]

正常项目中的类不会放到一个包中,主要管理不方便,所以在实际项目中,类总是基于功能分包管理 --- 分层设计思想(分3层)

表示层:展示数据(窗体|网页|控制台)

业务逻辑层:业务逻辑的判断(登录) ; 如果业务层没有业务的处理,业务层只是起到数据传递的作用(接力棒)

数据层:和文件或者数据库交互的(完成数据持久化或者从文件和数据库中读取数据)

在JAVA的项目设计中,分层是通过分包体现出来;

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表