下面是一個例子:
代碼如下:
use strict;
#這里是兩個數組
my @i =('1','2','3');
my @j =('a','b','c');
#在進行處理之前,我們把他們先打印出來,看一看他們的樣子
print "In main program before calling subroutine:i="."@i/n";
print "In main program before calling subroutine:j="."@j/n";
#然后我們通過子程序進行處理
reference_sub(@i,@j);
print "In main program after calling subroutine:i="."@i/n";
print "In main program after calling subroutine:j="."@j/n";
#下面是子程序
sub reference_sub
{
my (@i,@j)=@_;
print "In subroutine:i="."@i/n";
print "in subroutine:j="."@j/n";
#這里我們對@_的處理用pop,和shift來進行
push(@i,'4');
shift(@j);
}
得到的結果如下:
代碼如下:
F:/>perl/a.pl
In main program before calling subroutine:i=1 2 3
In main program before calling subroutine:j=a b c
In subroutine:i=1 2 3 a b c
in subroutine:j=
In main program after calling subroutine:i=1 2 3
In main program after calling subroutine:j=a b c
F:/>
在這個例子中,子程序中有兩個參數@i和@j,當我們將這兩個參數傳遞到子程序的時候,子程序將他們全部放入了內置數組@_中,然后在@_中@i和@j的不同沒有了,也就是在@_中混為一談了,無法區分。當我們想重新得到他們兩個的時候,我們發現,@i=1 2 3 a b c,而@j為空。在很多時候這顯然不是我們想要得到的結果,所以我們要用到pass by reference(在大駱駝書第六章中被翻譯為”傳入引用“)
我們僅僅把代碼做一個變動,也就是在
程序如下:
代碼如下:
use strict;
#這里是兩個數組
my @i =('1','2','3');
my @j =('a','b','c');
#在進行處理之前,我們把他們先打印出來,看一看他們的樣子
print "In main program before calling subroutine:i="."@i/n";
print "In main program before calling subroutine:j="."@j/n";
#然后我們通過子程序進行處理
reference_sub(/@i,/@j);#在這里我們添加了反斜線,也就是pass byreference(傳入引用,在大駱駝書中第六章翻譯)
print "In main program after calling subroutine:i="."@i/n";
print "In main program after calling subroutine:j="."@j/n";
#下面是子程序
sub reference_sub
{
my ($i,$j)=@_;#引用也是一種特殊的數據形式,它們在@_中都被當成標量變量來儲存
print "In subroutine:i="."@$i/n";所以這里引用它們的時候,我們在他們前面添加了兩個符號,@代表這是一個數組,$代表著是一個二次引用。
print "in subroutine:j="."@$j/n";
print "In subroutine:the third element is $$j[2]/n";#當引用數組中的一個元素的時候第一個$和后面的j[2]代表數組中的第三個元素,而第二個$代表的就是二次引用
#這里我們對@_的處理用pop,和shift來進行
新聞熱點
疑難解答