ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

数组和指针的区别

2022-02-20 01:04:09  阅读:173  来源: 互联网

标签:区别 45 mov eax ebp 数组 array PTR 指针


// test.c
void test()
{
    char array[4] = {0};
    *(array + 0) = 0x00;
    array[1] = 0x11;
    *(array + 2) = 0x22;
    array[3] = 0x33;
    char *pointer = array;
    pointer[0] = 0x00;
    pointer[1] = 0x11;
    pointer[2] = 0x22;
    pointer[3] = 0x33;
}
// Makefile
test.o: test.c
	gcc -c -O0 -m32 -masm=intel -std=c99 -ggdb3 -fno-stack-protector -fcf-protection=none -mmanual-endbr -fno-PIE -o test.o test.c
dump32: test.o
	objdump -Mintel -Mi386 -d test.o
clean:
	rm test.o
test.o:     file format elf32-i386


Disassembly of section .text:

00000000 <test>:
   0:   55                      push   ebp
   1:   89 e5                   mov    ebp,esp
   3:   83 ec 10                sub    esp,0x10

   6:   c7 45 f8 00 00 00 00    mov    DWORD PTR [ebp-0x8],0x0

   d:   c6 45 f8 00             mov    BYTE PTR [ebp-0x8],0x0
  11:   c6 45 f9 11             mov    BYTE PTR [ebp-0x7],0x11
  15:   c6 45 fa 22             mov    BYTE PTR [ebp-0x6],0x22
  19:   c6 45 fb 33             mov    BYTE PTR [ebp-0x5],0x33

  1d:   8d 45 f8                lea    eax,[ebp-0x8]
  20:   89 45 fc                mov    DWORD PTR [ebp-0x4],eax

  23:   8b 45 fc                mov    eax,DWORD PTR [ebp-0x4]
  26:   c6 00 00                mov    BYTE PTR [eax],0x0

  29:   8b 45 fc                mov    eax,DWORD PTR [ebp-0x4]
  2c:   83 c0 01                add    eax,0x1
  2f:   c6 00 11                mov    BYTE PTR [eax],0x11

  32:   8b 45 fc                mov    eax,DWORD PTR [ebp-0x4]
  35:   83 c0 02                add    eax,0x2
  38:   c6 00 22                mov    BYTE PTR [eax],0x22

  3b:   8b 45 fc                mov    eax,DWORD PTR [ebp-0x4]
  3e:   83 c0 03                add    eax,0x3
  41:   c6 00 33                mov    BYTE PTR [eax],0x33

  44:   90                      nop
  45:   c9                      leave  
  46:   c3                      ret    

以上展示了最简单的以数字下标的方式向“数组”和“指针指向的内容”存数据。

可以看出:

array在内存中的位置是ebp - 0x08ebp - 0x05四个字节,array的存取,直接以ebp - 0x08为基准。

pointer在内存中的位置是DWORD PTR ebp - 0x04,其中存储着array的地址,通过pointer存取array时,需要进行“解地址”计算。

在c语言中,arraypointer用起来几乎一样。

但如果通过inline assemblyarraypointer传入,那么array就是[ebp - 0x08],直接代表了第0个元素,访问第N个元素需要:

lea eax, %[array]
add eax, N
mov [eax], 0xabcd

pointer就是[ebp - 0x04],其中存储着array的地址,访问第N个元素:

mov eax, %[pointer]
add eax, N
mov [eax], 0xabcd

标签:区别,45,mov,eax,ebp,数组,array,PTR,指针
来源: https://www.cnblogs.com/wotent/p/15914344.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有