プログラミング超初心者です。
以前、この掲示板でtry/catchとはどんなもので、どういう処理のときに使うものなのかという質問をさせていただいたのですが、そのときに
・if/elseは、ファイルが存在しないとか、ユーザーが許容範囲を越える文字列を入力したなどの『予測可能』な場合に使う
・try/catchは、データベースとの接続が途中で切断されるなどの『予測不可能』な場合に使う
ということを教えていただいたのですが、『予測可能』と『予測不可能』の境目がわかっていません。
そこで
・具体的に、この処理のときは普通はtry/catchを使う
というような処理を教えていただけないでしょうか?
また、そのようなことが記載されているサイトなんかも教えていただければうれしいです。
私が周囲の人から聞いたのは、「COM、またはRPCなどの通信系の処理にはtry/catchを使う」らしいのですが、根拠がいまいちよくわかっていません。
Googleなどで調べてみてもそれらしい答えがないもので・・・。
よろしくお願いいたします。
No.4ベストアンサー
- 回答日時:
条件判断である if() と、例外処理である try/chtch は本来全く別のものです。
それは、本質的な処理における「条件分岐」なのか、本質的な処理でない部分の「例外」なのかの差です。
ですから、具体的な事例というよりは、プログラム設計時の設計思想に関わってきます。
「ファイルが存在しない」というのを、
1)ファイル名を指定する
2)そのファイルが存在しているかどうかチェックする
3)ファイルが存在しない時には、ファイル名の再入力を求める
という場合は、「本質的な処理における分岐」
1)ファイル名を指定する
2)指定されたファイルからデータを読み込む
3)...
※ファイルが存在しない時には、あらかじめ設定されたファイルに差し替えること
であれば、「例外処理」
ただ、ひとついえるのは、「例外処理」は、(例外なだけに)、リカバリ処理を、通常の処理の流れの中に自然に埋め込むのは、かなり面倒です。
どちらかといえば、例外事項が発生した時に、リカバリ処理が、(あらかじめ設定されているデータに差し替えるなど)プログラム側である程度強引に処理できるものは、構造的に例外処理で組み立てる方が簡単ではあります。
これは、(例の中にも示してありますが)
・ファイルが存在しなかった時に、ファイル名の再入力を求める(もちろん、その後、通常の処理に復帰する)
・ファイルが存在しなかったら、あらかじめ設定されたデータを読み込んだことにしてしまう
の、それぞれを例外処理で組み立ててみると、構造的にどちらが例外処理になじみやすいかは、実感できると思います。
No.3
- 回答日時:
C++の例外は、予測可能な事象についてしか使用できません。
というのも、必ずどこかで明示的にthrow式を実行しなければならないからです。特定の処理系の非標準な拡張機能を除けば、プログラムの外部から非同期に予測不能な例外が引き起こされる可能性はないのです。では、どんな場合に例外を使うかですが、
1. 例外を使わなければエラーを通知できない場合。
たとえば、コンストラクタの中で発生したエラーとか、多重定義された演算子で発生したエラーなどです。
2. 階層の深い部分や再帰処理から、一気に戻りたい場合。
一段ずつエラーコードを返しても構いませんが、コードの可読性が大幅に低下する場合が多々あります。
3. 致命傷かそれに近い場合。
その例外が発生した場合には、再起動かそれに近い対応が必要になります。
逆に、例外を使うべきでないのは、
1. リアルタイム処理やタイムクリティカルな処理の中で。
2. ユーザーによる不正な入力など、普通に起こりうる事象に対して。
3. デストラクタなど、リソースの解放時。
かなり乱暴な分類ですが、大体こんな感じです。
もちろん、状況によってはこの限りではありません。
No.2
- 回答日時:
まあ、私もそれなりに初心者ですが、
変数、ここでは
int nBox;
にしましょう。
このnBox は宣言しただけで、中には86409864
みたいなわけのわからない数字が入っています。
まあ、空みたいなものです。でも0(ゼロ)ではない。
つまりこの変数は
if では判定できないのです。
中身が変だから。判定できないから。というわけです。
こういうのに
try/chach を使用するのです。
まとめると
if はしっかりした数字又は文字等が確認できれば使用できる。
try/chatch は読み取り出来ないものに使用するもの。
・・・・だと思います。違っていたら申し訳ないです。
No.1
- 回答日時:
実はもっと単純。
・if/elseを使う場合
何らかの関数を用いて判定する事により、例外が起きる状態を回避でき、最初で例外が起きないと判ったら最後まで起きないとの保証がある場合。
・try/catchを使う場合
何らかの関数を用いて判定しようと思うと、判定する行為そのもので例外が発生してしまうとか、最初は大丈夫で途中まで正しくアクセス出来ていてもアクセスしている最中に回線強制切断などの例外が起きる等、外部に起因する状態変化が起きる場合。
ぶっちゃけ「ifで判定不可能で、赤×の例外が出ちゃう時、赤×の例外が出ちゃう可能性のある時」に使用する。
但し「例外が出ても、そのまま強制終了してもOKで、メモリを開放するとか作業用ファイルを消すとかの後始末などが不要な時」はtry/catchを使わない事もある。
・例外とは
ダイアログウィンドウに赤い×印と一緒に出る「一般保護例外」などの事
普通、予測しない場面でプログラムに非同期で発生する。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Java すみません。助けてください。 javaについての質問です。 integerに変換できない数値をエラー 5 2022/05/18 19:16
- Java Javaのソースコード作成が難しいです... 10 2022/11/11 14:06
- C言語・C++・C# C# で、あるフォルダー内にあるすべてのテキストファイルを別のフォルダーにコピーする。 4 2022/11/21 13:23
- PHP DBのハッシュ化したパスワードをpassword_verifyで戻し照合したのですが上手く行きません 2 2023/02/06 13:24
- その他(プログラミング・Web制作) 単純なコマンドプロンプトが動きません。 2 2022/04/19 15:21
- PHP PHP一覧表示した項目にリンクをはりたい 1 2023/07/12 17:08
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- オープンソース Try Kotlinで readLine()を使うには 1 2023/03/27 21:06
- 英語 共通の前置詞の目的語を持つ前置詞句を列挙する際の表現方法について(省略の位置と方法) 3 2023/08/24 09:40
- 病院・検査 医療事務の入院。 経皮的動脈血酸素飽和度測定 呼吸心拍監視(10時〜19時) 帰室後酸素吸入(11時 1 2022/08/05 20:58
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
マクロで、次のコードへ行く前...
-
【VBA】エラー処理で別プロシー...
-
特定の名前のオートシェイプの...
-
IF文に時間(何時から何時ま...
-
private subモジュールを他のモ...
-
VBAで組み合わせソフトを作ろう...
-
Vba 互換モードでのAppActiveに...
-
エクセルVBAでロックをかけたい
-
ProgressBarを用いる場合、全体...
-
複数個のTextBoxでいずれかの内...
-
ExcelのVBAで、選択したファイ...
-
StatusStripの表示が更新されな...
-
Word VBA。各マクロの間に待ち...
-
VBSのプログラムをタスクスケジ...
-
どう増強すべきか
-
vb2010 Sleepを使うと調子が悪...
-
シェルスクリプトでファイル内...
-
“try/catch”と“if/else”
-
VBAでBook読み込み時の非表示方...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
IF文に時間(何時から何時ま...
-
vbaのエラー対応(実行時エラー...
-
private subモジュールを他のモ...
-
マクロで、次のコードへ行く前...
-
どう増強すべきか
-
特定の名前のオートシェイプの...
-
シグナル 6(SIGABRT)とは?
-
Excel VBA セルの名前があるか...
-
ExcelのVBAで、選択したファイ...
-
どうやってもFor文を抜けてしま...
-
シェルスクリプトでファイル内...
-
ドリブン??
-
特定のファイルを他のプロセス...
-
VB6にてネットワーク上にある共...
-
【VBA】エラー処理で別プロシー...
-
Functionで戻り値を複数返す方法
-
Word VBA。各マクロの間に待ち...
-
エクセル VBAで複数セル選択時...
-
VBA 複数の行を高速で削除する...
おすすめ情報