IO流

1.定义:

IO流:设备和设备之间的传输(读写)
  
  IO流的分类:
按流的方向分为:
  输入流 --->读取数据(read)
  输出流 --->写出数据(write)
  按数据类型:
  字节输入流:InputStream ----读数据
  字节输出流:OutputStream ----写数据
  
  字符输入流:Reader
  字符输出流:Writer
2.
需求:写一个文件,这个文件内容是:hello,io:
  
  分析:写这样一个文件:最常用的是使用字符流,但是字符流实在字节流之后才产生的,所以:先讲字节流中的字节输出流,后面讲字符流
 
  OutPutStream :该类是一个抽象类,不能实例化
         现在使用他的对象进行写数据
  现在的需求:针对的是文件: File 联想起来:FileOutPutStream
  
 对于输出流和输入流来说,他们的基类的子类的后缀名是一下这种形式
  XXXOutputStream
  XXXInputStream
  XXXReader
  xxxWriter

  
  写数据的具体步骤:
  1)创建字节输出流对象
  看FileOutputStream:具体类的里面的构造方法:
  public FileOutputStream(File file):指定一个File对象
  public FileOutputStream(String name):直接指定文件名称
 
  2)写数据
  3)释放资源


  public class Demo1 {
	
	public static void main(String[] args) throws IOException {
		
		FileOutputStream fos  = new FileOutputStream("fos.txt");//直接指定文件名称
		fos.write("hello,io".getBytes());//写数据:写一个字节进去
		fos.close();//释放资源 关闭资源  关闭和IO流对象有关的资源
		
		
	}
}


文件字节输出流对象中的写数据的方法:
  public void write(int b):写入一个字节
  public void write(byte[] b):写一个字节数组
  public void write(byte[] b, int index,int len):写一部分字节数组(常用)
如何实现一个追加操作?
  构造方法:
  public FileOutputStream(File file, boolean append)
如果第二个参数为 true,则将字节写入文件末尾处,而不是写入文件开始处
public class Demo {
	public static void main(String[] args) throws IOException {
		FileOutputStream fos = new FileOutputStream("fos2.txt, true");
		 
		for(int x = 0;x<10;x++){
			fos.write(("hello"+x).getBytes());
			fos.write("\r\n".getBytes());
		}
		fos.close();
	}
}


 文件字节输入流:
 
  创建输入流对象
  读数据:通过读取文件,显示在控制台
  释放资源
 
  public int read():一次读取一个字节
  public int read(byte[] b):一次读取一个字节数组
public class Demo2 {
	public static void main(String[] args) throws IOException {
		FileInputStream fis = new FileInputStream("fos.txt");
		
		int by = 0;
		while((by = fis.read())!=-1){
			System.out.println((char)by);
		}
	}
}


第二种
              byte[] bys = new byte[1024] ;
		//定义长度
		int len = 0;
		while((len=fis.read(bys)) !=-1){
			System.out.println(new String(bys,0,len));
		}




3.
需求:在当前项目有一个a.txt文件,然后将a.txt文件的内容复制到当前文件下的b.txt文件
  
 复制文件:
  源文件:当前项目下的a.txt文件 ---- 读数据------>FlieInputStream
  
 目的地文件:当前项目下的b.txt文件   ------写数据------>FileOutputStream

public static void main(String[] args) throws IOException {
		//封装源文件
		FileInputStream fis = new FileInputStream("a.txt") ;
		//封装目的文件
		FileOutputStream fos = new FileOutputStream("b.txt") ;
		
		//一次读取一个字节
		int by = 0 ;
		while((by=fis.read()) !=-1){
			//每次读取一个字节,我就一次写一个字节
			fos.write(by);//b - 要写入的字节
		}
		
		//释放资源:谁先谁后都可以
		fis.close();
		fos.close();
	}
}


3.
计算机是何如识别中文这样的字符的,一个中文对应两个字节
  两个两个进行拼接在一块
  第一个字节:肯定是否负数
  第二个字节:可是负数,也可以是整数,对实际是没有影响的
 
public class StringDemo {
	public static void main(String[] args) {
//		String s = "abcde" ;
		//[97, 98, 99, 100, 101]----->如果以字母存储:就会找对应ASCII码表
		
		String s ="我爱你中国" ;
		
		
		//[-50, -46, -80, -82, -60, -29, -42, -48, -71, -6]
		byte[] bys = s.getBytes() ;
		
		System.out.println(Arrays.toString(bys));
	}
}


4.
定义一个字节数组的时候,读取的速度比一次读取一个字节快;为了提供读取的速度,java就给我们提供了
  字节缓冲输入流和字节缓冲输出流:
  缓冲流(高效流)
  BufferedInputStream
  BufferedOutputStream
 
 BufferOutputStream的构造方法:
  public BufferedOutputStream(OutputStream out):推荐使用第一种
                                         OutputStream:本身是抽象类,不能直接实例化
  BufferedOutputStream(new FileOutputStream("路径抽象表现形式"));
5.
字符输入流:
读数据: Reader:抽象类------->InputStreamReader--->FileReader
  public InputStreamReader(InputStream in):默认的编码格式
  public InputStreamReader(InputStream in,String charsetName):指定的编码格式
        字符输入流= 字节输入流+ 编码表
public static void main(String[] args) throws IOException {
		InputStreamReader isr = new InputStreamReader(new FileInputStream("a.txt"));
		
		int ch = 0;
		while((ch = isr.read())!=-1){
			System.out.print((char)ch);
		}
	}


第二种
               
 FileReader fw = new FileReader("a.txt");
		int ch = 0 ;
		while((ch=fw.read())!=-1){
			System.out.print((char)ch);
		




6.
什么时候使用字符流,什么时候使用字节流?
  当通过记事本打开以后,能读懂的文件,就可以使用字符流,但是记事本打开后读不懂乱码,使用字节流(视频,图片,音频等)
流的大方向分为:
输入流
输出流


按数据类型分为
字节输入流:--->InputStream---->FileInputStream--->BufferedInputStream
字节输入流:--->OutputStream--->FileOutputStream--->BufferedOutputStream


字符输入流:--->Reader-->InputStreamReader-->FileReader
字符输出流:--->Writer-->OutputStreamWriter-->FileWriter
本系统采用Python编程语言中的Flask框架作为基础架构,实现了一个面向二手商品交易的网络平台。该平台具备完整的前端展示与后端管理功能,适合用作学术研究、课程作业或个人技术能力训练的实际案例。Flask作为一种简洁高效的Web开发框架,能够以模块化方式支持网站功能的快速搭建。在本系统中,Flask承担了核心服务端的角色,主要完成请求响应处理、数据运算及业务程控制等任务。 开发工具选用PyCharm集成环境。这款由JetBrains推出的Python专用编辑器集成了智能代码提示、错误检测、程序调试与自动化测试等多种辅助功能,显著提升了软件编写与维护的效率。通过该环境,开发者可便捷地进行项目组织与问题排查。 数据存储部分采用MySQL关系型数据库管理系统,用于保存会员资料、产品信息及订单历史等内容。MySQL具备良好的稳定性和处理性能,常被各类网络服务所采用。在Flask体系内,一般会配合SQLAlchemy这一对象关系映射工具使用,使得开发者能够通过Python类对象直接管理数据实体,避免手动编写结构化查询语句。 缓存服务由Redis内存数据库提供支持。Redis是一种支持持久化存储的开放源代码内存键值存储系统,可作为高速缓存、临时数据库或消息代理使用。在本系统中,Redis可能用于暂存高频访问的商品内容、用户登录状态等动态信息,从而加快数据获取速度,降低主数据库的查询负载。 项目归档文件“Python_Flask_ershou-master”预计包含以下关键组成部分: 1. 应用主程序(app.py):包含Flask应用初始化代码及请求路径映射规则。 2. 数据模型定义(models.py):通过SQLAlchemy声明与数据库表对应的类结构。 3. 视图控制器(views.py):包含处理各类网络请求并生成回复的业务函数,涵盖账户管理、商品展示、订单处理等操作。 4. 页面模板目录(templates):存储用于动态生成网页的HTML模板文件。 5. 静态资源目录(static):存放层叠样式表、客户端脚本及图像等固定资源。 6. 依赖清单(requirements.txt):记录项目运行所需的所有第三方Python库及其版本号,便于环境重建。 7. 参数配置(config.py):集中设置数据库连接参数、缓存服务器地址等运行配置。 此外,项目还可能包含自动化测试用例、数据库结构迁移工具以及运行部署相关文档。通过构建此系统,开发者能够系统掌握Flask框架的实际运用,理解用户身份验证、访问控制、数据持久化、界面动态生成等网络应用关键技术,同时熟悉MySQL数据库运维与Redis缓存机制的应用方法。对于入门阶段的学习者而言,该系统可作为综合性的实践训练载体,有效促进Python网络编程技能的提升。 资源来源于网络分享,仅用于学习交使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值