• 第八周课程总结&实验报告(六)


    实验内容

    一,编写一个类,在其main()方法中创建一个一维数组,在try字句中访问数组元素,使其产生ArrayIndexOutOfBoundsException异常。在catch子句里捕获此异常对象,并且打印“数组越界”信息,加一个finally子句,打印一条信息以证明这里确实得到了执行。

    自定义异常类的使用

    1.代码

    package test;
    
    public class one {
    
        public static void main(String[] args) {
            
            
            try {
                int s[]= {1,2,3};
                System.out.println(s[3]);
            }catch(ArrayIndexOutOfBoundsException a) {
                System.out.println("数组越界"+a);
            }finally {
                System.out.println("执行");
            }
            
            System.out.println("计算结束");
    
        }
    
    }
    

    2.运行截图

    二,车站检查危险品的设备,如果发现危险品会发出警告。编程模拟设备发现危险品。

    技术方案:

    编写一个Exgeption的子类DangerException,该子类可以创建异常对象,该异常对象调用toShow()方法输出“危险物品”。编写一个Machine类,该类的方法checkBag(Goods goods)当发现参数goods是危险品时(goods的isDanger属性是true)将抛出DangerException异常。
    程序在主类的main()方法中的try-catch语句的try部分让Machine类的实例调用checkBag(Goods goods)的方法,如果发现危险品就在try-catch语句的catch部分处理危险品。

    1.代码

    package two;
    
    public class DangerException extends Exception{
        String message;
        public DangerException() {
            message="是危险品";
        }
        public void toShow(){                      
            System.out.println(message+" ");           
        }
    }
    
    package two;
    
    public class Goods {
        boolean isDanger;          
        String name;
        public boolean isDanger() {             
            return isDanger;
        }
        public void setIsDanger(boolean bo) {        
            this.isDanger = bo;          
        }
        public String getName() {           
            return name;
        }
        public void setName(String s) {          
            this.name = s;
        }
    }
    
    
    package two;
    
    public class Machine {
        public void checkBag (Goods goods) throws DangerException {
            if(goods.isDanger())
            {
                DangerException danger=new DangerException();
                throw danger;
            }
            else
            {
                System.out.print(goods.getName()+"不是危险品!");
            }
        }
    
    }
    
    package two;
    
    public class Test1 {
        public static void main(String arfs[]) {
        Machine machine=new Machine();
         String name[]={"汽油","野蛮女友","管制刀具","书"};   
         Goods[] goods = new Goods[name.length];             
         for(int i=0;i<name.length;i++){          
             goods [i]=new Goods();
             if(i%2==1){           
                 goods[i].setIsDanger(false);
                 goods[i].setName(name[i]);
             }
             else{
                 goods[i].setIsDanger(true);
                 goods[i].setName(name[i]);
             }
         }
         for(int i=0;i<goods.length;i++){     
             try { 
                 machine.checkBag(goods[i]);          
                 System.out.println(goods[i].getName()+"可安全通过");
             }
             catch (DangerException e){  
                 e.toShow();         
                 System.err.println(goods[i].getName()+"禁止通过");
             }
             
         }
     }
    }
    

    2.运行截图

    总结:
    1.throws出现在方法函数头;而throw出现在函数体。
    2.throws表示出现异常的一种可能性,并不一定会发生这些异常;throw则是抛出了异常,执行throw则一定抛出了某种异常对象。
    3.两者都只是抛出或者可能抛出异常,但是不会由函数去处理异常,真正的处理异常由函数的上层调用处理。

  • 相关阅读:
    Jmeter+Ant+Jenkins搭建持续集成的接口测试(推荐 Mark)
    配置sonar、jenkins进行持续审查
    查看端口占用
    CentOS 6.5系统上安装SVN服务器端的方法及目录访问权限配置(转总结)
    Windows批处理 调用程序后 不等待子进程 父进程继续执行命令
    Jmeter笔记:响应断言详解
    Ubuntu 16.04常用快捷键
    如何永久激活(破解) IntelliJ IDEA 2018.2
    Cobbler自动化部署
    Typora使用说明(记录总结)
  • 原文地址:https://www.cnblogs.com/zh2250881784/p/11700845.html
Copyright © 2020-2023  润新知