* Встроенные функции *
Встроенные функции используются как термы выражений и
подразделяются на две категории: списковые операторы и унарные
операторы. Это влияет на их приоритет по отношению к оператору
',' - запятая. Списковые операторы могут именть множество
(список) аргументов, а унарные только один. Таким образом
запятая завершает аргументы унарного оператора и разделяет
аргументы спискового.
Аргумент унарного оператора воспринимается обычно в
скалярном контексте а спискового как в скалярном так и
списковом причем скалярные аргументы идут первыми. В дальнешем
списковые аргументы мы будем обозначать словом 'LIST' это
значит что функция имеет список аргументов разделенных запятой.
Аргументы функций можно заключать в круглые скобки и таким
образом обозначать что "это функция" и приоритет не имеет
значения иначе это списковый или унарный оператор с
определенным фиксированным приоритетом. Пробел после имени
функции и скобкой значения не имеет. Поэтому будьте
внимательны!
Пример:
print 1 + 2 + 3; # результат 6
print(1+2)+3; # результат 3
print (1+2)+3; # опять 3
print (1+2+3); # 6
Если функция возвращает результат как в скалярном так и в списковом контексте
то код выхода по ошибке - скаляр c неопределенным значением или пустой
список.
Запомните правило:
Не существует общего правила преобразования списка в скаляр!
Каждый оператор и функция имеют свой вид значения в скалярном котексте.
Для одних это количество элементов из скалярного контекста. Для других
первый элемент списка или последний или количество
успешных операций. Каждый свое если вы специально не указываете.
-X указатель файла
-X выражение
-X
Проверка файла, где 'X' одно из ниже описанных значений.
Это унарный оператор с одним аргументом - либо именем файла либо
указателем файла. Проверяет одно из условий. Если аргумент не указан
то берется значение переменной $_. Для ключа -t STDIN.
Результат 1 если true и '' если false или неопределенное значение
если файл не найден. Несмотря на странный вид это унарный оператор
с соответсвующим приоритетом. Аргумент можно заключать в круглые скобки.
'X' имеет следующие значения:
-r Файл разрешен на чтение эффективным uid/gid
-w на запись -//-
-x исполнение -//-
-o принадлежит эффективному uid (идентификатор пользователя)
-R Файл разрешен на чтение реальным uid/gid
-W на запись -//-
-X исполнение -//-
-O принадлежит реальному uid
-e файл существует
-z пустой
-s не пустой
-f обычный текст
-d директория
-l символическая ссылка
-p pipes (конвейер)
-S socket (гнездо)
-b специальное блочное устройство
-c -//- символьное -//-
-t указатель на уст-во tty
-u установлен бит setuid
-g -//- setgid
-k -//- sticky
-T текстовой файл
-B двоичный
-M "возраст" файла в днях на момент старта скрипта
-A дней с последнего чтения
-C дней с последней модификации inode
Абсолютное значение выражения
Окрыть новый сокит по внешнему запросу. Аналогично
системному вызову accept(). Возвращает адрес или false в случае
неудачи.
Послать сигнал SIGALARM текущиму процессу
по истечении указанного промежутка времени. Не допустимо делать
несколько вызовов одновременно в одном промежутке времени.
Возвращает остаток времени предыдущего счетчика.
Арктангес отношения Y к X в пределах от -pi до +pi.
Назначить сетевой адрес сокиту. Подобно системному
вызову bind. Возвращает true в случае успеха и false иначе.
Имя - пакетный адрес сокита.
Открыть файл для двоичного (binary) режима доступа.
В обычном режиме при вводе символы CR LF транслируются в LF,
а при выводе LF транслируется в CR LF.
bless ссылка
Данная функция определяет что объект указанный ссылкой
принадлежит классу. Если класс не указан то он относится к текущему
классу. Обычно это последний оператор в конструкторе объекта.
Необходимо обязательно указывать имя класса если определяемый
объект может наследоваться классом-потомком.
caller
Возвращает контекст вызова текущей подпрограммы.
В скалярном контексте true если это подпрограмма или процедура
вызванная операторами eval() или require() и false - иначе.
В списковом это список ($package, $filename, $line)
где
$package - имя пакета
$filename - имя файла пакета
$line - номер строки откуда был сделан вызов.
Если указано выражение то возвращается список:
($package, $filename, $line, $subroutine, $hasargs, $wantargs)
Выражение определяет "глубину" вложенности просмотра стека вызовов.
$subroutine - имя подпрограммы
$hasargs - имеющиеся аргументы
$wantargs - необходимые аргументы
Применение данной функции в DB пакете возвращает более детальную
информацию. К списку аргументов добавляется список @DB::args.
Перейти в директорию указанную выражением. Если
выражение отсутсвует то перейти в "домашнию" директорию.
Возвращает true в случае успеха и false - неудачи.
Изменить права доступа к файлам указанным в списке.
Первый элемент в списке - числовое ,обычно восьмеричное значение прав.
Возвращает количество файлов которым были изменены права.
Пример: chmod 0666 'f1', 'f2', 'f3';
chomp список
chomp
Удаляет в конце строки символ указанный переменной $/.
Обычно это 'LF'. Возвращает количество удаленных символов.
Если переменная не указана то используется переменная $_.
Если указан список то обрабатывается каждая строка списка и
возвращается общее количество удаленных символов.
chop список
chop
Полностью аналогично функции chomp но всегда удаляет
последний символ строки.
Изменить "владельца" и "группу" файлов списка.
Первый элемент - номер нового владельца, второй номер новой группы
а далее список файлов.
В большинстве Юникс-систем вы не сможете сменить владельца если вы
не суперпользователь, но можете изменить группу если это одна из
ваших "вторичных" групп.
Возвращает символ с указанным кодом кодировки.
Сделать "корневой" указанную директорию.
"Корневая" - значит внутри программы на нее можно ссылаться как '/'.
Закрыть открытый файл или поток. Можно не использовать
если один и тот же файл открывается повтортно т.к. он будет
автоматически закрываться новым вызовом open().
Закрыть директорию открытую функцией opendir().
Связаться с удаленным сокитом. Данная функция подобна
системному вызову connect(). Возвращает true в случае успеха
и false при ошибке.
Косинус выражения в радианах.
Шифрация текта. Аналогично системному crypt().
Закрывает связь между хеш и базой данных.
Ассоциировать указанный хеш и базу в определенном режиме.
Дело в том что в Пел реализован очень удобный механизм работы
с базами данных типа dbm, ndbm, sbdm, gdbm и Berkeley DB. Для этого нужно
связать (открыть) базу под именем хеша. Вся работа с записями
базы выполняется так будто это обычный хеш (ассоциативный массив).
Более подробно смотрите описание функции AnyDBM().
Возвращает true если значение определено (существует)
и false если нет. Многие операции завершаются не определенным
значением, например чтение после конца файла, использование
не определенных переменных, системные ошибки и т.д.
Данная функция позволяет различать нулевое и не определенные
значения, определенность или не определенность функций или
ссылок. При использовании определенности ключа в хеше
она возвращает определен данный ключ или нет но не существует
он или нет.
Удалить значение из хеша. Возвращает удаляемое значение
или не определенность если ни чего не удаляется.
Удаление из массива окружения $ENV{} - изменяет окружение.
Удаление из хеша связанного с базой данных - удаляет запись в
базе данных.
Если программа не была запущена из eval() данная
функция выводит список в поток STDERR и завершает работу
программы с кодом из переменной $!. Если $! содержит 0
то с кодом ($? >> 8). Если и это 0 то с кодом 255.
При вызове из eval() сообщение об ошибке заносится в переменную $@
и eval() завершается с неопределенным значением. Это позволяет
отробатывать ошибочные ситуации не завершая головной модуль.
Если строка из списка не завершается символом '\n' то дополнительно
печатается номер строки скрипта откуда вызвана функция и номер
входной строки исли таковой имеется.
Это не совсем функция. Здесь возвращается значение
последнего оператора блока. Когда используется циклический модификатор
BLOCK исполняется перед проверкой условия цикла в отличии от обычных
циклов.
Устаревший метод вызова подпрограмм.
Значение выражения воспринимается как имя файла Пел скрипта.
Изначально это применялось для включения подпрограмм библиотеки.
Сейчас правильней использовать вызовы use() и require() которые
обеспечивают контроль ошибок и завершения.
Выполнние "дампа" текущей памяти. Применялось для
возможности исрользовать программу undump что бы включить текущий
исполняемый код в программу после инициализации всех переменных.
Выполнение этой новой программы будет начинаться оператором
goto метка. Если метка опущена то запуск сначала.
Внимание! Файлы открытые до момента дампа не будут открытыми
в момент исполнения новой программой.
Возвращает 2-элементный массив. Первый элемент - ключ
второй - значение следующего элемента хеша. Позволяет
"просматривать" все значения хеша в определенном порядке.
Сброс переменной цикла происходит только после прохлждения всего
массива.
eof()
eof
Возвращает 1 если выполняется чтение после конца или
чтение из не открытого файла. Аргументом должно быть выражение
возвращающее существующий указатель файла. Данную функцию нельзя
использовать для чтения файлов открытых как терминалы.
Если аргумент не указан то используется последний читаемый файл.
Использование в форме eof() целесообразно применять в циклах
while(<>) для определения конца только последнего файла из
списка. Применяйте eof(ARGV) или eof для определения конца
каждого файла из списка.
eval блок
Выражение сканируется и выполняется как обычная Пел программа.
Это делается в контексте текущей программы поэтому можно использовать
уже определенные переменные и подпрограммы.
Ворзвращается результат последнего оператора в блоке или значение
оператора return. Если обнаружится синтаксическая ошибка или выполнится
оператор die возвращается не определенное значение а переменная $@
содержит сообщение об ошибке. Если ошибки не было то $@ содержит
нулевую строку. При отсутсвии аргумента берется значение переменной $_.
Выполняется системная команда из списка и выполнение
программы завершается. Если вам необходимо вернуться то лучше
применяйте функцию system(). Если в списке количество аргументов
больше 1 или список это массив с количеством элементов больше 1
то выполняется системный вызов execvp() с аргументами из списка.
Если один скалярный аргумент то он сканируется на обработку
метасимволов и если они присутсвуют то полученные аргуметы
передаются интерпретатору /bin/sh -c для дальнейшей обработки.
Если метасимволов нет то аргумент расщепляется на слова и передается
системному вызову execvp() что более эффективно.
Внимание! exec() и system(0) не сбрасывают буфер ввода/вывода
поэтому необходимо установить переменную $| для предотвращения
потери выходной информации.
Возвращает true если существует указанный ключ хеша
даже если не определено его значение.
Выполнение программы завершается с кодом выражения.
Возвращает e (основание натурального логарифма) в степени
выражения.
Выполняет системный вызов fcntl(). Для использования
обязательно выполнить use Fcntl;
Возвращает описатель файла для данного указателя файла.
Системный вызов flock()
Системный вызов fork(). Возвращает pid потомка для родителя
и 0 для потомка в случае успеха иначе - неопределенное значение.
Декларативная функция Пел. Определяет формат вывода для
оператора write. Подробно смотрите главу Форматы.
Внутренняя функция используемая в format. Форматирует
вывод параметров из списка. Результат помещается в переменную $^A
Функция write просто выводит значение этой переменной, но ее так же
можно читать а затем обнулять. Обычно format выполняе один вызов
formline для одной строки формы, но formline не разделяет строки
формата. Это значит что символы '~' и '~~' рассматривают весь
формат как одну строку поэтому необходимо использовать многострочные
формыд для описания одной записи формата.
getc
Читает и возвращает символ из указанного файла.
Если файл не указан то читается STDIN. После конца файла возвращает
пустую строку.
Возвращает текущий login из файла /etc/utmp
Не применяйте для идентификации пользователя он не так сильно
"закрыт" как getpwuid().
Возвращает упакованный адрес удаленного сокита.
Возвращает группу процесса с указанным PID. Если
аргумент отсутсвует возвращает группу текущего процесса.
Возвращает PID родительского процесса.
Возвращает текущий приоритет процесса, группы процессов
или пользователя.
getpwnam NAME
getgrnam NAME
gethostbyname NAME
getnamebyname NAME
getprotobyname NAME
getpwuid UID
getgrid GID
getservbyname NAME, PROTO
gethostbyaddr ADDR, ADDRTYPE
getnetbyaddr ADDR, ADDRTYPE
getprotobynumber NUMBER
getservbyport PORT, PROTO
getpwent
gethostent
getnetent
getprotoent
getservent
setpwent
setgrent
sethostent STAYOPEN
setnetent STAYOPEN
setprotoent STAYOPEN
setservent STAYOPEN
endpwent
endgrent
endhostent
endnetent
endprotoent
endservent
Все эти функции анологичны одноименным системным вызовам.
В списковом контексте возвращают следующие списки:
($name, $passwd, $uid, $gid, $quota, $comment, $gcos, $dir, $shell) = getpw*
($name, $passwd, $gid, $members) = getgr*
($name, $aliases, $addrtype, $length, @addrs) = gethost*
($name, $aliases, $addrtype, $net) = getnet*
($name, $aliases, $proto) = getproto*
($name, $aliases, $port, $proto) = getserv*
В скалярном контексте возвращается имя или что-то другое в зависимости
от типа функции.
Элемент $members в вызове getgr содержит разделенные пробелом имена
членов группы.
@addrs содержит IP адреса компьютеров в сети Интернет в упакованном виде.
Для распаковки применяйте: ($a, $b, $c, $d) = unpack('C4',$addr[0]);
Возвращает упакованный адресс сокита локальной машины.
Возвращает опцию сокита.
Возвращает список файлов удовлетворяющих выражению с '*'
как в команде ls.
Переводит местное время полученное функцией time() во время
по Гринвичу.
Обычно используется в виде:
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst)=gmtime(time);
goto выражение
goto &подпрограмма
Бузусловный переход на метку. Нельзя делать переход на
метку в структуру которая должна быть инициирована например подпрограмму
или цикл foreach и т.д.
Вторая форма применяется для динамического определения перехода.
Например:
goto ('метка1', 'метка2', 'метка3')[$i];
Здесь при $i = 0 будет переход на 'метка1', $i = 1 на 'метка2' и т.д.
Третья форма (goto &подпрограмма) довольно "хитрый" метод подмены
имени вызываемой подпрограммы именем текущей. Это используется
в методе автозагрузки когда нужно запустить другую процедуру
но под именем текущей как-будто та была вызвана раньше.
grep выражение, список
Выполнят блок или выражение для каждого элемента списка.
Переменная $_ содержит текущий элемент.
Возвращает список элементов с которыми выражение дало результат true.
В скалярном контексте возвращает количество результатов true.
Воспринимает выражение как строку шестнадцетиричных цифр
и возвращает десятичное значение.
В Пел нет встроенной функции import, но есть метод
с помощью которого модули могут экспортировать область имен
другим модулям. Подробно смотрите функцию use().
index строка, подстрока
Возвращает позицию первого вхождения подстроки в строке
начиная с указанной позиции. Если позиция отсутсвует то сравнение
начинается с начала строки. Отсчет позиции ведется с 0 если только
не изменено значение встроеной переменной $[. Если подстрока не
найдена то результат меньше первой позиции на 1. Обычно это -1.
int выражение
Возвращает целую часть выражения.
Выполняет системный вызов ioctl(). В начале программы
необходимо указать: require "ioctl.ph";
Соединяет строки списка или массива в одну строку
с кодом разделителя равному выражению.
Возвращает массив всех ключей хеша. В скалярном
контексте - количество ключей. Порядок следования ключей
аналогичен порядку в each фунуции.
Послать сигнал (первый элемент) указанным в списке
процессам. Возвращает количество процессов которые сигнал приняли.
last
Функция аналогичная break в С. Прерывает цикл и переходит
на указанную метку. Если метки нет на ближайший внешний цикл.
Блок continue не выполняется.
Преобразовать строку в буквы нижнего регистра.
Заменить первую букву строки на малую.
Возвращает длину строки выражения.
Создать файл NEWFILE связанный с файлом OLDFILE.
Выполнить системный listen().
Объявляет перечисленные переменные как локальные в текущем
блоке или подпрограмме. Если указано два и более имени их
необходимо заключить в круглые скобки. Предпочтительней использовать
функцию my().
Преобразовать 9-элементный массив возвращаемый фугкцией
time относительно местного времени. Употребляется как:
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst)=localtime(time);
Возвращает натуральный логарифм выражения.
lstat выражение
То же что и системный вызов stat() но касательно ссылки
на файл а не самого файла.
Оператор соавпадения. Смотри главу "Операторы"
map выражение, список
Выполняет блок или выражение для каждого элемента списка.
Возвращает список результатов.
Создать директорию с указанными правами доступа. Возвращает
1 при успехе и 0 при неудаче.
Системный вызов msgctl() System V
Системный вызов msgget() System V
Системный вызов msgsnd() System V
Системный вызов msgrcv() System V
Объявляет локальными переменные в списке.
Если два или более имени их необходимо заключить в круглые скобки.
next
Аналогичен continue в С. Переход к следующей итерации в цикле.
Если в цикле присутсвует блок continue он так же выполняется.
Если метка отсутсвует - переход на ближайший внутренний цикл.
Исключить использование указанных модулей.
Возвращает десятичное число представленное восьмеричными цифрами.
open файл
Открыть файл с указанным именем. Аргумент "файл" - это
фактически указатель на блок описания файла. Если имя (выражение)
файла отсутсвует то имя считается таким же как и указатель файла.
Если перед именем стоит символ '<' то файл открывается только
на чтение (значение по умолчанию). Если '>' - на запись.
Если '>>' - на добавление записей. '+>' или '+<' - файл открыт
на чтение и запись одновременно.
Если имя файла начинается с символа '|' то имя считается системной
командой на вход которой выводятся данные (поток).
Имя '-' - стандартный вход (STDIN), '>-' - стандартный вывод (STDOUT).
Функция возвращает true при успехе и false - неудаче.
Если имя (выражение) начинается с символов ">&" то остаток
имени считается именем указателя файла который окрывается повторно.
Символ '&' может стоять после '<', '>>', '+>', '+>>' и '+<'.
Режим повторного открытия должен соответсвовать первому.
Выражение вида "<&=N" где N -число, эквивалентно системному вызову
fdopen().
Если имя "|-" или "-|" то происходит "расщепление" (fork) процесса
на потомка и родителя. При этом возвращается номер процесса потомка
(PID) внутри родительского процесса и 0 - внутри потомка. При этом
запись/чтение в файл родительским процессом воспринимается как
чтение/запись потомком. Для потомка это стандартный ввод/вывод.
Родительский процесс ждет завершения потомка после закрытия потока
и получает код завершения в переменной $?.
Имя файла не должно содержать пробелов как в начале так и в конце.
Открыть директорию с именем выражения для обработки
функциями readdir(), telldir(), seekdir(), rewinddir() и closedir().
Возвращает true при успехе.
Возвращает ascii код первого символа выражения.
Упаковывает список в двоичную структуру по шаблону.
Шаблон - это строка символов описывающая порядок и тип упакованных
значений.
A - текстовая строка, добавляется пробелами.
a - текстовая строка, добавляется 0 символом.
b - битовая строка (возрастающая нумерация бит)
B - битовая строка (убывающая нумерация бит)
h - шестнадцатеричная строка ( младший байт - первый)
H - шестнадцатеричная строка (старший байт первый)
c - символ со знаком
C - символ без знака.
s - короткое целое (один байт) со знаком.
S - короткое целое без знака.
i - целое (два байта) со знаком.
I - целое без знака.
l - длинное целое (4 байта) со знаком.
L - длинное целое без знака.
n - короткое в "сетевом" формате.
N - длинное в "сетевом" формате.
v - короткое в "VAX" формате.
V - длинное в "VAX" формате.
f - single float.
F - double float.
p - указатель на строку ограниченную 0.
P - указатель на структуру с фиксированной длиной.
u - упаковка uuencode.
x - нуль-байт
X - резервный байт.
@ - заполнить нулями позицию.
За каждой буквой может стоять число означающее количество повторов.
Для всех типов за исключением 'a', 'A', 'b', 'B', 'h' и 'H',
упаковывается максимально возможное количество значений из списка.
Символ '*' после типа означает использовать оставшиеся параметры.
Тип 'a' и 'A' использует только одно значение из списка и добавляет
остаток поля либо нуль-символами либо пробелами (при распаковке
по типу 'A' пробелы и нули отбрасываются, а по 'a' - нет).
Типы 'b' и 'B' упаковывают строку в указанное число бит.
Так же как и 'h' и 'H' в число ниблов (байт).
'P' - упаковывает указатель на структуру с указанной длиной.
Числа с плавающей запятой (floats и double) записываются в
стандартном для каждой машины формате и могут быть разными
для разных типов машин. Заметьте, что Пел всегда использует
двойную точность (double) поэтому упаковка и распаковка по
типу 'f' приведет к потере точности.
Шаблоны для распаковки и упаковки совершенно одинаковы.
Примеры:
print(pack("ccc",65,66,67)); # Результат ABC
print(pack("A4A3","ab","cdefg")); # "ab cde"
print(pack("a4a3","ab","cdefg")); # "ab\0\0cde"
Аналогичен системному pipe().
Удаляет и возвращает последний элемент массива.
Длина массива уменьшается на 1. Результат не определен если массив
пустой. Если имя массива отсутсвует то извлекает из @ARGV
для головной программы и @_ для полпрограммы.
Возвращает смещение от последнего m//g поиска.
print список
print
Выводит строку или список строк в файл. Возвращает true
при успехе. Аргумент файл может быть скалярной переменной содержащей
имя указателя файла если он отсутсвует то осуществляется вывод
в стандартный выходной поток STDOUT (если не было вызова select()).
Если список отсутсвует то выводится значение переменной $_.
Для вывода по умолчанию в другой файл необходимо использовать
функцию select().
Так как print работает в списковом контексте, то все элементы списка
так же вычисляются в списковом контексте т.е. функции будут возвращать
списковые значения. Аргументы можно заключать в круглые скобки.
Если указатель файла - элемент массива то элемент нужно заключить
в фигурные скобки для вычисления блока.
printf список
Аналогичен вызову "print файл sprintf(список)".
Первый элемент списка должен быть форматом printf() как и в С.
Добавить элементы массива значениями из списка.
Длина массива увеличивается на количество элементов списка.
qq/строка/
qx/строка/
qw/строка/
Обычные операторы строк. Смотри главу Операторы.
Вычисляет выражение в котором метасимволы рассматриваются
как обычные символы.
rand
Возвращает случайное число в диаппазоне между 0 и выражением.
Если выражение отсутсвует - между 0 и 1. Данная псевдослучайная
последовательность сбрасывается функцией srand().
read файл, скаляр, длина
Прочитать указанное число байт из файла в скалярную переменную.
Возвращает количество прочитаных байт или неопределенность при
ошибке. Длина скаляра станет равной количеству считанных байт. Смещение
указывают если данные нужно поместить не с самого начала строки.
Возвращает имя следующего файла в директории открытой командой
opendir(). В скалярном контексте возвращает все оставшиеся имена
файлов. Если файлов больше нет то возвращает неопределенность в
скалярном контексте и пустую строку в списковом.
Возвращает значение символической ссылки. При ошибке
возвращает неопределенное значение.
Получить сообщение из сокита. Аналогичен системному recvfrom().
redo
Перейти к началу блока минуя вычисление условия и блока
continue. Если метка отсутсвует то переход к ближайшему внешнему
блоку.
Возвращает true если выражение это ссылка иначе - false.
Возвращаемое значение зависит от типа ссылки. Существуют
следующие типы ссылок:
REF, SCALAR, ARRAY, HASH, CODE, GLOB
Если аргумент - ссылка на класс то возвращается имя класса.
Функция ref() аналогична функции typeof().
Переименовать файл. Возвращает 1 в случае успеха иначе 0.
require
Если выражение - число, требует что бы текущая версия
Пел была не ниже указанной. Если строка - считывает библиотечный файл
с указанным именем если он еще не прочитан.
Последний оператор библиотечного файла должен возвращать true.
Обычно это строка вида 1;
Если расширение имени файла отсутсвует то по умолчанию принимается ".pm"
В данной функции можно указывать путь расположения файла, а если
библиотека расположена в стандартной системной области Пел то вместо
require предпочтительней использовать use().
reset
Обычно используется в блоках continue циклов для
очистки переменных и поиска для повторного применения.
Выражение воспринимается как список символов. Для указания
диаппазона можно применять символ минус '-'.
Все переменные и массива начинающиеся с этих символов
обнуляются. Если выражение отсутсвует то обнуляестя поиск
?шаблон? для повторного поиска. Сбрасываются только
переменные текущего модуля.
Пример:
reset 'a'; # очистить все переменные начинающиеся
# буквой 'a'
reset 'a-z' # все переменные с малых букв.
Выражение вида: 'A-Z' употреблять не рекомендуестя т.к.
обнуляются важные массивы @ARGV и @ENV.
Выход из подпрограммы с указанным кодом. Если данная
функция отсутсвует то выход из подпрограммы осуществляется с
кодом последнего выполненного оператора.
В списковом контексте возвращает список с элементами
в обратном порядке указанному списку. В скалярном контексте
возвращает строку спереставленными символами первого элемента
списка.
Устанавливает указатель файлов открытой директории
в начало для последующего чтения функцией readdir().
rindex строка, подстрока
Подобна функции index , но возвращает позицию последнего
вхождения подстроки в строку. Если указана позиция, то просмотр
выполняется до нее.
Удалить указанную директорию если в ней нет никаких файлов.
Возвращает 1 при успехе и 0 при не удаче. При этом переменная $!
содержит код (errno).
Вычисляет выражение в скалярном контексте и возвращает
результат. В Пел нет специальной функции для принудительного
вычисления в списковом контексте т.к. для достаточно заключить
его в круглые скобки.
Установить указатель на произвольную позицию в файле.
Если отсчет равен 0 - позиционировать от начала файла, если 1 - от
текущего положения, 2 - от конца файла. Возвращает 1 при успехе
и 0 - неудаче.
Установить указатель файла в открытой директории для
последующего чтения функцией readdir(). Текущая позиция
может быть получена функцией telldir().
select
Возвращает текущий указатель файла- по умолчанию
или делает текущим указанный. Таким образом если в функциях
print или write не указан файл вывода то это осуществляется
в файл указанный select. Переменные связанные с выводом так же
действуют на вывод в этот файл.
select RBITS, WBITS, EBITS, TIMEOUT
Выполняет системный select()
Системный вызов semctl() для SYSTEM V.
Системный вызов semget() для SYSTEM V.
Системный вызов semop() для SYSTEM V.
send SOCKET, MSG, FLAGS
Послать сообщение через сокит. Аналогично системному send().
Установить номер группы PGRP процессу с номером PID
0 = для текущего процесса.
Установить приоритет PRIORITY процессу пользователя WHO
и группе WHICH.
Установить параметры сокита. Воззвращает неопределенность
при ошибке.
shift
Удаляет первый элемент массива и возвращает его значение.
Если массив пустой то результат неопределенность. Если аргумент
опущен - обрабатывается массив @ARGV в головной программе
или @_ в подпрограмме.
Системный вызов shmctl() System V
Системный вызов shmget() System V
shmread ID, VAR, POS, SIZE
shmread ID, STRING, POS, SIZE
Пишет или читает сегмент общедоступной памяти в System V.
Прекращает работу сокита методом HOW.
Возвращает в радианах синус выражения.
sleep
Приостанавливает работу процесса на указанное число секунд
или зацикливается если аргумент отсутсвует. Работа продолжается если
получен сигнал SIGALARM. Возвращает время фактической паузы.
Открывает сокит и привязывает его к указателю SOCKET.
Создает "безымянную" пару сокитов в указаном DOMAIN.
Возвращает true при успехе и false - неудаче.
sort блок список
sort список
Сортирует элементы списка и возвращает полученный
список. Не существующие элементы списка отбрасываются. Если не
указано имя подпрограммы или блок то сортирует в стандартном
строковом порядке.
Указанная подпрограмма возвращает значения больше, меньше
или равное нулю в зависимости от двух соседних элементов
списка. Имя подпрограммы может быть указано переменной. Она не
должна быть рекурсивной и два сравниваемых элемента списка
передаются как глобальные переменные $main::a и $main::b. Это
ссылки поэтому их изменение приводит к изменению самих
элементов списка.
splice массив, смещение, длина
splice массив, смещение
Удаляет элементы массива начиная со смещения и указанной длины.
Заменяет их указанным списком. Возвращает удаленный список.
Если длина не указана удаляет все элементы списка начиная со смещения.
split /шаблон/, выражение
split /шаблон/
split
Разделяет строку,указанную выражением, на массив элементов и возвращает его.
В скалярном контексте возвращает количество полученных элементов массива,
а сам массив помещает в @_ (в списковом контексте поместить результат
в @_ можно если применить ?шаблон?)
Если выражение отсутсвует то обрабатывается содержимое переменной $_.
Если шаблон отсутсвует то разделителем является пробел.
Все что подходит по шаблону считается разделителем. Если указан предел
то это максимальное число разделений. Отрицательное значение предела
воспринимается как неограниченно большой предел.
Если пустая строка походит под шаблон разделителя то исходное значение
разделяется по символьно.
Предел удобно использовать для частичного разделения строки.
Пример:
($a, $b, $остаток) = split(/ /, "Один Два Три Четыре",3);
здесь $a = 'Один', $b = 'Два' и $остаток = 'Три Четыре'
Если шаблон содержит круглые скобки то символы-разделители указанные
в них вставляются в результирующий список как обычные элементы,
причем вставляется символ который совпал с разделителем.
Пример:
@a = split(/([,.])/, "Один,Два.Три");
здесь @a = ("Один", "," ,"Два", ".", "Три")
Форматирует список по указанному формату аналогично
функции sprintf() языка С.
Возвращает корень квадратный выражения.
Задает начальное значение для генератора случайных чисел
оператора rand. Если аргумент отсутсвует то используется текущее
машинное время.
stat выражение
Возвращает 13 элементный массив параметров указанного файла
или пустой список при ошибке. Применяется обычно следующим образом:
($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size,$atime,$mtime,$ctime,
$blksize,$blocks) = stat($filename);
где
$dev - имя устройства
$ino - номер i-узла
$mode - права доступа
$nlink - количество связей
$uid - идентификатор владельца
$gid - идентификатор группы
$rdev - тип устройства
$size - размер файла в байтах
$atime - дата последнего обращения
$mtime - дата последней модификации
$ctime - дата последнего изменения статуса
$blksize - размер блока на диске
$blocks - количество блоков в файле.
Если указан аргумент '_' то возвращается результата предыдущего
вызова stat().
study
Влючение метода частотного сравнения. Целесообразность
применения зависит от количества поисков и количества констант в
строке в которой ведется поиск.
Функция работает следующим образом:
Для указанного скаляра (если аргумент отсутсвует берется значение
переменной $_) строится список указателей на каждый символ строки.
Затем когда начинается поиск первыми просматриваются символы которые
наиболее редко встречаются в английском языке.
Выигрыш по времени очевиден когда выполняется многократный поиск
в одной и той же строке и время затраченной на индексацию окупается.
substr выражение, смещение
Возвращает подстроку выражения начиная со смещения и заданной
длины. Если смещение отрицательное то отсчет ведется от конца строки.
Если длина не указана то берется все до конца строки.
Создает новый файл символически связанный со старым т.е.
создает ссылку на файл. Возвращает 1 при успехе и 0 - неудаче.
Выполняет системную функцию. Первый элемент списка - это
имя функции а остальные элементы - ее аргументы.
Если функция не выполнима то возвращается фатальная ошибка.
Аргументы интерпретируются следующим образом.
Если аргумент число, то оно считаестя целым. Если не число то аргумент
считается указателем на строку. Вам необходимо обеспечить достаточную
длину аргумента для подстановки значения указателя. В Пел передается
максимум 14 параметров. Обычно этого достаточно.
sysread файл, скаляр, длина
Прочитать из файла указанное число байт в скаляр с помощью
системного вызова read(). Смещение обозначает позицию в скаляре
после которой будут вставлены прочитанные байты.
Делает то же самое что и "exec список" с той лишь разницей
что вызов fork() делается первым и родительский процесс ждет
завершения потомка. Возвращает значение аналогичное функции wait().
Для получения действительного кода завершения необходимо разделить
на 256.
syswrite файл, скаляр, длина
Записать в файл укзанное число байт скаляра с помощью
системного вызова write(). Смещение указывает позицию в скаляре
откуда начинается запись.
tell
Возвращает текущую позицию указателя в открытом файле.
Если файл не указан то последнего читаемого файла.
Возвращает текущую позицию указателя в открытой директории.
Обычно это параметр для позиционирования указателя директории
функцией seekdir().
Присваивает переменную классу. Список - это аргументы
new метода класса (TIESCALAR, TIEARRAY или TIEHASH).
Возвращает указатель на созданный новый объект класса который
удобен для вызова других методов класса.
Внимание! Такие функции как keys() и values() могут вернуть
в качесте значения огромное количество данных.
Для создания объекта ассоциативного типа необходимо определение
следующих методов:
TIEHASH classname, LIST
DESTROY this
FETCH this, key
STORE this, key, value
DELETE this, key
EXISTS this, key
FIRSTKEY this
NEXTKEY this, lastkey
Обычного массива:
TIEHASH classname, LIST
DESTROY this
FETCH this, key
STORE this, key, value
[others TBD]
Скалярного типа:
TIEHASH classname, LIST
DESTROY this
FETCH this, key
STORE this, key, value
Возвращает количиство секунд начиная с 1 января 1970 г
00:00:00 UTC. Годы не разделяются на високосные.
Возвращает 4-х элементный массив значений:
($user, $system, $cuser, $csystem) = times;
где:
$user - пользовательское время процесса в секундах.
$system - системное время текущего процесса.
$cuser - время процесса-потомка текущего прцесса.
$csystem - его системное время.
tr///
Опрератор транслятор. Подробно смотри главу "Операторы".
truncate файл, длина
truncate выражение, длина
Усекает длину указанного файла.
Возвращает строку выражения в которой малые буквы заменены
на заглавные.
Возвращает строку выражения в которой первая буква заменена
на заглавную.
umask
Устанавливает маску umask и возвращает старое значение.
Без аргумента возвращает текущее значение.
undef
Делает неопределенным значение выражения. Применяется
только для скалярных переменных, целых массивов или подпрограмм.
Всегда возвращает неопределенное значение.
Удаляет файлы указанные в списке. Возвращает количество
удаленных файлов. Только супервизор может удалять директории
с файлами если Пел запущен с ключом -U.
Функция обратная pack(). Распаковывает строку выражения
по указанному шаблону в массив значений. В скалярном контексте
возвращает значение только первого элемента. Шаблоны такие же
как и в pack().
Символ '%' в шаблоне означает что вы хотите получить вместо
значения его контрольную сумму. По умолчанию 16 битовую.
Исключает переменную из класса указанного tie().
Противоположное shift. Помещает элементы списка
в начало массива.
use модуль
Указывает библиотечный модуль из которого можно
вызывать подпрограммы. Список перечисляет имена подпрограмм которые
добавляются к текущей область имен. Если не указан то все имена.
Действие аналогично блоку:
BEGIN { require модуль; import модуль список; }
Сам модуль должен распологаться в системной области Пел файлов.
Изменяет дату обращения и модификации файлов из списка.
Первые два элемента списка должны указывать новое значение даты
обращения и модификации.
Возвращает количество измененных файлов.
Возвращает обычный массив со всеми значениями хеша.
В скалярном контексте возвращает количество значений хеша.
Возвращает значени строки как вектор без знаковых целых.
Ожидать окончание порожденного процесса. Возвращает
PID для родительского процесса или -1 если нет процесса потомка.
Код завершения записывается в переменную $?.
Ожидать окончания процесса потомка с указанным PID.
Возвращает либо PID этого процесса либо -1 если нет такого процесса.
Код завершения записывается в перменную $?.
Возвращает true если подпрограмма вызывается в списковом
контексте и false - в скалярном.
Выодит в стандартный поток ошибок STDERR сообщение
аналогично die(), но не прекращает работу программы.
write выражение
write
Выводит в файл форматированные данные по оператору
format. По умолчанию имя формата совпадает с именем указателя файла.
Имя файла-по умолчанию можно изменить функцией select(), а имя
формата при этом надо присвоить переменной $~.
Заголовок листа пишется автоматически. Если на листе не хватает
места для вывода то выводится "перевод формата" и специальная
форма заголовка листа затем сами записи.
По умолчанию имя формата заголовка листа состоит из имени указателя
файла и добавленной строки "_TOP". Динамически это млжно делать
присваивая формат переменной $^. Количество оставшихся строк листа
содержится в переменной $- и если присвоить ей 0 то произойдет
смена листа. Подробно описание форматов смотри в главе "Форматы".
Оператор транслятор. Смотри главу "Операторы".
Last-modified: Thu, 24-Apr-97 17:55:47 GMT