malloc是完全在用户模式下运行的c标准库函数(当然,当用户申请的内存不够,在malloc里面是要调用系统内核函数sbrk()的),sbrk()函数是向系统申请一大块内存(heap),可能这块内存还没有被用户调用malloc来申请,而sbrk(n)向系统申请内存就是在页表中建立虚拟地址--物理地址的对应项。
而sbrk申请的内存的管理由用户自己通过malloc管理,
这也就是为什么有的时候一块地址自己没有malloc,但是使用了不会报错,但是使用heap top以上的地址一定会报错