我們將看到Sigls(變量名稱開頭處的符號)Perl 5和Perl 6之間的差別。
概述
讓我們從Perl 5和Perl 6中的Sigils概述開始:
| 符號 | Perl5 | Perl6 |
| @ | Array | Positional |
| % | Hash | Associative |
| & | Subroutine | Callable |
| $ | Scalar | Item |
| * | Typeglob | N/a |
@(Array vs. Positional)
在perl 5中定義數(shù)組時,可以創(chuàng)建一個可擴展的標量值列表,并給它一個帶有sigil的名稱。@:
# Perl 5my @foo = (1,2,3);push @foo, 42;say for @foo; # 12342
在perl 6中定義數(shù)組時,將創(chuàng)建一個新的列陣對象和綁定它以詞法墊中的那個名字輸入條目。因此:
# Perl 6my @foo = 1,2,3;push @foo, 42;.say for @foo; # 12342
在功能上與Perl 5中相同。然而,第一行是用于:
# Perl 6my @foo := Array.new( 1,2,3 );
這將綁定(而不是賦值)一個新的列陣對象指向詞匯定義的名稱。@foo。這,這個,那,那個@perl 6中的sigil表示一個類型約束:如果您想用該sigil將某個東西綁定到lexpad條目中,則它必執(zhí)行位置角色。要確定一個類是否使用SmartMatch執(zhí)行某個角色并不困難:
# Perl 6say Array ~~ Positional; # True
您可以認為perl 6中的所有數(shù)組都是以與綁定陣列在Perl 5中實現(xiàn)。而這也離事實不遠。如果不深入細節(jié),一個簡單的例子可能會澄清這一點。這,這個,那,那個at-POS方法是實現(xiàn)位置角色。每當需要訪問單個元素時,都會調(diào)用此方法。所以,當你寫:
say @a[42]
你正在執(zhí)行:
say @a.AT-POS(42)
當然,這不是唯一可以實現(xiàn)的方法;更多.
而不是必須綁定您的類來執(zhí)行位置角色,有一種特殊的語法使用是特質(zhì)。所以不必寫:
新聞熱點
疑難解答