第30天学习打卡(异常概述 IO流概述)
异常概述
即非正常情况,通俗的说,异常就是程序出现的错误
异常的分类(Throwable)
异常(Exception)
合理的应用程序可能需要捕获的问题
举例:NullPointerException
错误(Error)
合理的应用程序不应该试图捕获的问题
举例:StackOverFlowError
异常的处理方式
JVM默认的异常处理方式
在控制台打印错误信息,并终止程序
开发中异常的处理方式
try...catch(finally):捕获,自己处理
throws:抛出,交给调用者处理
try...catch(finally):捕获,自己处理
try{
//尝试执行的代码
}catch(Exception e){
//出现可能的异常之后的处理代码
}finally{
//一定会执行的代码,如关闭资源
}
package cn.itcast.demo18;
/*
Java中的异常
分类:
顶层父类:Throwable
子类: Error(错误,不需要我们处理)
子类: Exception(异常,这个才是我们常说的异常)
JVM默认的异常处理方式:
在控制台中打印异常信息,并终止程序。
处理方式:
方式一:捕获,自己处理。 try..catch.finally
格式:
try{
//尝试执行的代码(有可能出现问题的代码)
}catch(Exception e){
//出现问题后的解决方案
}finally{
//写在这里的代码正常情况下一定会执行,一般是用来释放资源的
}
特点:
处理完异常之后,程序会继续执行
总结:
执行流程:
先执行try{}中的内容,看是否有问题(异常)
如果没有异常:直接执行finally语句中的异常
有异常:跳转到catch(){}语句中开始执行,再执行finally{}语句中的内容
方式二:抛出,交给调用者处理 throws
*/
public class Test {
public static void main(String[] args) {
//通过try catch finally来处理异常
try{
//尝试要执行的代码
int a = 10 / 0;
System.out.println("a:" + a);
return;
}catch (Exception e){
//出现问题后的代码(解决方案)
System.out.println("被除数不能为0");
}finally {
//即使try、catch中有return,finally里边的代码也会执行
System.out.println("看看我执行了吗?");
}
}
}
throws:抛出,交给调用者处理
public void 方法名()throws Exception{
}
异常处理方式throws之方案一接着抛:
package cn.itcast.demo19;
/*
异常处理方式二:throws
抛出异常,交给调用者处理
特点:
执行结束后,(抛出异常后)程序不再继续执行
*/
public class Test {
public static void main(String[] args) throws Exception{
//需求:调用show()
//因为show()方法已经抛出了一个异常,作为调用者(main)必须处理这个异常
//方案一:接着抛
show();
System.out.println("看看我执行了吗");
}
//定义一个方法
public static void show() throws Exception{
int a = 10 / 0;
System.out.println("a:" + a);
}
}
方案二:try catch
package cn.itcast.demo19;
/*
异常处理方式二:throws
抛出异常,交给调用者处理
特点:
执行结束后,(抛出异常后)程序不再继续执行
*/
public class Test {
public static void main(String[] args) throws Exception{
//需求:调用show()
//因为show()方法已经抛出了一个异常,作为调用者(main)必须处理这个异常
//方案一:接着抛
//show();
//方案二:采用try catch处理
try{
show();
}catch (Exception e){
System.out.println("代码出问题了!");
}
System.out.println("看看我执行了吗");
}
//定义一个方法
public static void show() throws Exception{
int a = 10 / 0;
System.out.println("a:" + a);
}
}
IO流概述:
I/O,即输入(Input)输出(Output),IO流指的是数据像连绵的流体一样进行传输。
IO流的作用:
在本地磁盘和网络上操作数据
IO流分类
按数据流向分:
输入流
输出流
按操作方式分:
字节流:
InputStream
OutputStream
字符流:
Reader
Writer
这四个流都是抽象类,使用时要使用它们的子类。
IO流体系
字符流:按字符读写数据的IO流
Reader
FileReader
BufferedReader
Writer
FileWriter
BufferedWriter
字节流:按字节读写数据的IO流
InputStream
FileInputStream
BufferedInputStream
OutputStream
FileOutputStream
BufferedOutputStream
IO流简介:
概述:
I(Input,输入)/O(Output,输出流)流,是Java中用来传输数据的方式
划分:
按照流向分:
输入流:读数据。
输出流:写数据。
按照操作分:
字节流:以字节为单位来操作数据
InputStream: 字节输入流的顶层抽象类
FileInputStream:普通的字节输入流
BufferedInputStream:高效的字节输入流(也叫:字节缓冲输入流)
OutputStream:字节输出流的顶层抽象类
FileOutputStream:普通的字节输出流。
BufferedOutputStream:高效的字节输出流(也加:字节缓冲输出流)
字符流:以字符为单位来操作数据
Reader:字符输入流的顶层抽象类
FileReader:普通的字符输入流。
BufferedReader:高效的字符输入流(也叫:字符缓冲输入流)
Writer:字符输出流的顶层抽象类
FileWriter:普通的字符输出流
BufferedWriter:高效的字符输出流(也叫:字符缓冲输出流)
第30天学习打卡(异常概述 IO流概述)的更多相关文章
- 36、IO流概述和分类
IO流概述 IO流的主要作用是用来处理设备之间的数据传输,例如可以使用IO流将一台电脑硬盘里面的照片传输到另一台电脑上面,即将照片转换为字节,然后将字节传到另一台电脑上面,另一台电脑接收后,可以将这些 ...
- java学习(九) —— java中的File文件操作及IO流概述
前言 流是干什么的:为了永久性的保存数据. IO流用来处理设备之间的数据传输(上传和下载文件) java对数据的操作是通过流的方式. java用于操作流的对象都在IO包中. java IO系统的学习, ...
- Java基础---IO(一)---IO流概述、字符流、字节流、流操作规律
第一讲 IO概述 概述 1.IO流:即InputOutput的缩写. 2.特点: 1)IO流用来处理设备间的数据传输. 2)Java对数据的操作是通过流的方式. 3)Java用于操作流的对象都 ...
- Java之IO流概述和File基本操作
IO流图解 IO(in / out)流的分类 流向: 输入流 读取数据 输出流 写出数据 数据类型: 字节流 一个字节占8位, 以一个字节为单位读数据 八大数据类型所占字节数: byte(1), ...
- JavaSE学习总结(十七)—— IO流
一.IO流概要 1.1.概念 开发中经常要进行输入输出操作,掌握Java中的IO流显得非常必要. 流(stream)的概念源于UNIX中管道(pipe)的概念.在UNIX中,管道是一条不间断的字节流, ...
- java IO流 (二) IO流概述
1.流的分类* 1.操作数据单位:字节流.字符流* 2.数据的流向:输入流.输出流* 3.流的角色:节点流.处理流 图示: 2.流的体系结构 说明:红框对应的是IO流中的4个抽象基类.蓝框的流需要大家 ...
- JAVA学习第四十七课 — IO流(一):文件的读写
输入流和输出流相对于内存 将外部设备的数据读取到内存中:输入 将内存中的数据写入外部设备中:输出 IO流经常使用基类 字节流的抽象基类:InputStream,OutputStream 字符的抽象基类 ...
- Java学习之路(十一):IO流<前戏>
File类的概述和构造方法 构造方法: File(String pathname):根据一个路径得到File对象 File(String parent,String child):根据一个目录和一个子 ...
- java学习第20天(IO流)
构造方法File file = new File("e:\\demo"); 创建文件夹 File file = new File("e:\\demo"); fi ...
随机推荐
- 2019 Multi-University Training Contest 4.Divide the Stones(贪心)
题意:给你n和k (k|n) 有n个数 第i个数权值为i 要你求权值相同且分成k组 且每组的个数为n/k 思路:恶心构造题,首先对于总权值不能分为k份的 显然不能分成 然后 我们把n/k 分奇偶 我们 ...
- Codeforces Round #673 (Div. 2) D. Make Them Equal(数论/构造)
题目链接:https://codeforces.com/contest/1417/problem/D 题意 给出一个大小为 $n$ 的正整数数组 $a$ ,每次操作如下: 选择 $i,j$ 和 $x$ ...
- HDU5589 Tree【分块 01字典树】
HDU5589 Tree 题意: 给出一棵\(N\)个点的树,每条边有边权,每次询问下标为\([L,R]\)区间内的点能选出多少点对,点对之间的路径上的边权异或和大于\(M\) 题解: 对于两点\(u ...
- 【noi 2.5_1792】迷宫(bfs 或 dfs)
简单搜索,在n*n的矩阵中,问从起点是否可以到达终点,有些格子不可走,上下左右四个方向都可以走.(N<=100)1.bfs从起点开始走,直到走到终点或全部遍历过一次就结束.2.dfs要一走到终点 ...
- Codeforces Round #648 (Div. 2) F. Swaps Again
题目链接:F.Swaps Again 题意: 有两个长度为n的数组a和数组b,可以选择k(1<=k<=n/2)交换某一个数组的前缀k和后缀k,可以交换任意次数,看最后是否能使两个数组相等 ...
- fzu2204 7
Problem Description n个有标号的球围成一个圈.每个球有两种颜色可以选择黑或白染色.问有多少种方案使得没有出现连续白球7个或连续黑球7个. Input 第一行有多组数据.第一行T表 ...
- WPF Animation For SizeChanged Of UIElement
效果图 学到一个新词: Show me the money 背景 这几天查资料,看到 CodeProject 上面的一篇 Post <Advanced Custom TreeView Layou ...
- 【史上最全】Hadoop 核心 - HDFS 分布式文件系统详解(上万字建议收藏)
1. HDFS概述 Hadoop 分布式系统框架中,首要的基础功能就是文件系统,在 Hadoop 中使用 FileSystem 这个抽象类来表示我们的文件系统,这个抽象类下面有很多子实现类,究竟使用哪 ...
- dll的注册与反注册
regsvr32.exe是32位系统下使用的DLL注册和反注册工具,使用它必须通过命令行的方式使用,格式是:regsvr32 [/i[:cmdline]] DLL文件名命令可以在"开始→运行 ...
- woj1016 cherry blossom woj1017 Billiard ball 几何
title: woj1016 cherry blossom date: 2020-03-18 20:00:00 categories: acm tags: [acm,几何,woj] 几何题,判断给出的 ...