后台开发常用工具 开发工具
1、查看二进制文件的内容::
hexdump filename 或者 hexdump -C filename
查看二进制文件的内容。
与hexdump相类似的还有od 。它可以查看文件的实际内容。非常有用。od -c 将看到非常多的内容。
2、将可执行程序反汇编成汇编代码::
objdump -S filename > filename2
3、查看二进制文件中的所有字符串::
strings filename
4、dd作用是用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。
如拷贝MBR中的内容::
dd if=filepath(输入文件的路径) of=filepath(输出文件的路径) bs=每一块的大小 count=复制的块数。
命令dd 及简单应用
由于 dd 命令允许二进制方式读写,所以特别适合在原始物理设备上进行输入/输出。例如可以用下面的命令为软盘建立镜像文件:dd if=/dev/fd0 of=disk.img bs=1440k
有趣的是,这个镜像文件能被 HD-Copy ,Winimage 等工具软件读出。再如把第一个硬盘的前 512 个字节存为一个文件:
dd if=/dev/hda of=disk.mbr bs=512 count=1
功能:
把指定的输入文件拷贝到指定的输出文件中,并且在拷贝过程中可以进行格式转换。可以用该命令实现DOS下的diskcopy命令的作用。先用dd命令把软盘上的数据写成硬盘的一个寄存文件,再把这个寄存文件写入第二张软盘上,完成diskcopy的功能。需要注意的是,应该将硬盘上的寄存文件用rm命令删除掉。系统默认使用标准输入文件和标准输出文件。
语法:dd [选项]
if =输入文件(或设备名称),缺省为标准输入。
of =输出文件(或设备名称),缺省为标准输出。
ibs = bytes 一次读取bytes字节,即读入缓冲区的字节数。 (认为每一块的字节数)
obs = bytes 一次写入bytes字节,即写入缓冲区的字节数。
bs = bytes 同时设置读/写缓冲区的字节数(等于设置ibs和obs)。
count=blocks 只拷贝输入的blocks块。
cbs = byte 一次转换bytes字节。
skip = blocks 跳过读入缓冲区开头的ibs*blocks块。
conv = ASCII 把EBCDIC码转换为ASCIl码。
conv = ebcdic 把ASCIl码转换为EBCDIC码。
conv = ibm 把ASCIl码转换为alternate EBCDIC码。
conv = block 把变动位转换成固定字符。
conv = ublock 把固定位转换成变动位。
conv = ucase 把字母由小写转换为大写。
conv = lcase 把字母由大写转换为小写。
conv = notrunc 不截短输出文件。
conv = swab 交换每一对输入字节。
conv = noerror 出错时不停止处理。
conv = sync 把每个输入记录的大小都调到ibs的大小(用NUL填充)
seek=blocks 从输出文件开头跳过 blocks 个块后再开始复制。(通常只有当输出文件是磁盘或磁带时才有效)
如何用DD来使WIN引导LINUX
dd bs=512 count=1 if=/dev/hda5 of=bootsect.lnx
dd bs=512 count=1 if=/dev/hda3 of=bootsect.bsd
然后再mount到DOS分区,将bootsect.lnx与bootsect.bsd拷贝到C盘根目录下,就基本上大功告成了。
最后进入Windows 2000,编辑C盘根目录下的boot.ini文件,加入以下两行:
C:BOOTSECT.LNX=”Linux”
C:BOOTSECT.BSD=”FreeBSD”
然后就可以重新启动。
5、valgrind用来监视内存的使用情况。
valgrind ./filename
6、runlevel查看init进程的运行级别,即linux操作系统运行在那个级别。
发表评论
要发表评论,您必须先登录。