国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Malloc兩種內(nèi)存獲取方式的區(qū)別

安全 終端安全 黑客攻防
既然你正在看這篇文章,那么你就應(yīng)該知道m(xù)alloc函數(shù)是通過(guò)syscall調(diào)用從操作系統(tǒng)獲取內(nèi)存的。 如下圖所示,malloc是通過(guò)調(diào)用brk或mmap這兩種syscall之一來(lái)獲取內(nèi)存的。

既然你正在看這篇文章,那么你就應(yīng)該知道m(xù)alloc函數(shù)是通過(guò)syscall調(diào)用從操作系統(tǒng)獲取內(nèi)存的。 如下圖所示,malloc是通過(guò)調(diào)用brk或mmap這兩種syscall之一來(lái)獲取內(nèi)存的。

1.brk方式

brk:brk是通過(guò)增設(shè)程序斷點(diǎn)來(lái)從內(nèi)核獲取內(nèi)存(非清零)的。最初堆段的起點(diǎn)(start_brk)和堆段終點(diǎn)(brk)是指向相同的位置的。當(dāng)ASLR關(guān)閉時(shí),start_brk和brk將指向data/bss段(end_data)的末尾。當(dāng)ASLR打開(kāi)時(shí),start_brk和brk的值將等于data/bss段(end_data)的結(jié)尾加上一個(gè)隨機(jī)的brk偏移。

正如上面的“進(jìn)程虛擬內(nèi)存布局”圖展示的,start_brk是堆段的開(kāi)始,brk(程序中斷)是堆段的結(jié)尾。

例程如下:

  1. /* sbrk and brk example */ 
  2. #include <stdio.h> 
  3. #include <unistd.h> 
  4. #include <sys/types.h> 
  5.  
  6. int main() 
  7.         void *curr_brk, *tmp_brk = NULL
  8.  
  9.         printf("Welcome to sbrk example:%d\n", getpid()); 
  10.  
  11.         /* sbrk(0)返回此進(jìn)程的斷點(diǎn)位置*/ 
  12.         tmp_brk = curr_brk = sbrk(0); 
  13.         printf("Program Break Location1:%p\n", curr_brk); 
  14.         getchar(); 
  15.  
  16.         /* brk(addr)遞增/遞減程序的斷點(diǎn)位置*/ 
  17.         brk(curr_brk+4096); 
  18.  
  19.         curr_brk = sbrk(0); 
  20.         printf("Program break Location2:%p\n", curr_brk); 
  21.         getchar(); 
  22.  
  23.         brk(tmp_brk); 
  24.  
  25.         curr_brk = sbrk(0); 
  26.         printf("Program Break Location3:%p\n", curr_brk); 
  27.         getchar(); 
  28.  
  29.         return 0; 

輸出分析:在增設(shè)程序中斷之前,通過(guò)下面的輸出,我們可以看到并沒(méi)有堆段。

因此:• start_brk = brk = end_data = 0x804b000

  1. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ ./sbrk  
  2. Welcome to sbrk example:6141 
  3. Program Break Location1:0x804b000 
  4. ... 
  5. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ cat /proc/6141/maps 
  6. ... 
  7. 0804a000-0804b000 rw-p 00001000 08:01 539624     /home/sploitfun/ptmalloc.ppt/syscalls/sbrk 
  8. b7e21000-b7e22000 rw-p 00000000 00:00 0  
  9. ... 
  10. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ 

在增設(shè)了程序斷點(diǎn)后:在下面的輸出我們可以觀察到有堆段。

因此:• start_brk = end_data = 0x804b000• brk = 0x804c000

  1. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ ./sbrk  
  2. Welcome to sbrk example:6141 
  3. Program Break Location1:0x804b000 
  4. Program Break Location2:0x804c000 
  5. ... 
  6. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ cat /proc/6141/maps 
  7. ... 
  8. 0804a000-0804b000 rw-p 00001000 08:01 539624     /home/sploitfun/ptmalloc.ppt/syscalls/sbrk 
  9. 0804b000-0804c000 rw-p 00000000 00:00 0          [heap] 
  10. b7e21000-b7e22000 rw-p 00000000 00:00 0  
  11. ... 
  12. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ 

其中0804b000-0804c000是此堆段的虛擬地址范圍

rw-p是Flags(可讀,可寫,不可執(zhí)行,私有)

00000000是文件偏移 – 由于不存在文件映射,所以這里為零

00:00是主要/次要設(shè)備號(hào) – 由于不存在文件映射,所以這里為零

0是Inode編號(hào) – 由于不存在文件映射,所以這里為零

[heap]表示是堆段

2.mmap方式

mmap:malloc使用mmap去創(chuàng)建一個(gè)私有的匿名映射段。映射這個(gè)私有匿名段的主要目的是為了分配新的內(nèi)存(已清零),并且這個(gè)新的內(nèi)存將被調(diào)用進(jìn)程獨(dú)占使用。

例程:

  1. /* Private anonymous mapping example using mmap syscall */ 
  2. #include <stdio.h> 
  3. #include <sys/mman.h> 
  4. #include <sys/types.h> 
  5. #include <sys/stat.h> 
  6. #include <fcntl.h> 
  7. #include <unistd.h> 
  8. #include <stdlib.h> 
  9.  
  10. void static inline errExit(const char* msg) 
  11.         printf("%s failed. Exiting the process\n", msg); 
  12.         exit(-1); 
  13.  
  14. int main() 
  15.         int ret = -1; 
  16.         printf("Welcome to private anonymous mapping example::PID:%d\n", getpid()); 
  17.         printf("Before mmap\n"); 
  18.         getchar(); 
  19.         char* addr = NULL
  20.         addr = mmap(NULL, (size_t)132*1024, PROT_READ|PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); 
  21.         if (addr == MAP_FAILED) 
  22.                 errExit("mmap"); 
  23.         printf("After mmap\n"); 
  24.         getchar(); 
  25.  
  26.         /* Unmap mapped region. */ 
  27.         ret = munmap(addr, (size_t)132*1024); 
  28.         if(ret == -1) 
  29.                 errExit("munmap"); 
  30.         printf("After munmap\n"); 
  31.         getchar(); 
  32.         return 0; 

輸出分析:

mmap調(diào)用前:在下面的輸出中,我們只能看到屬于共享庫(kù)libc.so和ld-linux.so的內(nèi)存映射段

  1. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ cat /proc/6067/maps 
  2. 08048000-08049000 r-xp 00000000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  3. 08049000-0804a000 r--p 00000000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  4. 0804a000-0804b000 rw-p 00001000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  5. b7e21000-b7e22000 rw-p 00000000 00:00 0  
  6. ... 
  7. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ 

mmap調(diào)用后:在下面的輸出中,我們可以看到我們的內(nèi)存映射段(b7e00000 – b7e21000,大小為132KB)與已映射的內(nèi)存映射段(b7e21000 – b7e22000)拼接在一起了。

  1. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ cat /proc/6067/maps 
  2. 08048000-08049000 r-xp 00000000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  3. 08049000-0804a000 r--p 00000000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  4. 0804a000-0804b000 rw-p 00001000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  5. b7e00000-b7e22000 rw-p 00000000 00:00 0  
  6. ... 
  7. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ 

其中b7e00000-b7e22000是此段的虛擬地址范圍

rw-p是Flags(可讀,可寫,不可執(zhí)行,私有)

00000000是文件偏移 – 由于不存在文件映射,所以這里為零

00:00是主要/次要設(shè)備號(hào) – 由于不存在文件映射,所以這里為零

0是Inode編號(hào) – 由于不存在文件映射,所以這里為零

munmap調(diào)用后:在下面的輸出中,我們可以看到我們的內(nèi)存映射段是未映射的,就是說(shuō)其相應(yīng)的內(nèi)存已經(jīng)釋放到操作系統(tǒng)了。

  1. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ cat /proc/6067/maps 
  2. 08048000-08049000 r-xp 00000000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  3. 08049000-0804a000 r--p 00000000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  4. 0804a000-0804b000 rw-p 00001000 08:01 539691     /home/sploitfun/ptmalloc.ppt/syscalls/mmap 
  5. b7e21000-b7e22000 rw-p 00000000 00:00 0  
  6. ... 
  7. sploitfun@sploitfun-VirtualBox:~/ptmalloc.ppt/syscalls$ 

注意:在我們的示例程序中ASLR是關(guān)閉的。

責(zé)任編輯:武曉燕 來(lái)源: FreeBuf
相關(guān)推薦

2024-09-20 11:32:28

.NET內(nèi)存管理

2010-03-18 10:18:52

python模塊

2009-12-25 16:46:08

2011-03-03 10:26:04

Pureftpd

2021-05-27 10:57:01

TCP定時(shí)器網(wǎng)絡(luò)協(xié)議

2009-06-25 13:43:00

Buffalo AJA

2010-10-21 16:24:18

sql server升

2023-03-29 13:06:36

2010-08-06 09:38:11

Flex讀取XML

2010-09-07 11:09:59

2010-07-27 15:03:37

Flex ArrayC

2011-03-23 11:22:14

oracle dbli

2010-07-14 10:30:26

Perl多線程

2010-05-10 18:19:00

負(fù)載平衡技術(shù)

2011-04-02 09:48:38

深拷貝

2010-07-15 14:38:55

Perl eval函數(shù)

2021-12-08 10:47:35

RabbitMQ 實(shí)現(xiàn)延遲

2011-06-16 10:02:08

JAVA靜態(tài)載入

2009-09-08 15:22:20

Spring依賴注入

2010-08-03 13:27:04

FlexBuilder
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

亚洲美女视频一区| 国产三级精品在线| 成年人免费网站| 91精品国产色综合久久久蜜香臀| 精品99在线视频| 久久九九免费| 欧美日韩亚洲国产成人| 日本欧美一区二区三区乱码| 欧美精品一区二区三区很污很色的 | 免费毛片aaaaaa| 国产原创一区二区| 51xx午夜影福利| 日韩国产欧美在线视频| 欧美精品国产精品久久久| 精品午夜一区二区三区在线观看| 欧美精品在线免费| 香蕉一区二区| 日韩**中文字幕毛片| 午夜精品久久久久久久久久蜜桃| 久久av.com| 一区二区三区国产精品| 国产酒店精品激情| 国产伊人精品| 永久免费精品视频| 欧美xxxx免费虐| 在线观看国产福利视频| 国产偷人视频免费| www.成人av| 亚洲成人亚洲激情| 91亚洲午夜精品久久久久久| 国产精品一线| 伦理av在线| 婷婷免费在线观看| 久久国产精品一区二区三区| 欧美精品制服第一页| 亚洲一区二区三区四区的| 亚州av乱码久久精品蜜桃| 网友自拍区视频精品| 国产又黄又猛又粗| 亚洲欧美精品午睡沙发| 超碰在线免费公开| 国产精品看片资源| 久久se这里有精品| 九色视频网站入口| 欧美成人午夜激情在线| 99久久99久久精品免费看蜜桃| 欧在线一二三四区| 色婷婷激情综合| 日本精品不卡| 国产自产在线视频一区| 国产日韩影视精品| 中文字幕电影在线| 久久久av电影| ccyy激情综合| 免费观看成人高| 欧美色婷婷久久99精品红桃| 在线电影av| 动漫黄在线观看| 好吊妞这里只有精品| 999在线免费视频| 欧美亚洲日本在线观看| 四虎4hutv紧急入口| 1024av视频| 毛片av在线播放| 精品一区二区三区毛片| 国产女主播一区二区三区| 久久国内精品一国内精品| 日韩视频免费观看高清完整版 | 亚洲第一成年免费网站| 亚洲四色影视在线观看| 久久365资源| 免费看黄色a级片| 欧美日韩另类一区| 欧美大片aaaa| 免费资源在线观看| 99中文字幕| 午夜激情久久久| 日韩精品免费一区二区三区竹菊| 免费中文日韩| 欧美日韩久久一区二区| 免费看成人人体视频| 超碰在线94| 免费在线黄网| 免费观看国产视频在线| 日韩成人午夜影院| 8090成年在线看片午夜| 欧美激情一区三区| 久久久久美女| a黄色片在线观看| 精品视频免费观看| 日韩精品免费看| xnxx国产精品| 日韩欧美中文字幕电影| 黄www在线观看| 欧美亚洲国产另类| 色综合久久精品| 亚洲成av人在线观看| 日韩一区二区三区免费看 | 国产成人免费视| 久久精品在线免费观看| 91福利资源站| 欧美精品日日鲁夜夜添| 在线成人午夜影院| 久久精品国产一区| 97超级碰碰碰| 国产精品海角社区在线观看| 久久久综合亚洲91久久98| 伊人婷婷久久| 毛片毛片毛片毛片毛片毛片| 成a人v在线播放| 免费观看v片在线观看| 免费黄网站在线| 黑人一区二区三区四区五区| 最爽无遮挡行房视频在线| 亚洲国产欧美不卡在线观看| 国产精品专区第二| 精品视频在线播放色网色视频| 国产盗摄一区二区三区| 福利一区二区三区视频在线观看| 俄罗斯xxxx性全过程| 蜜桃导航-精品导航| 91久久久久久国产精品| 91午夜在线观看| fc2ppv完全颜出在线播放| 久久久久久免费看| 午夜免费精品视频| 亚洲搞黄视频| 浪潮av一区| 天堂资源中文在线| 国产精品天天av精麻传媒| 国产欧美日韩综合一区在线观看| 久久中文字幕国产| 日韩欧美亚洲另类制服综合在线| 五月激情综合网| ww久久中文字幕| 成人av电影在线| 亚洲欧洲日本mm| 精品午夜久久| 麻豆国产欧美一区二区三区r| 日本美女久久| jizz日韩| 韩国日本一区| 久久精品国产99国产精品| 在线观看91av| 97在线免费视频观看| 色多多在线观看| 麻豆成人av在线| 在线看日韩欧美| 人妻少妇精品无码专区二区| 第84页国产精品| 国产精品白丝jk黑袜喷水| 欧美三级三级三级爽爽爽| 91嫩草在线| 日本成人免费| 国产成人一二片| 成人精品一区二区三区四区 | 成黄免费在线| 成人羞羞视频播放网站| 国产精品理论片在线观看| 国产视频不卡| 国内视频在线精品| 西野翔中文久久精品国产| 欧美wwwsss9999| 国产精品一区二区免费福利视频| 88久久精品| 亚洲国产一成人久久精品| 亚洲精选91| 欧美激情日韩| 一区二区三区亚洲变态调教大结局| 国产高清不卡| 91久久中文| 精品亚洲一区二区三区在线播放| 日韩三级电影| 欧美私密网站| 韩国三级在线一区| 中文字幕亚洲不卡| 欧美日韩国产a| 韩国国内大量揄拍精品视频| 农村寡妇一区二区三区| 冲田杏梨av在线| 国产免费永久在线观看| 精品欠久久久中文字幕加勒比| 国产精品久久久久一区二区三区厕所| 成人性色生活片免费看爆迷你毛片| 亚洲同性同志一二三专区| 欧美一区二区三区视频在线| 欧美极品美女视频网站在线观看免费| 99re6在线| 国产www视频在线观看| 亚洲另类在线制服丝袜| 亚洲高清精品中出| 在线中文字幕亚洲| 亚洲免费视频网站| 国产黄色小视频在线| 亚洲福利一区二区| 久草热视频在线观看| 久久狠狠婷婷| 国产精品一区二区av| 日本视频在线免费观看| 国产成人综合精品三级|