勉強を始めて数日、サブルーチンが理解できずこまっています。長くてすみませんが、どなたか以下の解説をお願いします。
1 : $aa = "hello";
2 : $kekka_sub_1 = $sub_1($aa);
3 : $kekka_sub_2 = $sub_2($aa);
4 :
5 : print "sub_1の結果: $kekka_sub_1";
6 : print "sub_2の結果: $kekka_sub_2";
7 :
8 : sub sub_1{
9 : ($aa) = @_;
10: $aa = "Hanako!".$aa;
11: return $aa;
12: }
13:
14: sub sub_2{
15: ($aa) = @_;
16: $aa = "Taro!".$aa;
17: return $aa;
18: }
まず、line9と15の@_というのが一体何なのかわかりません。
@といえば配列全体を示すものと覚えているのですが、これがどこから来たのか・・・・。
次にreturnですが、これは実際には「line1の$aaへ戻れ」という意味なのかそれとも別の意味なのか・・・・・。
私の持っている本だと@_は、サブルーチンの引数が設定されている変数です。とあるのですが、実際何をしているところなのかが理解できません。
勉強を始めたばかりなので、わかりやす~い解説を頂けたらうれしいです。よろしくお願いします。
No.1ベストアンサー
- 回答日時:
まず、書かれているスクリプトに一部書き間違いと思われるところがありますので、そちらを修正しますね。
2 : $kekka_sub_1 = $sub_1($aa);
3 : $kekka_sub_2 = $sub_2($aa);
は
$kekka_sub_1 = &sub_1($aa);
$kekka_sub_2 = &sug_2($aa);
ですね。
引数というのは、関数へジャンプするときに
一緒に持っていく変数や値の事です。
たとえば、このスクリプトですと2行目、3行目の$aaの部分が引数に当たります。
Perlでは関数を呼び出すときに自動的に引数が@_という配列になります。
なので、引数は関数側ではその配列の添え字を利用して、
@_[0] # 一つ目の引数
@_[1] # 二つ目の引数
という感じで値を受け取るんです。
このスクリプトでは、値を受け取るときに
($aa) = @_;
となっていますが、これは
$aa = @_[0];
と同じ意味になります。
split関数の記述を思い出してくださればご理解いただけると思います。
でも後者の方がわかりやすいと思いますよ。
もっと言えば、このままだとこの$aaと関数を呼び出す時に使用した$aaは同じ物とみなされてしまうので、関数の中で$aaの中身を変えてしまったら、関数の外の$aaの中身も変わってしまいます。
それを防ぐ為には
local($aa) = @_[0];
として、「これはこの関数の中だけで使う変数なんだ」と書いてやる必要があります。
returnですが、これは「戻り値」と言いまして、関数から抜けるときに一緒に持って変える値の事です。(この場合$aa)
その値はこの例ですと$kekka_sub_2 = &sub_2($aa);
の$kekka_sub_2 に格納される事になります。
sub1では受け取った値("hello")を"Hanako!"と連結させて返しているんです。
実際にこのスクリプトを動かしてみると、よくわかると思いますよ。
長々と失礼しました。
yuizuianさん、とってもとっても分かりやすい解説ありがとうございます。
ものすごく分かりやすいので、ひとつひとつ何度も読んでます。
こんな参考書があったらいいんですけど、探すのが下手なのか、それとも私が理解できなさ過ぎなのか・・・・。
とにかく、ありがとうございます。本当に助かりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ワークシートごとに計算結果 2 2022/04/30 22:00
- その他(プログラミング・Web制作) pythonのmap、結果の利用は1度だけ? 5 2022/06/11 12:33
- Excel(エクセル) Formulaプロパティーを使ってセルに数式を組んだのですが簡潔にしたい。 3 2022/08/21 20:51
- Visual Basic(VBA) リストボックスに表示されたファイルを削除したい 1 2023/04/19 12:02
- Perl perlの構文でカンマの意味が分からない 2 2022/10/30 01:53
- お酒・アルコール 断酒団体AAについての質問です 今年に入ってからお酒をやめました 自助グループとして「断酒会」と「A 3 2023/05/22 11:39
- C言語・C++・C# C言語: ポインタ 5 2022/06/01 08:33
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- C言語・C++・C# const char** p;のとき、free(p)でC4090エラーとなるのはなぜですか 3 2023/03/31 16:28
- Excel(エクセル) 【マクロ】リボン、行列、数式・ステータスバを非表示に 4 2022/12/12 07:32
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA public変数はどのようなこ...
-
マクロ 条件式
-
上付文字と下付文字について(D...
-
フォルダ内にさらにフォルダが...
-
演奏記号の・・・・
-
GetNextWindowがDLLファイルUse...
-
Functionの戻り値を配列にした...
-
チェックボックスを操作できな...
-
C言語のサフィックスについて
-
C#のループでtextboxに値を入れ...
-
他のフォームから別のフォーム...
-
【VB6.0】 あるフォームから他...
-
リストビューの列ヘッダーの幅...
-
【VBScript】変数のスコープ
-
VB.NETでのイベントの途中終了
-
verilogのcase文
-
アクセスできない保護レベルエ...
-
VBAでcallで呼び出したsubを終...
-
SavePictureで保存できない
-
ボールが壁に当たって跳ね返る...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA public変数はどのようなこ...
-
GetNextWindowがDLLファイルUse...
-
VB6.0の正規表現を使って、文字...
-
Excel VBA: private sub 内の...
-
演奏記号の・・・・
-
上付文字と下付文字について(D...
-
pthread_cond_waitとptherad_co...
-
プロシージャをまたいて変数を...
-
2項定理
-
slapd再起動時にエラー
-
sub-paragraphとsub-sub-paragraph
-
分割コンパイルの方法がわかり...
-
sublimit textっていうエディタ...
-
エクセルVBAでテキストボッ...
-
VBAでcallで呼び出したsubを終...
-
他のフォームから別のフォーム...
-
Functionの戻り値を配列にした...
-
C#のループでtextboxに値を入れ...
-
チェックボックスを操作できな...
-
レコードセットにnullの場合
おすすめ情報