打开终端:鼠标右键-OpenTerminal
linux终端复制文件权限不够命令:sudo nautilus
linux终端解压压缩包权限不够(Permission denied)命令:sudo chmod -R 777 压缩包名称,之后再解压就不会出现权限问题啦
linux下解压.tar.gz:
tar -xvzf 文件名(文件名是.tar.gz格式)
Linux下解压.tar:
tar -xvf 文件名(文件名是.tar格式)
linux下解压.zip:
unzip 文件名(文件名是.zip格式)
linux终端打开文件权限不够命令:
sudo su
如下图所示:
Linux下gdb:
gdb+文件名 eg:gdb ctarget
gdb exam
反汇编:
x/s $r3 可以查看寄存器r3
b *0x10878设置指定位置断点
speti逐步运行
disas查看当前运行位置
delete1删除上一个断点
delete删除所有断点
q(即quit的简称)可以退出gdb
sp/esp/rsp(16bit/32bit/64bit)栈寄存器—指向栈顶
bp/ebp/rbp 栈基址寄存器—指向栈底
ip/eip/rip 程序指令寄存器—指向下一条待执行指令
寄存器%rip:一个新的寻址形式,在64位模式下实现,有效地址是
下一条指令的虚拟地址+偏移
eg:
7ffff7a97759 mov 0x33b780(%rip),%rax #0x7ffff7dd2ee0
7ffff7a97760 mov (%rax),%rax
解释如下:
读取rip中的地址,并加上0x33b780。此时,rip包含下一条指令的地址,即0x7ffff7a97760,加上0x33b780,就得到0x7ffff7dd2ee0,这是注释中的地址。它将存储在该地址的8字节值复制到rax中。
movb、movsbl和movzbl之间的差别如下:
假设%dh =8D,%eax=98765432
movb %dh ,%a1 %eax=9876548D
movsbl %dh , %eax %eax=FFFFFF8D
movzbl %dh,%eax %eax=0000008D
在以上的例子中都是将寄存器%eax 的低位字节设置为%dh 的字节。
movb指令不改变其他三个字节。
根据原字节的最高位,movsbl指令将其他三个字节设为全1或全0。
movzbl指令无论如何都是将其他三个字节设为全0。
汇编后缀字母
b 字节 = 1字节 w 字 = 2字节
l 双字 = 4字节 q 四字 = 8字节
图 一和图 二记录的是两类数据移动指令,在将较小的源值复制到较大的目的时使用。所有这些指令都把数据从源(在寄存器或内存中)复制到目的寄存器。MOVZ 类中的指令把目的中剩余的字节填充为 0, 而 MOVS类中的指令通过符号扩展来填充,把源操作的最高位进行复制。可以观察到,每条指令名字的最后两个字符都是大小指示符:第一个字符指定源的大小,而第二个指明目的的大小。正如看到的那样,这两个类中每个都有三条指令,包括了所有的源大小为 1 个和 2 个字节、目的大小为 2 个和 4 个的情况,当然只考虑目的大于源的情况。
图一
图二
汇编语言一些指令及其效果和描述: