天下

记录修行的印记

brk/sbrk

brk/sbrk
从堆中分配空间,本质是移动一个位置,向后移就是分配空间,向前移就是释放空间

sbrk用相对的整数值确定位置,如果这个整数是正数,会从当前位置向后移若干字节,如果为负数就向前若干字节。在任何情况下,返回值永远是移动之前的位置

brk用绝对的地址指定移到哪个位置。

#include 
<stdio.h>
#include 
<unistd.h>
int main()
{
    
void* p = sbrk(0);
    
int* p1 = p;
    brk(p1
+4);//分配了16个字节的空间
    p1[0= 10;
    p1[
1= 20;
    p1[
2= 30;
    p1[
3= 40;
    p1[
4= 50;
    
int* p2 = sbrk(4);
    printf(
"*p2=%d\n"*p2);
    brk(p1
+1024);//分配整个页面的空间
    brk(p1+512);//释放一半空间
    brk(p1);//释放所有空间
}

sbrk:
参数
>0 向后移动当前位置,相当分配内存空间
参数
<0 向前移动当前位置,相当释放内存空间
参数==
0 当前位置不动
返回总是移动前的位置

brk(
void* ptr);
将当前位置移动到ptr的位置
ptr的位置一般通过sbrk(
0)获取首地址,然后再计算得出

sbrk实例
#include 
<stdio.h>
#include 
<unistd.h>
int main()
{
    
/*分配10个字节的空间,返回该空间的首地址*/
    
void* p = sbrk(12);
    
void* p2 = sbrk(4);
    
void* p3 = sbrk(4);
    
void* p4 = sbrk(4);
    printf(
"p=%p\n", p);
    printf(
"p2=%p\n", p2);
    printf(
"p3=%p\n", p3);
    printf(
"p4=%p\n", p4);
    
/*用参数为0来获取未分配空间的开始位置*/
    
void* p0 = sbrk(0);
    printf(
"p0=%p\n", p0);
    
void* p5 = sbrk(-4);
    printf(
"p5=%p\n", p5);
    printf(
"pid=%d\n", getpid());
    sleep(
10);
    
/*当释放到一个页面的开始位置时,整个页面会被操作系统回收*/
    sbrk(
-20);

    
/*
    int* pi = p;
    *pi = 10;
    *(pi+1) = 20;
    *(pi+2) = 30;
    *(pi+1023) = 1023;
    *(pi+1024) = 1024;
    
*/
    
while(1);
}


#include 
<stdio.h>
#include 
<unistd.h>
int main()
{
    printf(
"pid=%d\n", getpid());
    
void* p = sbrk(0);
    
int* p1 = sbrk(4);
    sleep(
10);
    
int* p2 = sbrk(1023*4+1);
    sleep(
10);
    sbrk(
-1);
    
while(1);
}

posted on 2012-08-10 10:46 天下 阅读(1109) 评论(0)  编辑 收藏 引用 所属分类: C/C++


只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2012年8月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678

导航

统计

常用链接

留言簿(4)

随笔分类(377)

随笔档案(327)

链接

最新随笔

搜索

最新评论