《Java编程思想》读书笔记(12)

以前学c语言时,总是在自己写的函数里为程序的各种运行情况设置一个返回标志值,返回值可以是10等标志值,来根据这些标志值来判断程序是否正常运行,但代码多了就总是搞不清楚这些标志值之间的区别,因此代码就变得很难读了。而java用“异常处理”很好地解决了这个恼火的问题。

       异常处理理论上划分为两种:中止模型(temination),也就是javac++采用的模型,它假定错误十分严重,因此无法回到错误的地方,只能抛出异常。还有一种就是“继续(resumption),它认为异常处理程序应该能对当前的运行环境进行修复,然后尝试上次出错了的方法。也就是说处理完异常后,希望能够继续运行当前指令。但这种模型的”耦合性“太大。

package com.vitamin.Console;
import java.lang.
*;

public class exceptionTest
{
    
    
/**
     * @param args
     
*/

    
public static void main(String[] args)
    
{
        
// TODO Auto-generated method stub
        try
        
{
            f();
        }

        
catch(MyException ex)
        
{
            System.err.println(ex.getMessage().toString());
        }


    }

    
public static void f() throws MyException
    
{
        System.
out.println("Hello");
        
    }


}

Java异常处理中存在着一个错误,如果用如下方式去使用的话就会出错:

package com.vitamin.Console;
import java.lang.Throwable;


public class exceptionTest
{
    
    
public static void main(String[] args) throws Exception
    
{
        
// TODO Auto-generated method stub
        try
        
{
            g();
        }

        
finally
        
{
            f();
        }

    }

    
public static void g() throws Exception
    
{
        
throw new Exception("异常1");
    }

    
public static void f() throws MyException
    
{
        
throw new MyException("异常2");
        
    }


}

异常2把异常1给弄丢了!!!

在覆写一个方法时,只能抛出这个方法在基类中的版本所声明的异常,这样就可以实现多态性。

posted on   Phinecos(洞庭散人)  阅读(435)  评论(0编辑  收藏  举报

编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述

导航

统计

点击右上角即可分享
微信分享提示