zoukankan      html  css  js  c++  java
  • 第八周课程总结&实验报告(六)

    课程总结
    一、异常
    异常处理的格式

    try{
            //有可能出现异常的语句
    }catch(异常类 异常对象){
           //编写异常的处理语句
    }[catch(异常类 异常对象){
           //编写异常的处理语句
    }...]
    [finally{
           一定会运行盗的程序代码;
    }]
    

    二、throws与throw关键词
    在定义一个方法时可以用throws关键词声明,使用throws声明的方法表示此方法不处理,而交给方法的调用进行处理

    class Math{
             public int div(int i,int j)throws Exception{                        //本方法中可以不处理异常
                     int tem=i/j;                                                              //此处有可能产生异常
                     return temp;                                                           //返回计算结果
          }
    }
    public class ThrowsDemo{
          public static void main (String args[]){
            Math m= new Math();                                                       //实例化Math对象
            try{
                     System.out.println("除法操作:"+m.div(10,2));
           }catch(Exception e){
                e.printStackTrace();                                                      //打印异常
           }
       }
    }
    

    在上面代码中,不管是否有问题,都要使用try...catch块进行异常的捕获与处理,与rhrows关键词不同的是throw可以直接使用抛出一个异常,抛出时直接抛出异常类的实例化对象即可。

    三、多线程
    Java中线程的实现包括①继承Thread类②实现Runnable接口 Thread是不共享变量的,Runnable是共享变量的
    一个类只要继承了Thread类,此类就称为多线程操作类,所以在Thread子类中,必须明确地覆写Thread类中run()方法

    线程启动:
    Thread类

    class My Thread extends Thread{                                               //继承Thread类
         private String name;                                                               //在类中定义一个属性
         public MyThread(String name){                                             //通过构造方法设置属性内容
               this.name =name;                                                            //为name属性赋值
         }
    public void run(){                                                                         //覆写Thread类中run()方法
           for(int i=0;i<10;i++){                                                             //循环输出10次
                 System.out.println(name +“运行,i=”+i);
           }
       }
    };
    public class ThreadDemo{
           public static void main(String args[]){
                  MyThread mt1 =new MyThread("线程A");                     //实例化对象
                  MyThread mt2 =new MyThread("线程B");                     //实例化对象
                  mt1.start();                                                                     //启动多线程
                  mt2.start();                                                                     //启动多线程
             }
    }
    

    在线程启动时虽然调用的是start()方法,但实际上调用的确实run()方法的主体,那为什么在启动线程时,为什么必须通过start()方法启动,而不能直接调用run()方法呢
    首先 start()方法在Thread类中定义

    public synchronized void start(){
            if (threadStatus !=0)
                  throw new IllegalThreadStateException();
          ...
          start();
          ...
    }
    private native void start0();
    

    从中可以知道在一个类中的start()方法调用时矿难会抛出“IllegalThreadStateException”的异常,一般重复调用start()方法的时候会抛出这个异常,而实际上此处真正调用的是start()方法
    如果一个类通过继承Thread类来实现,那么只能调用异常start()方法,如果调用多次,则会抛出“IllegalThreadStateException”异常

    实现Runnable接口

    class MyThread implements Runnable{                                                 //实现Runnable接口
                   属性... ;                                                                                      //类中i定义属性
                   方法... ;                                                                                      //类中定义方法
                   public void run(){                                                                       //覆写Runnable接口中的run()方法
              -        线程主体;
              }
    }
    

    synchronized关键词 可以同步对象 ,但是在同步中如果条件矛盾会出现死锁

    实验六 Java异常
    实验目的
    理解异常的基本概念;
    掌握异常处理方法及熟悉常见异常的捕获方法。
    实验要求
    练习捕获异常、声明异常、抛出异常的方法、熟悉try和catch子句的使用。
    掌握自定义异常类的方法。

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

    package test;
    
    public class Demo {
    
    	public static void main(String[] args) {
    		int a[]=null;
    		a=new int [3];
    		try {
    			for(int i=1;i<=4;i++) {
    				System.out.println(a[i]); 
    				
    		}
    			for(int i=1;i<=4;i++) {
    				a[i]=i+3; 
    			}
    			System.out.println(a[4]);
    		
    		}
    		catch(ArrayIndexOutOfBoundsException e) {
    			System.out.println("数组越界:"+e);
    		}
    		finally {
    			System.out.println("异常得到了处理");
    		}
    
    }
    }
    

    实验截图:

    自定义异常类的使用
    车站检查危险品的设备,如果发现危险品会发出警告。编程模拟设备发现危险品。
    技术方案:
    编写一个Exgeption的子类DangerException,该子类可以创建异常对象,该异常对象调用toShow()方法输出“危险物品”。编写一个Machine类,该类的方法checkBag(Goods goods)当发现参数goods是危险品时(goods的isDanger属性是true)将抛出DangerException异常。
    程序在主类的main()方法中的try-catch语句的try部分让Machine类的实例调用checkBag(Goods goods)的方法,如果发现危险品就在try-catch语句的catch部分处理危险品。

    源代码

    package yichang;
    
    import java.util.*;
    
    public class DangerException extends Exception {
    	public void toShow() {
    		System.err.print("属于危险物品");
    	}	
    }
    
    class Machine{
    	public void checkBag(boolean good)throws DangerException{
    		if(good) {
    			DangerException DE=new DangerException();
    			throw DE;
    		}
    	}
    }
    
    class Goods{
    	String name;
    	boolean IsDanger;
    	public String getName() {
    		return name;
    	}
    	public void setName(String name) {
    		this.name = name;
    	}
    	public boolean isIsDanger() {
    		return IsDanger;
    	}
    	public void setIsDanger(boolean isDanger) {
    		IsDanger = isDanger;
    	}
    }
    class Text {
    
    	public static void main(String[] args) {
    		Scanner input =new Scanner(System.in);
    		int flag=0;
    		String check=input.nextLine();
    		Machine m=new Machine();
    		String name[]= {"AK47","RPG","激光枪","硫酸","冰毒"};
    		Goods g=new Goods();
    		for(int i=0;i<name.length;i++) {
    			if(check.equals(name[i])) {
    				g.setIsDanger(true);
    				g.setName(name[i]);
    				flag=1;
    			}
    		}
    		if(flag==1) {
    			try {
    				m.checkBag(g.IsDanger);
    			}
    			catch(DangerException e) {
    				System.out.print(check);
    				e.toShow();
    			}
    		}
    		else {
    			System.out.println(check+"不属于危险物品");
    		}
    
    	}
    
    }
    

    实验截图:

  • 相关阅读:
    在Flex or AIR中检测你的网络连接是否正常
    设置Adobe Air应用程序属性
    airMeeting
    用Adobe Flex3开发AIR应用程序–入门指南
    Adobe Flash Player 9.0.124 的安全策略更改
    分发,安装和运行AIR应用程序
    永远置于顶层(always on top)的AIR应用
    翻译:SWFObject 2.0官方文档
    C#温故而知新学习系列之.NET框架高级特性—概述.NET框架中的反射(一)
    C#温故而知新学习系列之字符串处理—指定字符串的显示格式(一)
  • 原文地址:https://www.cnblogs.com/edg4396/p/11697529.html
Copyright © 2011-2022 走看看