Языковые конструкции Perl



Основные понятия



В предыдущих версиях Perl была реализована возможность только символьных ссылок. Perl версии 5 и выше позволяет использовать не только символьные ссылки на переменные, но и ``жесткие'' ссылки на любые данные. Так как любой скаляр может быть ссылкой, а массивы и хэши состоят из скаляров, то можно с легкостью организовать массив массивов, массив хэшей, хэш массивов и так далее. ``Жесткие'' ссылки следят за счетчиком ссылки и как только счетчик становится равным нулю, автоматически удаляют ссылку. Символьные ссылки содержат только имя переменной, также как символьная ссылка файловой системы содержит просто имя файла. Ссылки могут быть созданы несколькими способами:
  1. Используя бэкслэш оператор перед переменной, подпрограммой или простой константой. (Это работает почти как & - создается еще одна ссылка, так как одна уже существует в символьной таблице.)
    $varref = \$foo;    $arref = @ARGV;    $hashref = \%ENV;    $coderef = \&handler;
  2. Ссылка на массив может быть создана с использованием квадратных скобок:
    $arrayref = [1,2,['a','b','c']];
    По адресу $arrayref[2][1] будет храниться значение b.
  3. Ссылка на произвольный хэш может быть создана с использованием фигурных скобок:
    $hashref = {        'Earth' => 'Moon',        'Jupiter' => 'Kallisto',        ...    };
  4. Ссылка на подпрограмму может быть создана с использованием слова sub, без определения имени подпрограммы:
    $coderef = sub { print "Hello!\n" };
  5. Ссылки часто возвращаются конструкторами. Объекты Perl на самом деле являются ссылками на специальную сущность, которая знает, какой пакет ассоциировать с объектом. Конструкторы это специальные подпрограммы, которые умеют создавать эту ассоциацию.
Чтобы извлечь информацию, на которую указывает ссылка, тоже существует несколько методов:
  1. Можно сделать идентификатор ссылки частью имени переменной или подпрограммы:
    $bar = $$scalarref;    push(@$arrayref,$filename);    $$arrayref[0] = "January";    $$hashref{"key"} = "value";    &$coderef(1,2,3);        $refrefref = \\\"how are you?";    print $$$$refrefref;
    - напечатает ``how are you?''.
    Нужно понимать, что раскрытие ссылки имеет более высокий приоритет, чем извлечение значения переменной.
  2. Можно поступить как и в предыдущем случае, но заключить выражение после знака $в фигурные скобки. Приведенный пример тогда будет выглядеть таким образом:
    $bar = ${$scalarref};    push(@{$arrayref},$filename);    ${$arrayref}[0] = "January";    ${$hashref}{"key"} = "value";    &{$coderef}(1,2,3);
    В данном случае использование фигурных скобок ничего не меняет, но в общем случае в скобках может стоять произвольное выражение, даже подпрограмма:
    &{ $dispatch{$index} }(1,2,3);
  3. В случае массива или хэша можно использовать такую запись:
    $arrayref->[0] = "January";    $hashref->{"key"} = "value";
    Левая часть должна быть выражением, возвращающим ссылку, возможно также являющуимся раскрытием ссылки:
    $array[$x]->{"foo"}->[0] = "January";
  4. Если ссылка является ссылкой на объект, то раскрытие данных происходит также, как уже было описано выше.
Функция ref() может быть использована для определения типа объекта, на который указывает ссылка. Функция bless() может быть использована для ассоциирования ссылки с пакетом, функционирующим как объектный класс.

Символьные ссылки



Мы рассмотрели, что происходит, если величина, используемая в качестве ссылки, не была определена ранее. Что же происходит, если она уже определена и не является жесткой ссылкой? В таком случае она обрабатывается как символьная ссылка. То есть значение скаляра рассматривается как имя переменной, а не прямая ссылка на переменную.
 ?    $name = "foo";    $$name = 1;   - то же самое, что $foo = 1;     ${$name} = 2; - то же самое, что $foo = 2;    ${$name x 2 } = 3; 	 -то же самое, что $foofoo = 3;    $name->[0] = 4; 	 -то же самое, что $foo[0] = 4;    @$name = ();  - обнуляет массив @foo    &$name();  - вызывает &foo    


Регулярные выражения



Perl позволяет использовать регулярные выражения. Для того чтобы пояснить, что же представляет из себя регулярное выражение приведем несколько примеров:
/SWAP.*/ - соответствуют все слова начинающиеся со SWAP и заканчивающихся произвольным набором символов. Точка обозначает произвольный символ, звездочка - то, что символ, стоящий перед ней, входит в слово 0 и более раз. Все метасимволы, которые будут описаны ниже, бозначают вхождение того, что стоит перед ними.
/\w*/ - соответствуют слова состоящие только из алфавитных, цифровых символов и символа подчерк. \w - соответствует алфавитным, цифровым символам и символу подчерк, звездочка - тому, что эти символы могут входить произволное количество раз. Здесь мы приведем только основные метасимволы. Для более подробной информации смотрите соответствующие страницы man по Perl.
 ?    * 	  соответствует 0 или более вхождений    + 	  соответствует 1 или более вхождений    ? 	  соответствует 1 или 0 вхождений    {n}  соответствует ровно n вхождений    {n,}  соответствует по крайней мере n вхождений    {n,m}  соответствует по крайней мере n,                  	 но не более m вхождений    
Метасимвол * эквивалентен {0,}, + эквивалентен {1,} и ? эквивалентен {0,1}. Ограничений на величину m и n нет. Эта стандартная конструкция работает в ``жадном'' режиме, то есть: регулярному выражению a.*b будет соответствовать всевозможный набор слов начинающихся с символа a и кончающихся символом b, в том числе слова типа abcab. В таких словах есть подпоследовательности символов, которые также удовлетворяют условиям регулярного выражения. Если после каждого из описанных метасимволов поставить знак ?, то подобные последовательности будут опускаться. Шаблоны обрабатываются как строка в двойных кавычках, поэтому приведенные ниже последовательности также будут обрабатываться:
 ?    \l 	 - передвижение на символ вниз    \u  - передвижение на символ вверх    
А также все перечисленные ранее бакслэш-последовательности. В Perl-е определены также:
 ?    \w  - соответствуют алфавитные и цифровые                  	  символы а также символ подчерк    \$W  - соответствуют все символы не входящие           во множество символов w    \s  - символы пробела, табуляции, возврата каретки    \S  - все символы не входящие во множество символов     s    \d  - цифровые символы    \D  - нецифровые символы    
Обратите внимание, что \w отмечает только отдельные символы, а не все слово. Чтобы отметить все слово нужно использовать \w+. Также определены следующие команды:
 ?    \b  - соответствуют границы слова    \B  - соответствуют не-границы слова    \A  - соответствуют только начало строки    \Z  - соответствуют только конец строки    
При использовании конструкции типа ( ... ), \<digit> подставляет подстроку из скобок с номером digit. Можно использовать скобки для отделения подшаблона. Если в скобках имеется более, чем 9 подстрок, то переменные $10, $11, ... содержат соответствующие подстроки. $+ возвращает то, чему соответствует последняя конструкция в скобках. $& возвращает подставленную строку. $` возвращает все перед подставленной строкой, $' возвращает все после подставленной строки.
  $_ = 'abcdefghi';      /def/;      print "$`:$&:$'\n"; - напечатает abc:def:ghi
На этом мы закончим описание регулярных выражений, для более подробной информации читайте manual page.

Зарезервированные переменные



В Perl есть имена имеющие специальное значение. Многие из них аналогичны зарезервированным именам в shell.
Если вы хотите использовать длинные имена переменных, в заголовке программы требуется сказать:
use English;
Многие переменные доступны только для чтения, то есть при попытке присвоения такой переменной какого-либо значения напрямую или по ссылке происходит ошибка. $_В эту переменную по умолчанию происходит ввод, присваивание, в нее складываются результаты поиска по заданному образцу.
  while(<>){...}
или, что то же самое:
  while($_= <>) {...}
$<digit>Эта переменная была описана в предыдущем параграфе. Она доступна только для чтения, так же как и переменные $&, $`, $' и $+. $.Эта переменная содержит номер строки, которая была почитана последней из файла, который был прочитан последним. Она также доступна только для чтения. $/Содержит символ по которому разделяются вводимые записи. По умолчанию содержит символ перевода строки. Она похожа на переменную RS из awk. $|По умолчанию имеет значение 0. Если содержит ненулевое значение, то происходит сброс буферов каждый раз после осуществления вывода (на печать, на экран и т.д.). $,Содержит символ-разделитель полей для оператора печати. Подобна переменной OFS в awk. $Содержит символ-разделитель записей для оператора печати. Подобна переменной ORS в awk. (Вы можете определить $ вместо того, чтобы печатать n в конце печати.) $"Подобна переменной $,. Но используется при обращении к списку величин в двойных кавычках (или другой строке, которая требует интерпретации). По умолчанию содержит символ пробел. $;Содержит символ-разделитель для эмуляции многомерных хэшей. Если ссылаться на такой элемент хэша как $foo{$a,$b,$c} то реально это будет происходить так: $foo{join($;,$a,$b,$c)}. Не путайте с @foo{$a,$b,$c}, так как это тоже самое, что($foo{$a},$foo{$b},$foo{$c}). По умолчанию содержит значение \034 такое же как переменная SUBSEP в awk. $#Формат для печати чисел. Подобна переменной OFMT в awk. Первоначально содержит значение %.20g. $%Содержит номер текущей выводимой страницы. $=Содержит длину текущей страницы (количество печатных срок), обычно содержит значение 60. $-Содержит значение, определяющее количество оставшихся на странице строк, например количество еще не напечатанных строк для печатного канала вывода. $~ Содержит имя текущего формата сообщений. Обычно имя дескриптора файла. $^Содержит имя текущего формата заголовка страницы. Обычно содержит имя дескриптора файла с добавлением в конце _TOP $:Содержит множество символов после которых вывод сроки может быть прерван и начат снова после перевода строки. $!Если эта переменная используется в числовом контексте, то содержит текущее значение errno (номер ошибки) со всеми обычными сообщениями. В строковом контексте содержит соответствующее системное сообщение об ошибке. $@Содержит сообщение о синтаксической ошибке, допущенной во время исполнения последней команды eval(). Если содержит значение 0, то команда была исполнена корректно. Но заметьте, что сообщения не накапливаются в этой переменной. $$Содержит идентификатор текущего процесса. $<Содержит идентификатор пользователя (UID), которому принадлежит текущий процесс. $>Содержит эффективный UID текущего процесса. $(Содержит идентификатор группы (GID) пользователя, которому принадлежит текущий процесс. $)Содержит эффективный GID текущего процесса. $0Содержит имя файла, в котором находится исполняемая программа. $ARGVСодержит имя текущего файла, из которого происходит чтение. @ARGVСодержит массив аргументов командной строки, которые были переданы программе. @INCСодержит список точек входа в программу, в которых используются конструкции do EXPR, require и use. %INCСодержит входы для каждого файла, который включается посредством использования операторов do или require. Ключами являются имена файлов, а значениями места их расположения. %ENVСодержит текущее окружение процесса. Изменением содержимого хэша можно изменить окружение порожденного (дочернего) процесса. %SIGЭтот хэш используется для установки обработчиков различных сигналов. Например:
  sub handler {          local($sig) = @_;          print "Caught a SIG$sig - shutting down\n";          close(LOG);          exit(0);      }          $SIG{'INT'} = 'handler';      $SIG{'QUIT'} = 'handler';      ...      $SIG{'INT'} = 'DEFAULT';      $SIG{'QUIT'} = 'IGNORE';


Встроенные функции



abs VALUEВозвращает абсолютное значение аргумента. accept NEWSOCKET, GENERICSOCKETподобно системному вызову accept(2) ждет соединения. Возвращает запакованный адрес, если соединение произошло успешно и FALSE в противоположном случае. atan2 Y,XВозвращает arctg(Y/X). bind SOCKET, NAMEПривязывает сетевой адрес к сокету, также как системный вызов bind в OS UNIX или любой другой системе, поддерживающей BSD Sockets. Если привязка произошла успешно, возвращает TRUE, в противном случае - FALSE. Переменная NAME должна содержать запакованный адрес, соответствующего для сокета типа. Тип адреса для разных видов сокетов определяется в терминах языка C структурой sockaddr, которая представляет собой абстрактный тип, содержащий все данные, необходимые для сокета. binmode FILEHANDLEПозволяет читать или писать файл с соответствующим дескриптором в бинарном режиме. bless REF, PACKAGEЭта функция присоединяет объект на который указывает ссылка REF, к пакету PACKAGE, если он определен, если же он опущен, то к текущему пакету. Для удобства возвращает ссылку, так как bless() часто является последним оператором в конструкторе. caller EXPRВозвращает контекст текущего вызова подпрограммы. В скалярном контексте возвращает TRUE, если мы находимся внутри подпрограммы, eval() или require(). FALSE в противоположном случае. В списковом контексте возвращает:
  ($package, $filename, $line) = caller;
С аргументом EXPR возвращает более сложную информацию, которая используется отладчиком для печати карты стека. Значение EXPR отмечает глубину стека до текущей записи.
  ($package, $filename, $line,       $subroutine, $hasargs, $wantargs) = caller($i);
chdir EXPRИзменяет текущую директорию на указанную в EXPR, если это возможно. Если EXPR опущено, то устанавливает в качестве текущей директории домашнюю директорию. Возвращает TRUE в случае успеха и FALSE иначе. chmod LISTИзменяет права доступа к файлам указанным в LIST. Первым аргументом должна быть маска доступа в цифровом формате. Возвращает число файлов права доступа к которым были успешно сменены.
  $cnt = chmod 0700 'foo','bar';      chmod 700 @executables;
chown LISTИзменяет хозяина или группу, которой принадлежит список файлов. Первыми двумя аргументами должны быть uid и gid. Возвращает количество успешных изменений. chr NUMBERВозвращает символ, представленный номером NUMBER в наборе символов. Например, chr(65) вернет A. close FILEHANDLEЗакрывает файл с дескриптором FILEHANDLE. Для более подробной информации читайте manual page.
  open(OUTPUT '/usr/home/petrov');      ...      close OUTPUT;
closedir DIRHANDLEЗакрывает каталог открытый вызовом opendir(). connect SOCKET,NAMEПытается соединиться с удаленным сокетом (по аналогии с системным вызовом). Возвращает TRUE в случае успешного соединения и FALSE в противоположном случае. Переменная NAME должна содержать запакованный адрес соответствующего данному сокету типа. cos EXPRВозвращает косинус EXPR, выраженного в радианах. Если EXPR опущено, возвращает косинус $_. dbmopen ASSOC, DBNAME, MODEСвязывает dbm(3) или ndbm(3) файл с ассоциативным массивом. ASSOC - имя ассоциативного массива. DBNAME - имя базы данных (без .dir или .pag расширения). Если база данных не существует, то она создается с правами доступа указанными в MODE.
  dbmopen(%HIST,'/usr/lib/news/history', 0600);      while (($key, $val) = each %HIST){          print $key, '=', unpack('L',$val),\n;}      dbmclose(%HIST);
dbmclose ASSOCПрерывает связь между файлом и ассоциативным массивом. defined EXPRВозвращает TRUE или FALSE, в зависимости от того определено значение EXPR или нет. Многие операции возвращают неопределенное значение в случае конца файла, неинициализированной переменной, системной ошибки или при подобной ситуации. Если речь идет о хэше, то defined покажет только определены ли ли величины, ничего не говоря о существовании ключей. Для определения существования ключей используется функция exists(). delete EXPRСтирает указанную величину. Возвращает удаленную величину или значение не определено в случае, если удаление не произошло.
  foreach $key (keys %array) {         delete $array{$key};      }
Но более быстро то же самое можно сделать используя функцию undef(). die LISTВне eval() печатает значение LIST в STDERR и выходит из программы с текущим значением $!. Если значение $! есть ноль, то принимает значение $? >> 8. Если значение $? >> 8 есть ноль, то принимает значение 255. Внутри eval() сообщение об ошибке помещается в переменную $@ и eval() прерывается с неопределенным значением.
  open(FL, "/root/rm-rf") || die "Can't open file.\n";
do BLOCKФункцией не является. Возвращает значение последней операции внутри блока. do EXPRИспользует величину EXPR как имя файла и далее запускает содержимое этого файла, как программу на Perl. Обычно это используется для включения библиотечных подпрограмм.
  do 'stat.pl';
Это то же самое, что:
  eval 'cat stat.pl';
Однако подключать библиотечные модули более удобно используя use и require. each ASSOC_ARRAYВозвращает массив из двух элементов, содержащий ключ и значение из хэша, причем по очереди перебирает все пары ($key, $value).
  while (($key,$value) = each %ENV){      print " $key = $value \n";      }
eof FILEHANDLEВозвращает 1, если следующее считывание возвращает конец файла или если FILEHANDLE не был открыт. При опущении аргумента eof обрабатывает последний файл, из которого происходило считывание. Но на практике эта функция редко используется, так как в Perl-е операторы чтения возвращают неопределенное значение в конце файла. eval EXPREXPR выполняется как маленькая программа в контексте основной программы. Определенные переменные и подпрограммы остаются определенными и в дальнейшем. Возвращается значение, которое возникает при обработке последнего выражения. Если EXPR опущено, то обрабатывается $_. exec LISTИсполняет внешнюю программу и НИКОГДА не возвращает управление. На самом деле (в UNIX) производится системный вызов семейства exec, который подменяет программу, исполняющуюся в рамках текущего процесса. Если LIST представляет собой список из более, чем одного аргумента, то вызывается execvp(3) с аргументами из LIST. Если аргумент только один, то он проверяется на метасимволы shell. Если они присутствуют, то он далее передается /bin/sh -c для обработки. Если же их нет, то аргумент передается напрямую execvp, который более эффективен. exists EXPRВозвращает TRUE, если в хэше есть ключи и даже в том случае, когда значения VALUE не определены. exit EXPRОбрабатывает EXPR и осуществляет немедленный выход с полученной величиной.
  $ans = <STDIN>;      exit 0 if $ans =~ /^[Xx]/;
Если EXPR опущено, то осуществляет выход с нулевым статусом. exp EXPRВозвращает е (основание натурального логарифма e = 2.718281828...) в степени EXPR. По умолчанию обрабатывается $_. forkДелает системный вызов fork(2). Возвращает pid (идентификатор процесса) дочернего процесса родительскому процессу и 0 дочернему процессу. Значение не определено в случае неуспешного завершения команды. Неуспех может произойти, например, в случае установки в системе ограничения на количество процессов данного пользователя. Вот небольшой пример использования этой функции.
  unless ($pid = fork) {          unless (fork) {              exec "what you really wanna do";              die "no exec";              some_perl_code_here;              exit 0;          }          exit 0;      }      waitpid($pid,0);
getc FILEHANDLEВозвращает следующий символ из файла чтения, присоединенный к FILEHANDLE или пустую строку в случае конца файла. Если FILEHANDLE опущен, то считывание происходит из STDIN. goto LABELЭта функция осуществляет переход на точку программы LABEL и продолжает выполнение программы с этой точки. Точка не может находиться внутри подпрограммы или foreach цикла, так как в этих случаях требуется предварительная инициализация. Использовать в качестве LABEL выражение не рекомендуется, хотя такая возможность и предоставляется. grep BLOCK, LISTgrep EXPR, LISTОбрабатывает BLOCK или EXPR для каждого элемента LIST и возвращает список элементов для которых значение выражения TRUE. В скалярном контексте возвращает число элементов для которых EXPR TRUE. hex EXPRВозвращает десятичное значение EXPR, интерпретируемого как шестнадцатеричная строка. По умолчанию обрабатывает переменную $_. kill LISTПосылает сигнал списку процессов LIST, первым элементом списка должен быть номер сигнала. Возвращает число процессов, которым сигнал был послан успешно. В отличие от shell, если номер сигнала отрицателен, то он посылается группе процессов. int EXPRВозвращает целую часть EXPR, если EXPR опущено, то обрабатывает переменную $_. join EXPR,LISTСоединяет в единую строку строки из LIST. При этом в качестве разделителей между элементами LIST ставит значение EXPR. Например:
  $_ = join( ':',$login,$passwd,      $uid,$gid,$gcos,$home,$shell);
keys ASSOC_ARRAYВозвращает обычный массив, состоящий из ключей ассоциативного массива ASSOC_ARRAY. В скалярном контексте возвращает число ключей.
  @keys = keys %ENV;
length EXPRВозвращает длину EXPR в символах. По умолчанию обрабатывает переменную $_. link OLDFILE,NEWFILEСоздает файл NEWFILE, присоединенный к файлу OLDFILE. (В OS UNIX создание нескольких имен для одного файла) Возвращает 1 в случае успеха и 0 иначе. listen SOCKET, QUEUESIZEДелает то же самое, что и одноименный системный вызов. Возвращает TRUE в случае успеха, FALSE иначе. local EXPRНа самом деле гораздо эффективнее использовать функцию my. Функция local делает перечисленные переменные локальными в блоке, подпрограмме, eval или do. Если переменных более, чем одна, то они должны объединяться скобками.
  sub RANGEVAL{          local($min,$max,$thunk) = @_;          local $result = '';          local $i;          for ($i = $min; $i < $max; $i++) {              $result = eval $thunk;          }          $result;      }
log EXPRВозвращает натуральный логарифм EXPR, по умолчанию обрабатывает переменную $_. map EXPR,LISTПодставляет каждый элемент из списка LIST в EXPR (которое может быть блоком) и возвращает список полученных после обработки величин.
  @chars = map(chr, @nums);
mkdir FILENAME,MODEСоздает директорию с именем FILENAME и правами доступа указанными в переменной MODE. В случае успеха возвращает 1, в противном случае возвращает 0 и устанавливает значение переменной $!(errno). my EXPRЭта функция (так же как и описанная ранее функция local) делает перечисленные переменные локальными в пределах блока, подпрограммы, eval или do. Если список состоит более чем из одного элемента, то он должен быть заключен в скобки. Все элементы в списке должны быть фактическими параметрами. В отличие от local, переменные локализованные функцией my не видны снаружи блока, подпрограммы или другой конструкции, внутри которой my употребляется. next LABELУпотребляется подобно continue оператору в C - запускает следующую итерацию цикла.
   line: while (<STDIN>) {       next line if /^#/;       ...       }
oct EXPRВозвращает десятичное значение EXPR, интерпретируемого как строка в восьмеричном формате. (Если строка начинается с 0x, то интерпретируется, как строка в шестнадцатеричном формате.) open FILEHANDLE,EXPRОткрывает файл, имя которого описано в переменной EXPR и привязывает его к FILEHANDLE. Если EXPR опущено, то переменная с таким же именем как FILEHANDLE содержит имя файла. Если имя файла начинается со знака:
 ?    <  файл открывается на чтение.    >  файл открывается на запись.    >>  файл открывается для добавления.    |   имя файла расценивается как команда,        с которой будет организован программный канал,        то есть вывод в дескриптор FILEHANDLE будет        передаваться на вход программе EXPR.    
Если знак | указывается после имени команды, то вывод этой команды будет ассоциирован с дескриптором FILEHANDLE, из которого будет производиться чтение. Интересно, что нельзя открыть двойной программный канал, то есть ассоциировать ввод и вывод команды с дескриптором файла (что соответствовало бы системному вызову popen в UNIX). В случае, когда имя файла оканчивается вертикальной чертой, оно расценивается как имя команды, вывод которой будет интерпретироваться как ввод из файла (аналог функции popen(3)).
  open(LOG, '>>/usr/spool/news/twitlog');
open DIRHANDLE,EXPRОткрывает директорию с именем EXPR, возвращает TRUE в случае успеха. ord EXPRВозвращает числовое значение в таблице ASCII первого символа EXPR. По умолчанию обрабатывает переменную $_. print FILEHANDLE,LISTПечатает строку или несколько строк, разделенных запятой. FILEHANDLE может быть именем скалярной переменной, содержащей дескриптор файла. Если эта переменная опущена то печать идет в выбранный канал вывода. Если переменная LIST тоже опущена, то печатает переменную $_ в STDOUT. printf FILEHANDLE, LISTЭквивалентно print FILEHANDLE, sprintf(LIST). Первый аргумент LIST интерпретируется как формат печати. rand EXPRВозвращает выбранное случайным способом значение между 0 и EXPR. EXPR должно быть положительным. По умолчанию производит выборку в диапазоне между 0 и 1. (Замечание: если ваша функция постоянно возвращает слишком большие или слишком малые значения, то скорее всего была допущена ошибка при компиляции вашей версии Perl. Было установлено неверное значение RANDBITS.) read FILEHANDLE,SCALAR,LENGTH,OFFSETСчитывает LENGTH байт данных из FILEHANDLE в переменную SCALAR. Возвращает число считанных байт или неопределенное значение в случае ошибки. Если вы хотите считать данные не с начала строки, то для этого нужно установить значение переменной OFFSET. readlink EXPRВозвращает значение символьной ссылки, если она существует. Если же ее нет, то выдает fatal error и устанавливает значение переменной $!. По умолчанию обрабатывает переменную $_. redo LABELПерезапускает цикл без повторной обработки условия. Блок continue, если он есть не исполняется. Если LABEL опущена, то команда выполняется для внутреннего цикла.
  line: while(<STDIN>) {          while ($_ ne '\') {    	if (ord $_ < 86) {    	  ...    	}    	redo line;          }          print;       }
ref EXPRВозвращает TRUE, если EXPR является ссылкой и FALSE в противоположном случае. Полученное значение зависит от типа объекта на который указывает ссылка. Существует несколько встроенных типов данных: Если объект, на который указывает ссылка, находится в пакете (package), то в таком случае возвращается имя пакета.
  if (ref($r) eq "HASH") {          print " Это ссылка на ассоциативный массив.\n";      }      if (!ref($r)) {          print " А это не ссылка вовсе! \n";
require EXPRИспользуется для подключения модулей.
  require "oraperl.pm";
reset EXPRОбычно используется в continue блоке в конце цикла для переустановки значений переменных. EXPR интерпретируется как список отдельных символов. Значения переменных и массивов, имена которых начинаются с одного из этих символов списка переустанавливаются. Например:
 ?    reset 'X'  переустановит все X переменные    reset 'a-z'  переустановит все переменные,    имена которых состоят из маленьких букв.    
rm FILENAMEУдаляет файл или директорию с заданным именем. Возвращает 1 в случае успеха, 0 в противоположном случае и устанавливает значение переменной $!. По умолчанию обрабатывает аргумент $_. scalar EXPRВыражение будет трактоваться в скалярном контексте. Возвращает значение EXPR. seek FILEHANDLE, POSITION, WHENCEПозволяет установить курсор в файле, определенном в переменной FILEHANDLE, на позицию POSITION в режиме, указанном в переменной WHENCE. Если переменная WHENCE содержит значение 0, то позиция отсчитывается от начала файла, если 1 то от текущей позиции и если 2, то от конца файла. Возвращает 1 в случае успеха и 0 иначе. select FILEHANDLEВозвращает текущий выбранный FILEHANDLE. Направляет вывод в FILEHANDLE. select RBITS,WBITS,EBITS,TIMEOUTВызывает системный вызов select(2) с определенной аргументами битовой маской. shift ARRAYСдвигает массив ARRAY влево с удалением первого элемента и возвращает удаленный элемент. Если в массиве нет элементов, то возвращает неопределенное значение. Если ARRAY опущен, то обрабатывает массив @ARGV в главной программе и массив @_ в подпрограммах. sin EXPRВозвращает синус выражения EXPR (выраженного в радианах). Если аргумент опущен, то обрабатывается переменная $_. sleep EXPRДает процессу команду остановки на EXPR секунд. Если аргумент опущен, то процесс зависает навсегда. В таком случае ``сон'' можно прервать, послав ему сигнал. Возвращает число секунд, в течение которых процесс был в состоянии остановки. socket SOCKET,DOMAIN,TYPE,PROTOCOLСоздает сокет и привязывает его к дескриптору файла SOCKET. Остальные параметры описываются так же, как и в одноименном системном вызове. В начале программы необходимо написать use Socket;. sort SUBROUTINE,LISTСортирует аргументы из LIST и возвращает отсортированный список. Если список является массивом, то несуществующие элементы массива не учитываются и не возвращаются. Ниже приведено несколько примеров.
    @articles = sort @files;
- Лексическая сортировка без использования подпрограммы.
  @articles = sort{$a cmp $b} @files;
- То же самое, но с использованием подпрограммы.
  @articles = sort{$a <=> $b} @files;
- Численная сортировка по возрастанию. splice ARRAY,OFFSET,LENGTH,LISTУдаляет из массива ARRAY элементы, отмеченные в переменных OFFSET и LENGTH и заменяет их элементами списка LIST, если таковые имеются. Возвращает удаленные из массива элементы. Длина массива растет или уменьшается, если это необходимо. Если переменная LENGTH опущена, то удаляет все, начиная с OFFSET. split /PATTERN/,EXPR,LIMITРазбивает строку на массив строк и возвращает его. В скалярном контексте возвращает число полученных полей и помещает полученный массив в @_. Если EXPR опущено то разбивается строка $_. Если PATTERN тоже опущен, то разбиение происходит по символу пробел. Символы, указанные в PATTERN, служат разделителями для полей. Разделители могут быть длиннее, чем один символ. Если переменная LIMIT задана и имеет неотрицательное значение, то разбиение будет происходить на число полей не более указанного в LIMIT. Если переменная не определена, то пустые поля отбрасываются, если имеет отрицательное значение, то это интерпретируется Perl-ом, как отсутствие ограничения на длину возвращаемого массива. Если шаблону соответствует пустая строка, то EXPR будет разбито на отдельные символы. Например:
  print join(':',split(/ */,'hi there'));
напечатает строку h:i:t:h:e:r:e. sqrt EXPRВозвращает корень квадратный из значения EXPR. По умолчанию обрабатывает переменную $_. system LISTДелает то же самое, что и функция exec LIST, за одним исключением: вместо того, чтобы просто начать выполнять программу , как это делает exec, system делает fork и порождает еще один процесс, причем родительский процесс ждет завершения дочернего. tell FULEHANDLEВозвращает текущую позицию курсора в файле FILEHANDLE. Если аргумент опущен, то обрабатывает файл, который читался последним. tie VARIABLE,PACKAGENAME,LISTПривязывает переменную к пакету, который будет заносить значения в эту переменную. Переменная VARIABLE содержит имя переменной, переменная PACKAGENAME содержит имя пакета. Дополнительные аргументы передаются методу new этого пакета. Обычно это такие аргументы, которые в дальнейшем могут быть переданы в качестве параметров dbm_open() функции из C.
  tie(%HIST, NDBM_File,'/usr/lib/news/history', 1, 0);      while(($key,$val) = each %HIST) {          print $key, '= ', unpack('L',$val),"\n";      }      untie(%HIST);
Пакет, реализующий ассоциативный массив, должен содержать следующие методы:
TIEHASH objectname, LIST
DESTROY this
FETCH this, key
STORE this, key, value
DELETE this, key
EXISTS this, key
FIRSTKEY this
NEXTKEY this, lastkey
Пакет, реализующий обычный массив, должен содержать следующие методы:
TIEARRAY objectname, LIST
DESTROY this
FETCH this, key
STORE this, key, value
Пакет, реализующий скаляры, должен содержать следующие методы :
TIESCALAR objectname, LIST
DESTROY this
FETCH this
STORE this, value
truncate FILEHANDLE, LENGTHОбрезает файл FILEHANDLE до заданной длины. undef EXPRДелает значение EXPR неопределенной величиной, в случае, когда аргумент опущен ничего не меняет. Не следует пытаться применять эту функцию к зарезервированным переменным, потому что результат может оказаться непредсказуемым. unlink LISTУдаляет список файлов и возвращает число удачно удаленных файлов. Если вы не являетесь суперпользователем, то эта функция не может удалять каталоги. Даже в случае, когда программа запускается с привилегиями суперпользователя, будьте осторожны, лучше использовать функцию rmdir. untie VARIABLEРазрывает связь между переменной и пакетом. unshift ARRAY, LISTПроизводит действие противоположное действию функции shift. Присоединяет LIST к началу массива ARRAY и возвращает новое количество элементов в массиве. use Module LISTОсуществляет присоединение модуля к программе.
  use strict qw(subs,vars,refs);
values ASSOC_ARRAYВозвращает обычный массив, состоящий из значений ассоциативного массива ASSOC_ARRAY. В скалярном контексте возвращает число элементов полученного массива. Элементы массива могут располагаться в произвольном порядке. wantarrayВозвращает TRUE, если контекст исполняющейся подпрограммы списковый, FALSE в противоположном случае. writeсоздает запись (возможно состоящую из нескольких строк) в соответствующем файле, используя формат ассоциированный с этим файлом. Формат для текущего канала вывода может быть установлен посредством присваивания переменной $~{ } имени формата.

Подпрограммы и модули





Подпрограммы



Описать и использовать подпрограмму можно несколькими способами:
  1. sub NAME; - подразумевает описание в дальнейшем тела подпрограммы.
  2. sub NAME BLOCK - непосредственное описание.
  3. $subref = sub BLOCK - анонимное описание.
  4. use PACKAGE qw(NAME1, NAME2, NAME3) - включение подпрограмм из модулей.
Вызвать подпрограмму можно тоже несколькими способами:
  1. &NAME(LIST) - скобки обязательны для & формы.
  2. NAME(LIST) - & не обязательно со скобками.
  3. NAME LIST - скобки можно опустить в случае предварительного описания или включения подпрограммы из модуля.
Аргументы передаются подпрограмме в виде локального массива @_, его элементы являются ссылками на реальные скалярные параметры. Подпрограмма возвращает значение, полученное в результате исполнения последнего оператора подпрограммы. Как уже говорилось, подпрограмма вызывается использованием префикса & перед ее именем, в Perl 5 этот префикс не обязателен. Пример:
  sub MAX {          my $max = pop(@_);          foreach $foo (@_) {              $max = $foo if $max < $foo;          }          $max;      }      ...      $bestmark = &MAX(1,2,3,4,5);
Подпрограмма может вызываться рекурсивно. Если подпрограмма вызывается с использованием & формы, то список аргументов необязателен. Если вы хотите создать внутри модуля его собственную, невидимую снаружи подпрограмму, то описание должно быть анонимным:
  my $subref = sub {...}      &$subref(1,2,3);


Пакеты



Perl поддерживает механизм альтернативного именного пространства для каждого отдельного пакета. Обычная программа является пакетом с именем main. Можно ссылаться на переменные или дескрипторы файлов из других пакетов посредством использования префикса перед именем переменной, состоящего из имени пакета и двойного двоеточия: $Package::Variable. Если имя пакета нулевое, то предполагается использование переменной из main пакета. То есть $::sail эквивалентно $main::sail. Пакеты могут включать в себя другие пакеты, в таком случае чтобы обратиться к переменной нужно применить описанное обозначение рекурсивно: $OUTER::INNER::var.
В пакете могут содержаться только переменные, чьи имена начинаются с буквы или подчерка, остальные переменные содержатся в пакете main. Кроме того зарезервированные переменные, как то STDIN, STDOUT, STDERR, ARGV, ARGVOUT, ENV, INC и SIG также содержатся в главном пакете.
package mypack;    sub main::mysub {        ...    }

Таблицы символов



Таблицы символов пакета хранятся в ассоциативном массиве с тем же именем и двойным двоеточием в конце. Для пакетов включенных в пакет имя символьной таблицы составляется аналогичным образом: %OUTER::INNER::.

Конструкторы и деструкторы пакетов



Существует две функции специального вида - конструкторы и деструкторы. Это BEGIN и END программы в их описании необязательно использование sub. Подпрограмма BEGIN исполняется сразу, как только это возможно, то есть в момент, когда она полностью определена, даже перед тем как обрабатывается остаток содержащего файла. В файле может быть несколько блоков BEGIN. Они исполняются в порядке определения.
Подпрограмма END исполняется в самом конце. В файле может содержаться несколько END блоков, они исполняются в обратном порядке.

Классы



В Perl 5 нет специального синтаксиса для описания классов, но пакеты могут функционировать как классы, если они содержат подпрограммы функционирующие как методы. Такие пакеты могут также брать некоторые методы из других пакетов-классов. Для этого необходимо перечислить имена других пакетов в массиве @ISA.

Модули



В Perl 5 понятие пакетов расширено в понятие модулей. Модули это пакеты находящиеся в одноименном файле, включенном в библиотеку. Модули подключаются следующим образом:
  use Module; или use Module LIST;
Это эквивалентно:
  BEGIN { require "Module.pm"; import Module; }
Все модули имеют расширение .pm. Если именное пространство модуля пересекается с именным пространством основной программы то всегда используется use, если не пересекается то можно использовать require.
Стандартные модули Perl описаны в документации.