Properties类

Properties 类表示了一个持久的属性集。Properties 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串。

特点:

1、Hashtable的子类,map集合中的方法都可以用。

2、该集合没有泛型。键值都是字符串。

3、它是一个可以持久化的属性集。键值可以存储到集合中,也可以存储到持久化的设备(硬盘、U盘、光盘)上。键值的来源也可以是持久化的设备。

4、有和流技术相结合的方法。

l  load(InputStream)  把指定流所对应的文件中的数据,读取出来,保存到Propertie集合中

l  load(Reader)

l  store(OutputStream,commonts)把集合中的数据,保存到指定的流所对应的文件中,参数commonts代表对描述信息

l  stroe(Writer,comments);

package com.oracle.Properties;

import java.util.Properties;

import java.util.Set;

public class Demo01 {

public static void main(String[] args) {

//创建集合对象

Properties pro=new Properties();

//赋值

pro.setProperty("name", "张三");

pro.setProperty("age", "123");

//System.out.println(pro.getProperty("age"));//测试

//遍历相当于map中的keyset

Set<String> set=pro.stringPropertyNames();

int num=0;

for(String key: set){

num++;

//通过键找值

System.out.println(num+"    "+key+" "+pro.getProperty(key));

}

}

}

运行结果:

1.1                将集合中内容存储到文件

package com.oracle.Properties;

import java.io.FileOutputStream;

import java.io.IOException;

import java.util.Properties;

public class Demo03 {

public static void main(String[] args) throws IOException {

//创建Properties对象

Properties pro=new Properties();

//创建字节输出流对象

FileOutputStream fos=new FileOutputStream("E:\\test\\por2.properties");

//准备数据

pro.setProperty("name","lisi");

pro.setProperty("age","123");

pro.store(fos, "李四");

}

}

运行结果:

1.2                读取文件中的数据,并保存到集合

需求:从属性集文件prop.properties 中取出数据,保存到集合中

分析:

1,创建集合

2,创建流对象

3,把流所对应文件中的数据 读取到集合中

load(InputStream)  把指定流所对应的文件中的数据,读取出来,保存到Propertie集合中

load(Reader)

4,关闭流

5,显示集合中的数据

package com.oracle.Properties;

import java.io.FileInputStream;

import java.io.IOException;

import java.util.Properties;

public class Demo02 {

public static void main(String[] args) throws IOException {

//创建Properties对象

Properties pro=new Properties();

//获取输入流对象

FileInputStream fis=new FileInputStream("E:\\test\\pro.properties");

//从文件中读取简直对到集合中

pro.load(fis);

//释放资源

System.out.println(pro);

}

}

运行结果:

注意:使用字符流FileReader就可以完成文件中的中文读取操作了

序列化流与反序列化流

用于从流中读取对象的

操作流 ObjectInputStream    称为 反序列化流

用于向流中写入对象的操作流 ObjectOutputStream   称为 序列化流

特点:用于操作对象。可以将对象写入到文件中,也可以从文件中读取对象。

2.1                对象序列化流ObjectOutputStream

ObjectOutputStream 将 Java 对象的基本数据类型和图形写入 OutputStream。可以使用 ObjectInputStream 读取(重构)对象。通过在流中使用文件可以实现对象的持久存储。

注意:只能将支持 java.io.Serializable 接口的对象写入流中

Person类:

package com.oracle.ObjectOutputStream;

import java.io.Serializable;

public class Person implements Serializable {

private String name;

private int age;

public Person(String name, int age) {

super();

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;

}

@Override

public String toString() {

return "Demo01 [name=" + name + ", age=" + age + "]";

}

}

添加数据:

package com.oracle.ObjectOutputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.ObjectOutputStream;

public class Demo01 {

public static void main(String[] args) throws IOException {

//明确数据源

FileOutputStream fos=new FileOutputStream("E:\\test\\person.txt");

ObjectOutputStream oos=new ObjectOutputStream(fos);

oos.writeObject(new Person("佩奇",18));

oos.close();

}

}

运行结果:

2.2                对象反序列化流ObjectInputStream

ObjectInputStream 对以前使用 ObjectOutputStream 写入的基本数据和对象进行反序列化。支持 java.io.Serializable接口的对象才能从流读取。

package com.oracle.ObjectOutputStream;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.ObjectInputStream;

public class Demo02 {

public static void main(String[] args) throws IOException, ClassNotFoundException {

//明确数据源

FileInputStream fis=new FileInputStream("E:\\test\\person.txt");

//创建反序列流

ObjectInputStream ois=new ObjectInputStream(fis);

//多态  重写toString方法

Object obj=ois.readObject();

//Person p=(Person)obj;

//强转

System.out.println(obj);

//释放资源

ois.close();

}

}

运行结果:

2.3                序列化接口

当一个对象要能被序列化,这个对象所属的类必须实现Serializable接口。否则会发生异常NotSerializableException异常。

同时当反序列化对象时,如果对象所属的class文件在序列化之后进行的修改,那么进行反序列化也会发生异常InvalidClassException。发生这个异常的原因如下:

l  该类的序列版本号与从流中读取的类描述符的版本号不匹配

l  该类包含未知数据类型

l  该类没有可访问的无参数构造方法

Serializable标记接口。该接口给需要序列化的类,提供了一个序列版本号。serialVersionUID. 该版本号的目的在于验证序列化的对象和对应类是否版本匹配。

l  代码修改如下,修改后再次写入对象,读取对象测试

package com.oracle.ObjectOutputStream;

import java.io.Serializable;

public class Person implements Serializable {

private String name;

private int age;

private static final long serialVersionUID=123456L;

public Person(String name, int age) {

super();

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;

}

@Override

public String toString() {

return "Demo01 [name=" + name + ", age=" + age + "]";

}

}

2.4                瞬态关键字transient

当一个类的对象需要被序列化时,某些属性不需要被序列化,这时不需要序列化的属性可以使用关键字transient修饰。只要被transient修饰了,序列化时这个属性就不会序列化了。

同时静态修饰也不会被序列化,因为序列化是把对象数据进行持久化存储,而静态的属于类加载时的数据,不会被序列化。

public class Person implements Serializable {

/*

* 给类显示声明一个序列版本号。

*/

private static final long serialVersionUID = 1L;

private static String name;

private transient/*瞬态*/ int age;

public Person() {

super();

}

public Person(String name, int age) {

super();

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;

}

@Override

public String toString() {

return "Person [name=" + name + ", age=" + age + "]";

}

}

打印流

3.1   打印流的概述

打印流添加输出数据的功能,使它们能够方便地打印各种数据值表示形式.

打印流根据流的分类:

字节打印流  PrintStream

字符打印流  PrintWriter

方法:

void print(String str): 输出任意类型的数据,

void println(String str): 输出任意类型的数据,自动写入换行操作

package com.oracle.dayinliu;

import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.FileWriter;

import java.io.IOException;

import java.io.PrintWriter;

public class Demo01 {

//打印流:没有数据源  只有数据目的

//永远不会抛IO异常

//PrintStream

//PrintWriter

public static void main(String[] args) throws IOException{

m1();

}

public static void  m1() throws FileNotFoundException{

PrintWriter  pw=new PrintWriter("E:\\test\\print.txt");

pw.println(100);

pw.flush();

pw.println(true);

pw.print("aaa");

pw.flush();

//释放资源

pw.close();

}

public static void m2() throws IOException{

//打印流自动刷新的前提:

//可以续写

FileWriter fw=new FileWriter("E:\\test\\print.txt",true);

PrintWriter  pw=new PrintWriter(fw,true);

pw.println("拉拉");

pw.println("呃呃");

pw.close();

}

}

}

运行结果:

3.2                打印流完成数据自动刷新

构造方法:

开启文件自动刷新写入功能

public PrintWriter(OutputStream out, boolean autoFlush)

public PrintWriter(Writer out, boolean autoFlush)

package com.oracle.dayinliu;

import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.FileWriter;

import java.io.IOException;

import java.io.PrintWriter;

public class Demo01 {

//打印流:没有数据源  只有数据目的

//永远不会抛IO异常

//PrintStream

//PrintWriter

public static void main(String[] args) throws IOException{

m3();

}

public static void m2() throws IOException{

//打印流自动刷新的前提:

//可以续写

FileWriter fw=new FileWriter("E:\\test\\print.txt",true);

PrintWriter  pw=new PrintWriter(fw,true);

pw.println("拉拉");

pw.println("呃呃");

pw.close();

}

public static void m3() throws IOException{

//获取数据流

FileReader fr=new FileReader("E:\\test\\print.txt");

//包装基本流变成高效率流

BufferedReader br=new BufferedReader(fr);

//创建输出流对象

FileWriter fw=new FileWriter("E:\\test\\e\\print.txt");

PrintWriter pw=new PrintWriter(fw,true);

//开始复制

String line=null;

while((line=br.readLine())!=null){

pw.println("拉拉");

pw.println("呃呃");

}

//释放资源

pw.close();

br.close();

}

}

运行结果:

commons-IO

4.1                导入classpath

加入classpath的第三方jar包内的class文件才能在项目中使用

创建lib文件夹

将commons-io.jar拷贝到lib文件夹

右键点击commons-io.jar,Build Path→Add to Build Path

4.2                FilenameUtils

这个工具类是用来处理文件名(译者注:包含文件路径)的,他可以轻松解决不同操作系统文件名称规范不同的问题

常用方法:

getExtension(String path):获取文件的扩展名;

getName():获取文件名;

isExtension(String fileName,String ext):判断fileName是否是ext后缀名;

4.3                FileUtils

提供文件操作(移动文件,读取文件,检查文件是否存在等等)的方法。

常用方法:

readFileToString(File file):读取文件内容,并返回一个String;

writeStringToFile(File file,String content):将内容content写入到file中;

copyDirectoryToDirectory(File srcDir,File destDir);文件夹复制

copyFile(File srcFile,File destFile);文件复制

提供文件操作(移动文件,读取文件,检查文件是否存在等等)的方法。

常用方法:

readFileToString(File file):读取文件内容,并返回一个String;

writeStringToFile(File file,String content):将内容content写入到file中;

copyDirectoryToDirectory(File srcDir,File destDir);文件夹复制

copyFile(File srcFile,File destFile);文件复制

package com.oracle.dayinliu;

import java.io.File;

import java.io.IOException;

import org.apache.commons.io.FileUtils;

import org.apache.commons.io.FilenameUtils;

public class Demo02 {

public static void main(String[] args) throws IOException {

//      m1();

//      m2();

//      m3();

//m4();

m5();

}

public static void m1(){

//获取文件的扩展名

String ext=FilenameUtils.getExtension("E:\\test\\a.java");

System.out.println(ext);

}

public static void m2(){

//获取文件的文件名

String fileName=FilenameUtils.getName("E:\\test\\a.java");

System.out.println(fileName);

}

public static void m3(){

//获取文件是否以java结尾

boolean flag=FilenameUtils.isExtension("E:\\test\\a.java","java");

System.out.println(flag);

}

public static  void m4() throws IOException{

File file=new File("E:\\test\\x.txt");

String content=FileUtils.readFileToString(file);

System.out.println(content);

}

public static  void m5() throws IOException{

//文件夹复制

File f1=new File("E:\\test\\e");

File f2=new File("E:\\test");

FileUtils.copyDirectoryToDirectory(f1, f2);

}

}

JavaProperties类、序列化流与反序列化流、打印流、commons-IO整理的更多相关文章

  1. Java:IO流其他类(字节数组流、字符数组流、数据流、打印流、Properities、对象流、管道流、随机访问、序列流、字符串读写流)

    一.字节数组流: 类 ByteArrayInputStream:在构造函数的时候,需要接受数据源,而且数据源是一个字节数组. 包含一个内部缓冲区,该缓冲区包含从流中读取的字节.内部计数器跟踪 read ...

  2. File类与常用IO流第十一章——打印流

    第十一章.打印流 概述:java.io.PrintStream extends OutputStream,为其他输出流添加了功能,使题目能够方便的打印各种数据值表示形式. 特点: 只负责数据的输出,不 ...

  3. java IO之 序列流 集合对象Properties 打印流 流对象

    序列流 也称为合并流. SequenceInputStream 序列流,对多个流进行合并. SequenceInputStream 表示其他输入流的逻辑串联.它从输入流的有序集合开始,并从 第一个输入 ...

  4. JAVA学习第五十四课 — IO流(八)打印流 &amp; 序列流

    一.综合练习-文件清单列表 获取指定文件夹下,指定扩展名的文件(含子文件夹),并将这些文件的绝对路径写到一个文本文件里.也就是建立一个指定扩展名的文件列表 1.深度遍历 2.过滤器->容器 3. ...

  5. Java基础知识强化之IO流笔记60:打印流 之 改进复制文本文件的案例

    1. 使用打印流改进复制文本文件的案例 2. 代码示例: package cn.itcast_03; import java.io.BufferedReader; import java.io.Buf ...

  6. Java基础知识强化之IO流笔记59:打印流

    1. 打印流 (1)分类: • 字节打印流   PrintStream • 字符打印流   PrintWriter (2)打印流的特点: • 只能写数据,不能读数据 • 只能操作目的地,不能操作数据源 ...

  7. IO流_PrintWriter(字符打印流)与PrintStream(字节打印流)

    PrintStream:  1.提供了打印方法可以对多种数据类型值进行打印,并保持数据的表示形式  2.它不抛IOException  3.构造函数接受三种类型的值:  字符串路径  File对象   ...

  8. Java第三阶段学习(五、流的操作规律、Properties流、序列化流与反序列化流、打印流、commons-IO jar包)

    一.流的操作规律 四个明确: 明确一:明确要操作的数据是数据源还是数据目的地 源:InputStream   Reader 目的地:OutputStream Writer 先根据需求明确是要读还是写 ...

  9. java基础 序列化反序列化流 实现Serializable 接口 自动装载序列号到对象文本文件如修改不能反序列化对象文本,除非自定义long型常量 打印流

    package com.swift.baseKnowledge; import java.io.File; import java.io.FileInputStream; import java.io ...

  10. Java API —— IO流(数据操作流 & 内存操作流 & 打印流 & 标准输入输出流 & 随机访问流 & 合并流 & 序列化流 & Properties & NIO)

    1.操作基本数据类型的流     1) 操作基本数据类型 · DataInputStream:数据输入流允许应用程序以与机器无关方式从底层输入流中读取基本 Java 数据类型.应用程序可以使用数据输出 ...

随机推荐

  1. SQL server 远程连接不成功解决

    一直以来打算自己做一个博客网站,前段时间开始准备做了,正好碰上新睿云服务器免费一年的活动,赶紧拿下.装好了sqlserver ,用本地访问没有问题,但是关键是外网访问一直不行找了好多资料最终才搞定.下 ...

  2. Python 日志模块logging

    logging模块: logging是一个日志记录模块,可以记录我们日常的操作. logging日志文件写入默认是gbk编码格式的,所以在查看时需要使用gbk的解码方式打开. logging日志等级: ...

  3. Linux学习历程——Centos 7 touch命令

    一.命令介绍 touch 命令用于创建空白文件,以及设置文件的时间. ----------------------------------------------------------------- ...

  4. keepalived+nginx负载均衡+ApacheWeb实现高可用

    1.Keepalived高可用软件 Keepalived软件起初是专为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能.因此,kee ...

  5. vue 组件开发、vue自动化工具、axios使用与router的使用(3)

    一. 组件化开发 1.1 组件[component] 在网页中实现一个功能,需要使用html定义功能的内容结构,使用css声明功能的外观样式,还要使用js定义功能的特效,因此就产生了一个功能先关的代码 ...

  6. spark-RDD源码分析

    http://stark-summer.iteye.com/blog/2178096 RDD的核心方法: 首先看一下getPartitions方法的源码: getPartitions返回的是一系列pa ...

  7. 01背包问题(动态规划)python实现

    01背包问题(动态规划)python实现 在01背包问题中,在选择是否要把一个物品加到背包中.必须把该物品加进去的子问题的解与不取该物品的子问题的解进行比較,这样的方式形成的问题导致了很多重叠子问题, ...

  8. C# — 调用dll出现试图加载不正确格式的程序问题

    今天在调用百度dll包时,运行项目出现了如下警告: 修改:鼠标右击项目名称----选择属性----生成-----平台目标-----X64(由于我调用的是X64的dll包,所以这里选择X64,网上许多说 ...

  9. 3-STM32物联网开发WIFI(ESP8266)+GPRS(Air202)系统方案安全篇(购买域名,域名绑定IP)

    2-STM32物联网开发WIFI(ESP8266)+GPRS(Air202)系统方案安全篇(监听Wi-Fi和APP的数据) 因为安全连接是和域名绑在一块的,所以需要申请域名 有没有不知道域名是什么的, ...

  10. MariaDB第四章:视图,事务,索引,外键--小白博客

    视图 对于复杂的查询,在多个地方被使用,如果需求发生了改变,需要更改sql语句,则需要在多个地方进行修改,维护起来非常麻烦 假如因为某种需求,需要将user拆房表usera和表userb,该两张表的结 ...