编写LLDB脚本
先在 /Volumes/WIN/Python 这个目录下新建一个HelloWorld.py的文件,文件内容如下:
# -*- coding:utf-8 -*-
# debugger 是当前调试器对象,类型是lldb.SDBDebugger
# command 是命令的参数,类型是字符串
# reulit 是执行命令后返回的参数,类型是lldb.SBCommandReturnObject
# internal_dict 是当前脚本所有变量和函数,类型是字典
def test(debugger, command, result, internal_dict):
""" This is my first lldb script """
print "hello, world"
# lldb_init_module函数是在加载脚本时会执行的
# command script -f 是用于将Python代码导出成自定义的命令,其中HelloWorld是脚本的名称,这个要和脚本的文件名保持一致,test是函数的名称,mycmd是导出的命令名称。
# 启动 LLDB 加载这一段脚本,输入 mycmd 命令就可以执行 test 函数里的代码。
def __lldb_init_module(debugger, internal_dict):
debugger.HandleCommand("command script add -f HelloWorld.test mycmd");
使用
- 将脚本引入调试器
command script import python脚本文件路径
command script import /Volumes/WIN/Python/HelloWorld.py
- 输入 help mycmd 可以查看到相应的提示信息
- 输入 mycmd 命令可以看到打印出 hello, world,证明 test 函数的代码得到执行。
问题
- python语法错误 no encoding declared
SyntaxError: Non-ASCII character '\xe5' in file Test1.py on line 8, but no encoding declared; see http://www.python.org/peps/pep-0263.html for details
原因:
如果要在python2的py文件里面写中文,则必须要添加一行声明文件编码的注释,否则python2会默认使用ASCII编码。
解决:
python的默认编码文件用的是ASCII码,将文件存成了UTF-8,编译通过。
也可以在py文件开头(必须在最前面),加入
#coding=utf-8
或者
# -*- coding:utf-8 -*-
了解LLDB配置文件
LLDB打开时会自动加载 ~/.lldbinit配置文件,通过这个配置文件可以设置加载的脚本路径等。上面我们编写的脚本文件H e l lo W o r l d.py,在启动LLDB需要手动执行 command script import 才能加入脚本,如果将command script import 添加到 ~/.lldbibit 中,那么每次启动LLDB时就会自动引入脚本。默认这个配置文件是不存在的,我们手动创建一个,然后添加下面的命令,这样每次LLDB启动都会自动引入HelloWorld.py
command script import /Volumes/WIN/Python/HelloWorld.py
除了引入自定义脚本,lldbinit配置文件还可以设置命令的别名、命令提示符文字等,比如我们添加下面的信息:
setting set prompt "(exchen lldb)"command alias connect process connect connect://127.0.0.1:1234
此时再进入LLDB会发现命令行的提示文字显示的是“(exchen lldb)”,输入connect命令别名就可以连接程序进行LLDB动态调试,省去了每次烦琐地输入一大串命令。