一、汇编语言中PTR的含义及作用
mov ax,bx ;是把BX寄存器“里”的值赋予AX,由于二者都是word型,所以没有必要加“WORD”
mov ax,word ptr [bx];是把内存地址等于“BX寄存器的值”的地方所存放的数据,赋予ax。由于只是给出一个内存地址,不知道希望赋予ax的,是byte还是word,所以需要用word明确指出!
所以,当两个操作数的宽度不一样时,就要用到ptr。
也就是说
*p 用汇编表示就是:dword ptr [p]
*p是取p所指内存地址处的值。
*p == 100 为true
dword ptr [ebp-xx]是很常见的用法,常常用来获取局部变量:
随便写一段代码
反汇编代码如下:
02 |
00401469 mov eax,dword ptr [ebp-18h] |
03 |
0040146C mov dword ptr [ebp-1Ch],eax |
05 |
0040146F mov ecx,dword ptr [ebp-1Ch] |
06 |
00401472 mov edx,dword ptr [ecx]//得到虚函数表指针 |
08 |
00401476 mov ecx,dword ptr [ebp-1Ch]//ecx即为this指针 |
09 |
00401479 call dword ptr [edx]//调用第一个虚函数,这里就是f |
11 |
0040147D call __chkesp (00402750) |
13 |
00401469 mov eax,dword ptr [ebp-18h] |
14 |
0040146C mov dword ptr [ebp-1Ch],eax |
16 |
0040146F mov ecx,dword ptr [ebp-1Ch] |
17 |
00401472 mov edx,dword ptr [ecx]//得到虚函数表指针 |
19 |
00401476 mov ecx,dword ptr [ebp-1Ch]//ecx即为this指针 |
20 |
00401479 call dword ptr [edx]//调用第一个虚函数,这里就是f |
22 |
0040147D call __chkesp (00402750) |
再来看看C中的取地址符&如何处理的
3 |
0040141D lea eax,[ebp-10h] |
4 |
00401420 mov dword ptr [ebp-14h],eax |
7 |
0040141D lea eax,[ebp-10h] |
8 |
00401420 mov dword ptr [ebp-14h],eax |
lea指令我看到看雪论坛有人如此说:
LEA是INTEL颇为得意的一条指令(虽然大多数程序员并不以为然)。在INTEL OPTIMIZATION REFERFENCE MANUAL中,特别提到了这条指令的好处。
0.LEA指令具有单时钟周期,执行效率很高。
1.它是CPU地址生成单元参与运算的,而不是ALU参与运算的,所以在流水线上不会与上下文的算术逻辑指令产生流水相关;
lea 不在 ALU 里执行,而是在 AGU (address generation unit) 里执行
ALU 与 AGU 是并行的整数运算单元,将巧妙地 lea 与 add 分开并行执行,很大程度提高吞吐量。
2.INTEL指令集中不存在很多RISC机器所具有的三操作数算术运算指令,比如像ARM的”add r0,r1,r2″,而LEA指令恰好提供了同样的功能,以模拟“三元算术逻辑指令”。
举个例子,要计算两个寄存器的和,但又不想破坏原来的值,那么可以执行lea ebx ,[eax+edx], 这条指令,执行的就是 ebx = eax + edx 这条加法运算。如果用add指令,则不可能一条指令内完成。
3.在汇编语言程序设计中,在需要取得一个变量地址时,使用LEA是很方便的。而MOV指令则常常出错,因为在微软MASM汇编语法中,label和variable是不同的。
看来可以多用lea。
Mov和lea的区别总结一下:
取值:mov eax ,[ebp-18h] mov [ebp-1ch],eax 相当于 : int a= b;
取地址:lea ecx , [ebp-18h] mov [ebp - 1ch ] , ecx 相当于 : int *p= &b;
LEA指令的功能是取偏移地址,例如LEA AX,[1000H],作用是将源操作数[1000H]的偏移地址1000H送至AX;
MOV指令的功能是传送数据,例如MOV AX,[1000H],作用是将1000H作为偏移地址,寻址找到内存单元,将该内存单元中的数据送至AX。
务必牢记。
参考:http://blog.himdd.com/archives/3024
另外发现一本好书:
http://ceccai.jmu.edu.cn/dzsj/%CE%A2%BB%FA%D4%AD%C0%ED%BC%B0%BD%D3%BF%DA%BC%BC%CA%F5/ch04.pdf
http://ceccai.jmu.edu.cn/dzsj/%CE%A2%BB%FA%D4%AD%C0%ED%BC%B0%BD%D3%BF%DA%BC%BC%CA%F5/ch13.pdf
--------------------------------------------------------------------------------
mov ecx,[eax+0x30]表示先运算eax+0x30得到一个结果,以这个结果为地址找一个ecx长度的内存数赋给ecx
lea ecx,[eax+0x30]表示先运算eax+0x30得到一个结果,把这个结果(mov时地址)赋给ecx
效果为ecx=eax+0x30 (这里eax参与了运算却没有改变值)
dword 双字 就是四个字节
ptr pointer缩写 即指针
[]里的数据是一个地址值,这个地址指向一个双字型数据
比如mov eax, dword ptr [12345678] 把内存地址12345678中的双字型(32位)数据赋给eax
http://blog.csdn.net/herecles/article/details/6061744
- LEA指令与MOV指令区别
Tips: LEA指令与MOV指令的区别: ① MOV指令是 数据 传送指令-------传送数据 LEA指令是 有效地址 传送指令-------取偏移地址 ② MOV OPRD1 ...
- 汇编中中括号[]作用以及lea和mov指令的区别
现在总结一下:其中牵扯到lea指令,mov指令,[] 一.lea指令:对于寄存器来说:第二个操作数是寄存器必须要加[],不然报错,这里lea就是取[寄存器]的值,如:mov eax,2lea ebx, ...
- LDR 和MOV 指令区别
ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令.比如想把数据从内存中某处读取到寄存器中,只能使用ldr比如:ldr r0, 0x12345678就 ...
- ARM指令和Thumb指令区别
Thumb指令集 ]的问题而提出的,它具有16为的代码密度.Thumb不是一个完整的体系结构,不能指望处理程序只执行Thumb指令而不支持ARM指令集.因此,Thumb指令只需要支持通用功能,必要时, ...
- 汇编总结:mov指令
mov指令的作用: mov指令可能是汇编里用的最多的指令了,完成c语言里的赋值. mov指令种类: 1.普通的mov指令 2.做符号扩展的movs 3.做零扩展的movz 1.普通mov的种类有: m ...
- 汇编寄存器(内存访问)基础知识之三---mov指令
1 内存中字的存储 一个字型数据占2个内存单元,内存里面一个内存单元一个字节(8位),高地址单位放高8位,低地址单元放低8位. 注意:0号是地址单元,1是高地址单元(上是低地址,下面是高地址) (1 ...
- keil Ax51中条件编译指令IF与$IF的区别
keil A51中条件编译指令IF与$IF的区别:1.IF和$IF是不等价的,不要混淆了;2.带前缀$的条件编译$IF用法:(汇编器指示命令Assembler Directive)只能用来测试由$SE ...
- arm mov 指令
语法格式: mov {条件} 1目的寄存器,2源操作数 作用: MOV指令可完成从另一个寄存器.被移位的寄存器或立即数赋值到目的寄存器.其中S选项为指令的操作结果是否操作CPSR中的条件标志位,当没有 ...
- mov指令具体解释
MOV指令能够在CPU内或CPU和存储器之间传送字或字节.它传送的信息能够从寄存器到寄存器,马上数到寄存器,马上数到存储单元,从存储单元到寄存器.从寄存器到存储单元,从寄存器或存储单元到除CS外的段寄 ...
随机推荐
- 【Python基础】迭代器、生成器
迭代器和生成器 迭代器 一 .迭代的概念 #迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 while True: #只是单 ...
- 我的java web之路(JSP基本语法)
1.JSP注释 1.1输出注释 语法格式 <!--comment [<%= expression %>] --> <body> This is my JSP pa ...
- LeetCode 467. Unique Substrings in Wraparound String
Consider the string s to be the infinite wraparound string of "abcdefghijklmnopqrstuvwxyz" ...
- 【02】sass更新的方法
[02]更新的方法 gem install sass **
- spring的IOC和DI
https://blog.csdn.net/fuzhongmin05/article/details/55802816 (1)IOC:控制反转,把对象创建交给spring进行配置 (2)DI:依赖注入 ...
- Sublime Text 3使用方法
一.下载安装 Sbulime Text 3官网 参考网站:http://lucida.me/blog/sublime-text-complete-guide/注意在安装时勾选Add to expl ...
- python017 Python3 模块
Python3 模块在前面的几个章节中我们脚本上是用 python 解释器来编程,如果你从 Python 解释器退出再进入,那么你定义的所有的方法和变量就都消失了.为此 Python 提供了一个办法, ...
- 【ITOO 1】SQLBulkCopy实现不同数据库服务器之间的批量导入
导读:在做项目的时候,当实现了动态建库后,需要实现从本地服务器上获取数据,批量导入到新建库的服务器中的一个表中去.之前是用了一个SQL脚本文件实现,但那时候没能实现不同的数据库服务器,现在用了SqlB ...
- Oracle臨時表空間過大問題解決
查詢資料庫伺服器時,發現資料庫伺服器磁片使用空間達到了98%,分析總共的資料檔案也不可能達到如此大,經過查詢發現原來臨時表空間的使用方式達到了 32G,導致磁碟空間使用緊張.搜索了相應的文檔與資料後, ...
- POJ 2513 无向欧拉通路+字典树+并查集
题目大意: 有一堆头尾均有颜色的木条,要让它们拼接在一起,拼接处颜色要保证相同,问是否能够实现 这道题我一开始利用map<string,int>来对颜色进行赋值,好进行后面的并查操作以及欧 ...