| 総合手引 | セクション 2 | English | Deutsch | オプション |
#include <sys/types.h>
#include <unistd.h>
brk() 関数と sbrk() 関数は、プロセスのデータセグメントに割り当てられた メモリ量を変更するために使用されます。 これは、 "ブレーク" 位置を移動することで実現します。 ブレークとは、プロセスの初期化されていないデータ ( "BSS" としても知られています) の後の最初のアドレスのことです。
brk() 関数は、ブレークを addr に設定します。
sbrk() 関数は、ブレークを incr バイトだけ増し、結果として少なくとも incr バイトの新規メモリをデータセグメントに割り当てます。 incr が負の場合、ブレークは incr バイトだけ減らされます。
プログラムのブレークの現在値は、 sbrk() を呼び出すことで判定可能です。 end(3) も参照してください。
getrlimit(2) システムコールは、 データ セグメントの許容できる最大のサイズを決定するのに利用できます。 " etext + rlim.rlim_max" を越えるブレークを設定することはできません。 rlim.rlim_max は getrlimit(RLIMIT_DATA, &rlim) の呼び出しから返された値です ( etext の定義については end(3) を参照してください)。
sbrk() 関数は、成功すると古いブレーク値を返します。 失敗すると、値 (void * )-1 が返し、グローバル変数 errno にエラーを表す値を設定します。
| [EINVAL] | |
| 要求されたブレーク値がデータセグメントの先頭を越えています。 | |
| [ENOMEM] | |
| setrlimit(2) が設定したデータセグメントサイズの限界を越えています。 | |
| [ENOMEM] | |
| データセグメントの拡張に必要なスワップ領域内の空間が不充分です。 | |
ブレークの設定は、スワップ空間の一時的な不足のために処理が失敗する 可能性があります。 これは getrlimit(2) を使用しないと、データセグメントの最大サイズを越えたことに起因する 失敗と区別することはできません。
| BRK (2) | July 12, 1999 |
| 総合手引 | セクション 2 | English | Deutsch | オプション |
このマニュアルページサービスについてのご意見は Ben Bullock にお知らせください。 Privacy policy.
| “ | An ASCII character walks into a bar and orders a double. "Having a bad day?" asks the barman. "Yeah, I have a parity error," replies the ASCII character. The barman says, "Yeah, I thought you looked a bit off." | ” |