Provided by: manpages-ru-dev_4.19.0-7_all bug

ИМЯ

       brk, sbrk - изменяет размер сегмента данных

LIBRARY

       Standard C library (libc, -lc)

СИНТАКСИС

       #include <unistd.h>

       int brk(void *addr);
       void *sbrk(intptr_t increment);

   Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

       brk(), sbrk():
           Since glibc 2.19:
               _DEFAULT_SOURCE
                   || ((_XOPEN_SOURCE >= 500) &&
                       ! (_POSIX_C_SOURCE >= 200112L))
           From glibc 2.12 to glibc 2.19:
               _BSD_SOURCE || _SVID_SOURCE
                   || ((_XOPEN_SOURCE >= 500) &&
                       ! (_POSIX_C_SOURCE >= 200112L))
           Before glibc 2.12:
               _BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE >= 500

ОПИСАНИЕ

       Вызов  brk()  и  sbrk() изменяет расположение маркера окончания программы (program break),
       который определяет конец сегмента данных процесса (т.е., маркер  окончания  —  это  первая
       точка  после  конца  сегмента  неинициализированных  данных). Увеличение маркера окончания
       программы позволяет процессу выделить память; уменьшение маркера приводит  к  освобождению
       памяти.

       brk() устанавливает конец сегмента данных в значение, указанное в аргументе addr, если это
       значение является  приемлемым,  система  имеет  достаточно  памяти  и  процесс  не  достиг
       максимально возможного размера своего сегмента данных (см. setrlimit(2)).

       sbrk()  увеличивает  пространство  данных  программы  на  increment  байт.  Вызов sbrk() с
       increment равным 0 может быть использован для нахождения текущего  местоположения  маркера
       окончания программы.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

       При  успешном  выполнении  brk() возвращает ноль. В случае ошибки возвращается -1, а errno
       становится равной ENOMEM.

       При успешном выполнении sbrk() возвращает  предыдущий  маркер  окончания  программы.  Если
       маркер  окончания  был  увеличен,  то  это  значение  указывает на начало новой выделенной
       памяти. В случае ошибки возвращается (void *) -1, а errno становится равной ENOMEM.

СТАНДАРТЫ

       4.3BSD; SUSv1, помечены как УСТАРЕВШИЕ в SUSv2, удалены из POSIX.1-2001.

ЗАМЕЧАНИЯ

       Не используйте brk() и sbrk(): для  выделения  памяти  функции  malloc(3)  являются  более
       переносимыми и удобными.

       В  различных  системах  используются  различные типы для аргумента sbrk(). Обычно это int,
       ssize_t, ptrdiff_t, intptr_t.

   Отличия между библиотекой C и ядром
       Возвращаемое brk() значение, описанное выше, является частью поведения обёрточной  функции
       glibc  к системному вызову Linux brk(). В большинстве других реализаций возвращаемое brk()
       значение то же самое; это значение также описано в SUSv2. Однако, реальный системный вызов
       Linux  в  случае  успешного  завершения  возвращает  новый маркер окончания программы. При
       ошибке системный вызов возвращает  текущий  маркер  окончания.  Обёрточная  функция  glibc
       делает  то же самое (т. е., проверяет меньше ли новый маркер чем addr), возвращая значения
       0 и -1, как описано выше.

       В Linux, вызов sbrk() реализован в виде библиотечной функции, которая использует системный
       вызов brk() и ведёт внутренний учёт для возврата старого значения маркера окончания.

СМ. ТАКЖЕ

       execve(2), getrlimit(2), end(3), malloc(3)

ПЕРЕВОД

       Русский    перевод    этой    страницы    руководства    был    сделан    Artyom    Kunyov
       <artkun@guitarplayer.ru>, Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitriy Ovchinnikov
       <dmitriyxt5@gmail.com>,     Dmitry     Bolkhovskikh     <d20052005@yandex.ru>,    ITriskTI
       <ITriskTI@gmail.com>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>

       Этот  перевод  является  бесплатной  документацией;  прочитайте  Стандартную  общественную
       лицензию GNU версии 3 ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩ или более позднюю, чтобы
       узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.

       Если вы обнаружите ошибки в переводе  этой  страницы  руководства,  пожалуйста,  отправьте
       электронное письмо на ⟨man-pages-ru-talks@lists.sourceforge.net⟩.