dSYM 文件的作用

来源:互联网 发布:上海自贸区 知乎 编辑:程序博客网 时间:2024/06/06 01:51

原文链接:http://www.cnblogs.com/pengyingh/articles/2502178.html

在 XCODE 编译项目之后,会在 app 旁看见一个同名的 dSYM 文件.
他是一个编译的中转文件,简单说就是 debug 的 symbols 包含在这个文件中.
他有什么作用?当 release 的版本 crash的时候,会有一个日志文件,包含出错的内存地址,
使用 symbolicatecrash 工具能够把日志和 dSYM 文件转换成可以阅读的 log 信息,
也就是将内存地址,转换成程序里的函数或变量和所属于的 文件名.
有一篇详细的 blog 讲了这个过程
http://www.anoshkin.net/blog/2008/09/09/iphone-crash-logs/
将类似
Thread 0 Crashed:
0 libobjc.A.dylib 0×300c87ec 0×300bb000 + 55276
1 MobileLines 0×00006434 0×1000 + 21556
2 MobileLines 0×000064c2 0×1000 + 21698
3 UIKit 0×30a740ac 0×30a54000 + 131244

的 log 信息转换成
Thread 0 Crashed:
0 libobjc.A.dylib 0×300c87ec objc_msgSend + 20
1 MobileLines 0×00006434 -[BoardView setSelectedPiece:] (BoardView.m:321)
2 MobileLines 0×000064c2 -[BoardView touchesBegan:withEvent:] (BoardView.m:349)
3 UIKit 0×30a740ac -[UIWindow sendEvent:] + 264

的有用信息.
工具 symbolicatecrash 隐藏在
/Developer/Platforms/iPhoneOS.platform/Developer/Library/Xcode/Plug-ins/
iPhoneRemoteDevice.xcodeplugin/Contents/Resources/symbolicatecrash

所以一般复制到 /usr/local/bin/ 成为命令行直接调用
$ sudo cp /Developer/Platforms/iPhoneOS.platform/Developer/Library/
Xcode/Plug-ins/iPhoneRemoteDevice.xcodeplugin/
Contents/Resources/symbolicatecrash /usr/local/bin/

这个时候运行
$ symbolicatecrash -h
就能看见帮助信息了.
这个时候,问题又来了..
每次编译后的 dSYM 文件都要手动保存一次,很是麻烦.
于是有人写了一个脚本,自动在编译后保存该文件.
请参考:
http://www.cimgf.com/2009/12/23/automatically-save-the-dsym-files/
脚本我复制过来在下面

#!/bin/shif [ "$BUILD_STYLE" == "Debug" ]; thenecho “Skipping debug”exit 0;fiif [ "$EFFECTIVE_PLATFORM_NAME" == "-iphonesimulator" ]; thenecho “Skipping simulator build”exit 0;fiSRC_PATH=${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}RELATIVE_DEST_PATH=dSYM/${EXECUTABLE_NAME}.$(date +%Y%m%d%H%M%S).app.dSYMDEST_PATH=${PROJECT_DIR}/${RELATIVE_DEST_PATH}echo “moving ${SRC_PATH} to ${DEST_PATH}”mv “${SRC_PATH}” “${DEST_PATH}”if [ -f ".git/config" ]; thengit add “${RELATIVE_DEST_PATH}”git commit -m “Added dSYM file for ${BUILD_STYLE} build” “${RELATIVE_DEST_PATH}”fi
-eof-

0 0