質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Perl

Perlは多目的に使用される実用性が高い動的プログラミング言語のひとつです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Q&A

解決済

1回答

1881閲覧

perl die関数の文字列が出力されない。

Ineda

総合スコア45

Perl

Perlは多目的に使用される実用性が高い動的プログラミング言語のひとつです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

0グッド

1クリップ

投稿2021/01/21 04:58

編集2021/01/21 04:59

環境

Red Hat Enterprise Linux Server release 6.5 (Santiago)
perl v5.10.1

困っていること

いにしえのperlのソケット通信プログラムを修正することになりました。
ログを調べたところ、以下送信エラー時に恐らくプログラムが終了しています。

perl

1send(HSOCK, $fdata, 0) or die("send() fail:$!\n");

しかし、ログには"send() fail"という記述は見当たりませんでした。
気になったので(簡易的に)

perl

1sub main() 2{ 3 die "send() fail:"; 4} 5eval {main()}; 6exit(); 7

のようなプログラムを簡易的に作成し、実行したのですが、
"send() fail:"という文字列はコンソールには出力されませんでした。

どのようにすればdie関数は出力されるのでしょうか?
または、どこかシステムログに出力されているのでしょうか?

知っている方教えて欲しいと思います。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

perlのdieは、単に「エラーを出力して異常終了する」という機能ではなく、「例外送出」です。
つまり、C++やJavaでのthrow、PythonやRubyでのraiseに相当します。
※例外に対してなにもしなければ異常終了になるだけで。

で、C++やJavaでのtry~catch、Pythonでのtry~except、Rubyでのbegin~rescueのような例外捕捉を行うのが、Perlの場合evalということになります。
eval{main()};のように、evalブロックで囲んでいる場合、その中の処理で例外がdieにより発生すると、異常終了ではなく、例外の内容が特殊変数$@に保存されます。つまり、このケースでは"send() fail:"という文字列が$@に入っていることになりますので、別途 print や say で出力すればコンソール等で確認できます。

参考: https://perldoc.jp/func/die

補足: $@には、dieで指定した例外の内容だけでなく、エラー発生個所(ソースファイル・行数)も追加されて保存されますので、適切に内容を追うことでトラブル発生個所の割り出しに役立ちます。

投稿2021/01/21 05:12

編集2021/01/21 05:32
angel_p_57

総合スコア1672

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問