汇编初探(一)

前言

  做为一个程序员在咱们的开发和学习过程当中,或多或少都接触过汇编,那咱们想没想过汇编是什么,掌握汇编咱们能干什么呢?
简单一点说就是把汇编语言翻译成计算机能够读懂的机器语言的过程,咱们称之为汇编。学会汇编能够玩工程的逆向,还能够了解计算机的原理。在作逆向分析过程当中一个很重要的环节叫静态分析,一个APP能够手机上执行,是由于手机上安装了可执行文件,它本质上是一个二进制文件,手机本质上执行的是二进制,而静态分析是创建在二进制上面。要想分析二进制就须要了解汇编程序员

汇编语言的发展

  • 什么是机器语言呢?

  它实际上是由0和1组成的机器指令:0100 0000,:0100 1000,:1111 0111 1110 0000,:1111 0111 1111 0000。汇编语言(assembly language),它是使用助记符代替机器语言。:INC EAX 经过编译器 0100 0000,:DEC EAX 经过编译器0100 1000,:MUL EAX 经过编译器1111 0111 1110 0000,:DIV EAX 经过编译器1111 0111 1111 0000。咱们平常开发的代码在终端设备上是怎样转化的呢?   经过上图能够很直观的看到代码的转化过程。咱们也应该认识到汇编语言与机器语言一一对应,每一条机器指令都有与之对应的汇编指令。汇编语言能够经过编译获得机器语言机器语言能够经过反汇编获得汇编语言。高级语言能够经过编译获得汇编语言机器语言,但汇编语言\机器语言几乎不可能还原成高级语言。markdown

  • 汇编语言的特色

  能够直接访问、控制各类硬件设备,好比存储器CPU等,能最大限度地发挥硬件的功能。目标代码简短,占用内存少,执行速度快。汇编指令是机器指令的助记符,同机器指令一一对应。每一种CPU都有本身的机器指令集\汇编指令集,因此汇编语言不具有可移植性。不区分大小写,好比mov和MOV是同样的。   目前比较常见的汇编语言有:8086汇编Win32汇编Win64汇编ARM汇编(嵌入式、Mac、iOS ).iPhone用到的是ARM汇编,但不一样的设备也有差别性,由于它们的CPU架构不同。
armv6 : iPhone, iPhone2, iPhone3G, 第一代、第二代 iPod Touch
armv7 : iPhone3GS, iPhone4, iPhone4S,iPad, iPad2, iPad3(The New iPad), iPad mini, iPod Touch 3G, iPod Touch4
armv7s : iPhone5, iPhone5C, iPad4(iPad with Retina Display)
arm64 : iPhone5S 之后 iPhoneX , iPad Air, iPad mini2之后   汇编会生成不一样的指令,不一样CPU架构会对应不一样的指令集。应用在手机或电脑中执行过程是怎么样的呢?   经过上图咱们基本能够摸清楚程序的执行过程。硬件相关最为重要的是CPU。在汇编中大部分的指令都是CPU内存之间关联。一般咱们所说的32位64位系统,区别在于在数据吞吐量上的差别,跟数据总线相关。CPU工做原理就是对外放电,32位系统CPU一次放电吞吐量位4字节,64位系统CPU一次放电吞吐量位8字节。那什么是数据总线呢?   总线是一根根导线的集合。每个CPU芯片都有许多管脚,这些管脚和总线相连,CPU经过总线跟外部器件进行交互。总线又分为三大类: 地址总线数据总线控制总线   地址总线有多根决定总线的宽度宽度决定了寻址的能力。在程序执行过程当中,咱们常提到一个名词镜像文件(image())。它实际上是可执行文件从磁盘加载内存中的一种表现形式。8086的地址总线宽度是20,因此寻址能力是1M8080的地址总线宽度是16,因此寻址能力是64K。   好了这一期的汇编咱们先探索到这里,下一期咱们继续研究。架构

相关文章
相关标签/搜索