Java异常处理的五个关键字:try、catch、finally、throw、throws
在编写程序时,我们必须要考虑程序出现问题的情况
当调用方法使用接受到的参数时,首先需要先对参数数据进行合法的判断,数据若不合法,就应该告诉调用者,传递合法的数据进来。这时需要使用抛出异常的方式来告诉调用者
// 使用格式
throw new 异常类名(参数);
public static void main(String[] args) {
int[] arr = {2,4,52,2};
//根据索引找对应的元素
int index = 4;
int element = getElement(arr, index);
System.out.println(element);
System.out.println("over");
}
/*
* 根据 索引找到数组中对应的元素
*/
public static int getElement(int[] arr,int index){
//判断 索引是否越界
if(index<0 || index>arr.length-1){
/*
判断条件如果满足,当执行完throw抛出异常对象后,方法已经无法继续运算
这时就会结束当前方法的执行,并将异常告知给调用者。这时就需要通过异常来解决
*/
throw new ArrayIndexOutOfBoundsException("索引越界");
}
int element = arr[index];
return element;
}
而对于调用者来说有两种方法进行处理:
声明异常:将问题标识出来,报告给调用者。如果方法内通过throw抛出了编译时异常,而没有捕获处理(稍后讲解该方式),那么必须通过throws进行声明,让调用者去处理
关键字throws运用于方法声明之上,用于表示当前方法不处理异常,而是提醒该方法的调用者来处理异常(抛出异常).
声明异常格式:
修饰符 返回值类型 方法名(参数) throws 异常类名1,异常类名2…{ }
声明异常的代码演示:
public static void main(String[] args) throws FileNotFoundException {
read("a.txt");
}
// 如果定义功能时有问题发生需要报告给调用者。可以通过在方法上使用throws关键字进行声明
public static void read(String path) throws FileNotFoundException {
if (!path.equals("a.txt")) {//如果不是 a.txt这个文件
// 我假设 如果不是 a.txt 认为 该文件不存在 是一个错误 也就是异常 throw
throw new FileNotFoundException("文件不存在");
}
}
throws用于进行异常类的声明,若该方法可能有多种异常情况产生,那么在throws后面可以写多个异常类,用逗号隔开。
public static void main(String[] args) throws IOException {
read("a.txt");
}
public static void read(String path)throws FileNotFoundException, IOException {
if (!path.equals("a.txt")) {//如果不是 a.txt这个文件
// 我假设 如果不是 a.txt 认为 该文件不存在 是一个错误 也就是异常 throw
throw new FileNotFoundException("文件不存在");
}
if (!path.equals("b.txt")) {
throw new IOException();
}
}
如果异常出现的话,会立刻终止程序,所以我们得处理异常:
try-catch的方式就是捕获异常。
捕获异常:Java中对异常有针对性的语句进行捕获,可以对出现的异常进行指定方式的处理。
捕获异常语法如下:
try{
编写可能会出现异常的代码
}catch(异常类型 e){
处理异常的代码
}
演示如下:
public static void main(String[] args) {
try {// 当产生异常时,必须有处理方式。要么捕获,要么声明。
read("b.txt");
} catch (FileNotFoundException e) {// 括号中需要定义什么呢?
//try中抛出的是什么异常,在括号中就定义什么异常类型
System.out.println(e);
}
System.out.println("over");
}
/*
*
* 我们 当前的这个方法中 有异常 有编译期异常
*/
public static void read(String path) throws FileNotFoundException {
if (!path.equals("a.txt")) {//如果不是 a.txt这个文件
// 我假设 如果不是 a.txt 认为 该文件不存在 是一个错误 也就是异常 throw
throw new FileNotFoundException("文件不存在");
}
}
Throwable类中定义了一些查看方法:
public String getMessage()
// 获取异常的描述信息,原因(提示给用户的时候,就提示错误原因
public String toString()
// 获取异常的类型和异常描述信息(不用)
public void printStackTrace()
//打印异常的跟踪栈信息并输出到控制台
finally:有一些特定的代码无论异常是否发生,都需要执行。另外,因为异常会引发程序跳转,导致有些语句执行不到。而finally就是解决这个问题的,在finally代码块中存放的代码都是一定会被执行的。
// finally不可以单独使用
// 多用于自身需要处理异常,最终还需要关闭资源时
try{
} catch{
} finally{
}
异常类如何定义:
java.lang.Exception。java.lang.RuntimeException。// 自定义异常, 当输入年龄小于0 或 大于200时 抛出异常
class AgeException extends Exception {
public AgeException() {}
public AgeException(String message) {
super(message);
}
}
class Person {
int age;
public void setAge(int age) throws AgeException {
if (age < 0 || age > 200) {
throw new AgeException("年龄非法");
}
this.age = age;
}
}
public class customException {
public static void main(String[] args) throws AgeException {
Person person = new Person();
person.setAge(100);
}
}

这张图是常用的集合,并非只有这些集合
public boolean add(E e): 把给定的对象添加到当前集合中 。public void clear() :清空集合中所有的元素。public boolean remove(E e): 把给定的对象在当前集合中删除。public boolean contains(Object obj): 判断当前集合中是否包含给定的对象。public boolean isEmpty(): 判断当前集合是否为空。public int size(): 返回集合中元素的个数。public Object[] toArray(): 把集合中的元素,存储到数组中public class Demo {
public static void main(String[] args) {
Collection<String> col = new ArrayList<>();
col.add("张三" );
col.add("李四");
col.add("王五");
System.out.println(col);
// 删除指定元素, 删除成功返回true, 删除失败返回false
boolean b = col.remove("刘六");
System.out.println(b);
System.out.println(col);
// 判断集合是否包含指定元素
boolean b2 = col.contains("张三");
System.out.println(b2);
// 清空集合中的元素
// col.clear();
// System.out.println(col);
// 判断当前集合是否为空, 长度为0返回true, 否则返回false
boolean empty = col.isEmpty();
System.out.println(empty);
// 返回集合中元素的个数
System.out.println(col.size());
// 将集合转换为数组并遍历
Object[] arr1 = col.toArray();
for (int i = 0; i < arr1.length; i++) {
Object obj = arr1[i];
System.out.println(obj);
}
String[] arr2 = col.toArray(new String[col.size()]);
for (int i = 0; i < arr2.length; i++) {
System.out.println(arr2[i]);
}
}
}
要遍历Collection集合,除了可以将其转换为数组,还可以获取该集合迭代器完成迭代操作
public Iterator iterator()
// 获取集合对应的迭代器,用来遍历集合中的元素的
// 迭代:即Collection集合元素的通用获取方式
// 在取元素之前先要判断集合中有没有元素
// 如果有,就把这个元素取出来,继续判断,如果还有就再取出来
// 一直把集合中的所有元素全部取出。这种取出方式专业术语称为迭代。
E next()
// 返回迭代的下一个元素。
boolean hasNext()
// 如果仍有元素可以迭代,则返回 true
void remove()
// 删除当前next指向的元素
Iterator<String> it = col.iterator();
while (it.hasNext()) {
String next = it.next();
System.out.println(next);
if (next.equals("王五")) {
// 当迭代器在迭代的同时, 集合修改了自身的长度
// 就会抛出 ConcurrentModificationException 并发修改异常
// col.add("刘六");
System.out.println(col);
// 删除当前next指向的元素
it.remove();
}
}
/*
泛型
定义泛型
泛型可以定义在 接口/类/方法 上, 将数据类型作为参数传递
泛型接口:
定义实现类时, 直接确定泛型的数据类型
定义实现类时, 不确定泛型的数据类型 实现类也是泛型类 创建实现类对象时 确定数据类型
使用
创建集合 指定集合中元素的类型, 就是在使用泛型
好处
明确集合中元素的数据类型
将运行时异常提前到编译时错误
避免强制类型转换的麻烦
泛型的通配符
?
泛型的限定
? extends 类: 上限限定 只能传这个类 及其子类类型
? extends super 类: 下限限定 只能传这个类 及其父类类型
*/
public class Demo {
public static void main(String[] args) {
// 创建对象时 确定泛型的类型为Integer
MyClass<Integer> myClass1 = new MyClass<>(12);
System.out.println(myClass1.getName());
// 创建对象时 确定泛型的类型为String
MyClass<String> myClass2 = new MyClass<>("小明");
System.out.println(myClass2.getName());
System.out.println("======================");
// 泛型方法的调用, 调用方法时 确定arg的类型为Integer
myClass1.method(1,12);
// 调用方法时 确定arg的类型为String
myClass1.method(1,"");
System.out.println("========================");
new A().method("张三", 16);
new B<Character, String>().method('四', "18");
System.out.println("=========================");
ArrayList<String> stringArrayList = new ArrayList<String>();
stringArrayList.add("aaa");
stringArrayList.add("nnn");
ArrayList<Integer> intArrayList = new ArrayList<Integer>();
intArrayList.add(1);
intArrayList.add(2);
// 定义方法 使两个集合都可以作为参数传入并遍历
show(stringArrayList);
show(intArrayList);
System.out.println("=========================");
ArrayList<Animal> animals = new ArrayList<>();
ArrayList<Cat> cats = new ArrayList<>();
ArrayList<Dog> dogs = new ArrayList<>();
animals.add(new Animal());
animals.add(new Animal());
cats.add(new Cat());
cats.add(new Cat());
dogs.add(new Dog());
dogs.add(new Dog());
show(dogs);
show(cats);
show(animals);
}
// 泛型的通配符
public static void show(ArrayList<?> arrayList){
// 不能使用?作为变量的数据类型, 所以使用Object
for (Object obj: arrayList) {
// 由于是Object类型, 不能调用对应类型的特有方法
System.out.print(obj + " ");
}
System.out.println();
}
// 泛型的限定
public static void show2(ArrayList<? extends Animal> arrayList) {
for (Object animal : arrayList) {
Animal animals = (Animal)animal;
animals.eat();
}
}
}
// 定义泛型类
class MyClass<A> {
private A name;
public MyClass(A name) {
this.name = name;
}
public A getName() {
return name;
}
// 定义泛型方法
public <arg>void method(A attribute, arg arg) {
System.out.println(attribute.getClass());
System.out.println(arg.getClass().getSimpleName());
}
}
// 定义反应接口
interface MyInterface<k,v> {
public abstract void method(k key, v value);
}
// 定义实现类并确定泛型的数据类型
class A implements MyInterface<String, Integer> {
@Override
public void method(String key, Integer value) {
System.out.println(key + ": " + value);
}
}
// 定义实现类(泛型类) 但不确定泛型的数据类型 创建对象时 确定数据类型
class B<k, v> implements MyInterface<k, v> {
@Override
public void method(k key, v value) {
System.out.println(key + ": " + value);
}
}
class Animal{
public void eat(){
System.out.println("动物吃了");
}
}
class Cat extends Animal {
public void eat(){
System.out.println("吃鱼");
}
}
class Dog extends Animal {
public void eat(){
System.out.println("吃肉");
}
}
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在学习Rails,并阅读了关于乐观锁的内容。我已将类型为integer的lock_version列添加到我的articles表中。但现在每当我第一次尝试更新记录时,我都会收到StaleObjectError异常。这是我的迁移:classAddLockVersionToArticle当我尝试通过Rails控制台更新文章时:article=Article.first=>#我这样做:article.title="newtitle"article.save我明白了:(0.3ms)begintransaction(0.3ms)UPDATE"articles"SET"title"='dwdwd
在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee
我在用Ruby执行简单任务时遇到了一件奇怪的事情。我只想用每个方法迭代字母表,但迭代在执行中先进行:alfawit=("a".."z")puts"That'sanalphabet:\n\n#{alfawit.each{|litera|putslitera}}"这段代码的结果是:(缩写)abc⋮xyzThat'sanalphabet:a..z知道为什么它会这样工作或者我做错了什么吗?提前致谢。 最佳答案 因为您的each调用被插入到在固定字符串之前执行的字符串文字中。此外,each返回一个Enumerable,实际上您甚至打印它。试试
我早就知道Ruby中的“常量”(即大写的变量名)不是真正常量。与其他编程语言一样,对对象的引用是唯一存储在变量/常量中的东西。(侧边栏:Ruby确实具有“卡住”引用对象不被修改的功能,据我所知,许多其他语言都没有提供这种功能。)所以这是我的问题:当您将一个值重新分配给常量时,您会收到如下警告:>>FOO='bar'=>"bar">>FOO='baz'(irb):2:warning:alreadyinitializedconstantFOO=>"baz"有没有办法强制Ruby抛出异常而不是打印警告?很难弄清楚为什么有时会发生重新分配。 最佳答案
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/