Educoder/Touge JAVA——JAVA オブジェクト指向: JAVA の例外

レベル 1: Java の例外処理メカニズム

関連要件

何が異常なのか

例外:プログラムの実行中に発生する異常な状況。

プログラムの実行中に予期しないイベントが発生し、作成したコードがコードどおりに実行されない場合がありますが、これは例外です。例外はJavaプログラム内のエラーですが、すべてのエラーが例外であるわけではありません。たとえば、変数名を定義するときにルールに従わず、Javaステートメントの末尾のセミコロンを見逃した場合、実行の結果は次のようになります。エラーメッセージである可能性がありますjava.lang.Error

しかし、これを使用するとSystem.out.println(5/0)、現時点ではプログラムは正常にコンパイルできますが、実行時には、それを0除数として使用したため、 の例外java.lang.ArithmeticExceptionが。

例外には次のような多くの理由があります。

  1. 間違ったデータが入力された場合。たとえば、プログラムにはint型データが必要であるのに、ユーザーが文字列を入力した場合などです。

  2. オブジェクトは初期化せずに呼び出されます。次のコードでは、null ポインター例外が発生します。

  1. String str = null;
  2. int length = str.length();
  1. 開くファイルは存在しません。

  2. ネットワーク通信中に接続が中断されたか、JVM メモリがオーバーフローしました。

Javaでの例外の仕組みを理解するには、次の 3 種類の例外を理解する必要があります。

  1. チェックされた例外。

  2. 実行時例外。

  3. 間違い。

チェックされた例外

たとえば、ファイルを開こうとする場合、ファイルが存在しない可能性があるため、このコードでは例外が発生する可能性があります。

  1. File f = new File("G://test.java");
  2. FileInputStream fs = new FileInputStream(f);

ここのGディスクの下にtest.javaファイルが存在しない可能性があり、現時点でこのコードを実行すると例外が発生する可能性があるため、コードを記述するときに、IDE はこのコードで発生する可能性のある例外に対処するように求めるプロンプトを表示します。

これを処理しないとプログラムをコンパイルできません。

実行時例外

プログラマーはランタイム例外に対処する必要がなく、例外が発生すると仮想マシンが処理します。一般的な実行時例外は、NULL ポインター例外です。

一般的な実行時例外:

  1. ClassCastException(类转换异常)
  2. IndexOutOfBoundsException(数组越界)
  3. NullPointerException(空指针)
  4. ArrayStoreException(数据存储异常,操作数组时类型不一致)

間違い

エラーは例外ではなく、プログラマの制御の範囲外にある問題です。通常、コード内のエラーは無視されます。たとえば、スタックがオーバーフローするとエラーが発生し、コンパイル時にチェックされません。

例外クラス

すべての例外クラスは、java.lang.Exception クラス。

ExceptionクラスはThrowable クラス。クラスに加えてExceptionThrowableサブクラスもありますError

Java通常、プログラムはエラーを検出しません。エラーは通常、重大な障害が発生したときに発生し、Javaプログラムの処理範囲外です。

Error実行環境で発生したエラーを示すために使用されます。

たとえば、JVMメモリ不足です。一般に、プログラムはエラーから回復できません。

例外クラスには、IOExceptionclass とRuntimeExceptionclass という2 つの主要なサブクラスがあります。

パス 2: 例外のキャッチ 

関連情報

例外をキャッチする

最初のパスでは、いくつかの例外をプログラマが事前に処理する必要があることがわかります。この種の例外は総称して検出例外と呼ばれます。これを処理しないと、プログラムはコンパイルできず、赤い線が表示されます。 IDE。

現時点では、この異常なプログラムに対処する必要があります。

どうやって対処すればいいのでしょうか?

Java は、例外をキャッチするためのメカニズムを提供します。try-catch

tryこれら 2 つの単語の文字通りの意味から、 : try、: catchcatch; 実行を試み代码A代码Bこれら 2 つのコードのいずれかに例外がある場合はcatch進行中のステートメントが実行され、代码A、B例外がない場合は進行中のステートメントが実行されることがよく理解できます。コードは実行されずcatch、最後まで実行が続行されます代码C

したがって、前にエラーを報告したコードは、次のように記述すれば正しいものになります。

catchここで、キャッチされたのは、FileNotFoundExceptionこれがファイルが見つからない例外であることがわかります。したがって、例外をキャッチするときは、例外のタイプが何であるかを明確にすることが最善です。

プログラミング要件

右側のコードを注意深く読み、メソッドのプロンプトに従ってBegin - Endその領域のコードを補足してください。具体的なタスクは次のとおりです。

  • エディターのコードの実行中に例外が発生する可能性があります。この知識を利用して例外を処理してください。
package step2;

import java.util.Scanner;

public class Task {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int num1 = sc.nextInt();
		int num2 = sc.nextInt();
		/********* Begin *********/
		try{
            int ans =num1/num2;
        }catch(ArithmeticException a){
            System.out.println("除数不能为0");
        }		
		System.out.println(num1/num2);		
		/********* End *********/
	}
}

レベル 3: 例外のスロー

関連情報 

キーワードをスローします

前のセクションでは、例外のキャッチを処理する方法を学びましたが、場合によっては、これらの例外を自分で処理せずに怠けたい場合があります。それは可能でしょうか? 答えは「はい」です!

処理したくない例外を他の人に渡すことができますが、それを実現するにはどうすればよいでしょうか?

非常に簡単です。throwsキーワードを使用して例外をスローするだけです。

例えば:

この時点で、エラーが報告されたことがわかりIDE、ここで処理すべき例外があることがわかりましたが、処理したくない場合は、次のようにすることができます。

testメソッド内ではエラーが報告されていませんが、testメソッドが呼び出されたところでエラーが報告されていることがわかります。理由は何ですか?

例外をスローすることは、私たちが通常「鍋を投げる」と呼んでいるものとまったく同じです。責任を負う誰かが常に存在し、例外は常に最終的に処理またはキャッチますJavaメソッド例外が発生した場合、このメソッドの呼び出し元はこの例外をキャッチするか、この例外をスローし続ける必要があります。

したがって、上記のエラーには 2 つの解決策があります。

最初: 例外をキャッチ:

Java2 番目の方法:仮想マシンに「ポット」を投げます。

キーワードを投げる

throw キーワードの役割は、積極的に例外をスローすることです。

まず、システムが自動的に例外をスローする様子を見てみましょう。

  1. public static void main(String[] args) {
  2. int a = 10;
  3. int b = 0;
  4. System.out.println(a/b);
  5. }

このコード システムを実行すると、自動的にjava.lang.ArithmeticException例外がスローされます。

このプログラムは、throw次のキーワードを使用して実装することもできます。

  1. public static void main(String[] args) {
  2. int a = 10;
  3. int b = 0;
  4. if(b == 0){
  5. throw new ArithmeticException("/ by zero");
  6. }
  7. System.out.println(a/b);
  8. }

2 つのプログラムの実行結果は似ていることがわかります。

throwこれは、通常はコード ブロック内で例外をスローするステートメントであり、プログラム内で特定の論理エラーが発生すると、プログラマは積極的に特定の種類の例外をスローします

注:throwキーワードを使用して検出された例外をアクティブthrowsにスローする場合は、このメソッドを呼び出すときに例外がスローされる可能性があることを示すためにメソッド名で使用する必要があります。

例えば:

ArithmeticExceptionこれは実行時例外であり、実行時に検出されるため、上記のコードのコンパイルは通過しますFileNotFoundExceptionがこれは検出例外であり、コンパイル前に処理する必要があるため、throwsコンパイルを通過するには 2 番目のプログラムを追加する必要があります。

プログラミング要件

右側のコードを注意深く読み、メソッドのプロンプトに従ってBegin - Endその領域のコードを補足してください。具体的なタスクは次のとおりです。

  • 例外のスローと処理。
package step3;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;

public class Task {
	/********* Begin *********/
	//请在合适的部位添加代码
	public static void main(String[] args) throws FileNotFoundException {	
        test();
	}
	public static void test() throws FileNotFoundException {
		File file = new File("abc");
		if(!file.exists()){		//判断文件是否存在
			//文件不存在,则 抛出 文件不存在异常
			 throw new FileNotFoundException("该文件不存在");
		}else{
			FileInputStream fs = new FileInputStream(file);
		}
	}
	/********* End *********/
}

 レベル 4: カスタム例外

関連情報

カスタム例外

上で述べたのはシステムに付属する例外ですが、複雑なプロジェクトを開発している場合、システムに付属する例外ではニーズを満たせない状況によく遭遇するため、現時点では自分で例外を定義する必要があります。 。

カスタム例外を使用する

例外をカスタマイズするにはクラスを継承する方法が一般的ですExceptionが、どのように行うのでしょうか?

これは非常に簡単で、 を継承してException、その情報を親クラスに渡すだけです。

  1. class 自定义异常名 extends Exception{
  2. //因为Exception已经实现了很多异常处理的方法了属性了,
  3. //所以自定义异常只需要将信息传递给父类(使用super关键字)即可
  4. }

単純なカスタム例外:

出力:我是自定义异常

これにより、カスタム例外の定義と使用が実現されます。

プログラミング要件

右側のコードを注意深く読み、メソッドのプロンプトに従ってBegin - Endその領域のコードを補足してください。具体的なタスクは次のとおりです。

  • ユーザー名が3 文字未満かどうかを判断するカスタム例外を定義し、ユーザー名が 3 文字未満の場合はカスタム例外をスローします。
package step4;

import java.util.Scanner;

public class Task {
	/********* Begin *********/
	public static void main(String[] args) throws MyException {
		Scanner sc = new Scanner(System.in);
		String username = sc.next();
		//判断用户名
		if(username.length()<3){
            throw new MyException("用户名小于三位Exception");
        }
        if(username.length()>=3){
            System.out.println("用户名格式正确");
        }		
	}
}
class MyException extends Exception{
    public MyException(){

    }
    public MyException(String err){
        super(err);
    }
}
/********* End *********/

おすすめ

転載: blog.csdn.net/zhou2622/article/details/128357188