在内嵌汇编中,能够将C语言表达式指定为汇编指令的操作数,而且不用去管如何将C语言表达式的值读入哪个寄存器,连同如何将计算结果写回C 变量,您只要告诉程式中C语言表达式和汇编指令操作数之间的对应关系即可, GCC会自动插入代码完成必要的操作。

1、简单的内嵌汇编
例:
     __asm__ __volatile__("hlt"); “__asm__”表示后面的代码为内嵌汇编,“asm”是“__asm__”的别名。“__volatile__”表示编译器不要优化代码,后面的指令 保留原样,“volatile”是他的别名。括号里面是汇编指令。

2、内嵌汇编举例
  使用内嵌汇编,要先编写汇编指令模板,然后将C语言表达式和指令的操作数相关联,并告诉GCC对这些操作有哪些限制条件。例如在下面的汇编语句:
   __asm__ __violate__ ("movl %1,%0" : "=r" (result) : "m" (input));  

“movl %1,%0”是指令模板;“%0”和“%1”代表指令的操作数,称为占位符,内嵌汇编靠他们将C 语言表达式和指令操作数相对应。指令模板后面用小括号括起来的是C语言表达式,本例中只有两个:“result”和“input”,他们按照出现的顺序分 别和指令操作数“%0”,“%1”对应;注意对应顺序:第一个C 表达式对应“%0”;第二个表达式对应“%1”,依次类推,操作数至多有10 个,分别用“%0”,“%1”….“%9”表示。在每个操作数前面有一个用引号括起来的字符串,字符串的内容是对该操作数的限制或说需要。 “result”前面的限制字符串是“=r”,其中“=”表示“result”是输出操作数,“r”表示需要将“result”和某个通用寄存器相关联, 先将操作数的值读入寄存器,然后在指令中使用相应寄存器,而不是“result”本身,当然指令执行完后需要将寄存器中的值存入变量“result”,从 表面上看似乎是指令直接对“result”进行操作,实际上GCC做了隐式处理,这样我们能够少写一些指令。“input”前面的“r”表示该表达式需要 先放入某个寄存器,然后在指令中使用该寄存器参加运算。
  C表达式或变量和寄存器的关系由GCC自动处理,我们只需使用限制字符串指导 GCC如何处理即可。限制字符必须和指令对操作数的需要相匹配,否则产生的汇编代码将会有错,读者能够将上例中的两个“r”,都改为“m”(m表示操作数 放在内存,而不是寄存器中),编译后得到的结果是:
            movl input, result
很明显这是一条非法指令,因此限制字符串必须和指令对操作数的需要匹配。例如指令movl允许寄存器到寄存器,立即数到寄存器等,但是不允许内存到内存的操作,因此两个操作数不能同时使用“m”作为限定字符。