ホームページ Java &#&チュートリアル 一部の開発者が Java のチェック例外に反対するのはなぜですか?

一部の開発者が Java のチェック例外に反対するのはなぜですか?

Nov 19, 2024 am 07:17 AM

Why Do Some Developers Oppose Checked Exceptions in Java?

チェック例外に対する異議

私は何年もの間、「なぜ一部の開発者はチェック例外にそれほど反対しているのか」という質問に対してまともな返答を得ることができませんでした。異常を確認しましたか?私は何度も会話を交わし、ブログ投稿を読み、ブルース・エッケルの視点を読みました(彼は私がこれに反対する声を上げたのを初めて見た人です)。

私は現在、いくつかの新しいコードを書いており、例外の処理方法には細心の注意を払っています。 「チェック例外は好きではない」という人々の意見を理解しようと努めていますが、まだ理解できません。

これまでの会話はすべて、答えのない同じ質問で終わりました...これを設定してみましょう:

一般的に言えば (Java の設計により)、

  • 絶対に捕捉すべきではないエラー (VM はピーナッツアレルギーで、誰かがピーナッツの瓶を注いだ)
  • RuntimeExceptionプログラマが間違ったことをした場合に使用されます (プログラマが配列の端から出て行った)。
  • 例外 (RuntimeException を除く) プログラマが制御できない場合に使用されます (ファイル システムへの書き込み中にディスクがいっぱいになり、プロセスのファイル ハンドルの制限に達したため、これ以上ファイルを開くことはできません)
  • Throwable は、すべての例外タイプの親クラスにすぎません。

例外が発生した場合、開発者ができることはプログラムを終了することだけだという意見をよく聞きます。

私がよく耳にするもう 1 つの議論は、チェック例外によりコードのリファクタリングが難しくなるというものです。

「やめただけ」という議論に関して、私が言いたいのは、たとえやめたとしても、それなりのエラーメッセージを表示する必要があるということです。エラー処理を回避するだけであれば、理由が明確に示されないままプログラムが終了したときに、ユーザーはあまり満足しないでしょう。

「リファクタリングが難しくなる」という意見は、適切な抽象化レベルが選択されていないことを示しています。メソッドが IOException をスローすることを宣言する代わりに、IOException を、何が起こっているかにより適切な例外に変換する必要があります。

プログラムが正常に終了するように Main を catch(Exception) (または場合によっては catch(Throwable) でラップすることに問題はありません -ただし、キャッチする必要がある特定の例外は常にキャッチします。そうすることで、少なくとも適切なエラー メッセージを表示できます。

誰も答えない質問は次のとおりです。

代わりに RuntimeException
サブクラスをスローする場合Exception
サブクラスでは、
何をキャッチすべきかをどうやって知ることができますか?


答えが Exception をキャッチすることである場合、あなたもそれは間違っているように思えます

システム例外を同じ方法で処理する場合。スロー可能な場合、システム例外と VM エラー (など) を同じ方法で処理していることになります。それは私には間違っているように思えます

答えが、スローされたことがわかっている例外のみをキャッチするということであれば、それを知る方法は次のとおりです。例外がスローされましたか? プログラマー X が新しい例外をスローし、それをキャッチするのを忘れた場合はどうなりますか? それは私にとって危険に思えます

スタックトレースを表示するプログラムが間違っていると思います。チェック例外が嫌いな人はそう思いませんか?

では、チェック例外が好きではない場合、その理由を説明できますか?そして、その答えのない質問に答えてください?

どちらのモデルの使用についてのアドバイスも求めていません。人々が Exception ではなく RuntimeException から拡張する理由と、例外をキャッチして再スローする理由を探しています。 1 つは、RuntimeException スローをメソッドに追加する代わりに。チェック例外を好まない理由を理解したいと思います。

以上が一部の開発者が Java のチェック例外に反対するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は? 会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は? Apr 19, 2025 pm 04:51 PM

一部のアプリケーションが適切に機能しないようにする会社のセキュリティソフトウェアのトラブルシューティングとソリューション。多くの企業は、内部ネットワークセキュリティを確保するためにセキュリティソフトウェアを展開します。 ...

名前を数値に変換してソートを実装し、グループの一貫性を維持するにはどうすればよいですか? 名前を数値に変換してソートを実装し、グループの一貫性を維持するにはどうすればよいですか? Apr 19, 2025 pm 11:30 PM

多くのアプリケーションシナリオでソートを実装するために名前を数値に変換するソリューションでは、ユーザーはグループ、特に1つでソートする必要がある場合があります...

MapsTructを使用したシステムドッキングのフィールドマッピングの問題を簡素化する方法は? MapsTructを使用したシステムドッキングのフィールドマッピングの問題を簡素化する方法は? Apr 19, 2025 pm 06:21 PM

システムドッキングでのフィールドマッピング処理は、システムドッキングを実行する際に難しい問題に遭遇することがよくあります。システムのインターフェイスフィールドを効果的にマッピングする方法A ...

Intellijのアイデアは、ログを出力せずにSpring Bootプロジェクトのポート番号をどのように識別しますか? Intellijのアイデアは、ログを出力せずにSpring Bootプロジェクトのポート番号をどのように識別しますか? Apr 19, 2025 pm 11:45 PM

intellijideaultimatiateバージョンを使用してスプリングを開始します...

エンティティクラス変数名をエレガントに取得して、データベースクエリ条件を構築する方法は? エンティティクラス変数名をエレガントに取得して、データベースクエリ条件を構築する方法は? Apr 19, 2025 pm 11:42 PM

データベース操作にMyBatis-Plusまたはその他のORMフレームワークを使用する場合、エンティティクラスの属性名に基づいてクエリ条件を構築する必要があることがよくあります。あなたが毎回手動で...

Javaオブジェクトを配列に安全に変換する方法は? Javaオブジェクトを配列に安全に変換する方法は? Apr 19, 2025 pm 11:33 PM

Javaオブジェクトと配列の変換:リスクの詳細な議論と鋳造タイプ変換の正しい方法多くのJava初心者は、オブジェクトのアレイへの変換に遭遇します...

eコマースプラットフォームSKUおよびSPUデータベースデザイン:ユーザー定義の属性と原因のない製品の両方を考慮する方法は? eコマースプラットフォームSKUおよびSPUデータベースデザイン:ユーザー定義の属性と原因のない製品の両方を考慮する方法は? Apr 19, 2025 pm 11:27 PM

eコマースプラットフォーム上のSKUおよびSPUテーブルの設計の詳細な説明この記事では、eコマースプラットフォームでのSKUとSPUのデータベース設計の問題、特にユーザー定義の販売を扱う方法について説明します。

Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Apr 19, 2025 pm 11:36 PM

Redisキャッシュソリューションは、製品ランキングリストの要件をどのように実現しますか?開発プロセス中に、多くの場合、ランキングの要件に対処する必要があります。

See all articles