出典: http://www.codefrom.com/paper/%E4%BD%BF%E7%94%A8gdb%E8%B0%83%E8%AF%95p...
PHP 拡張機能は c/c++ を使用して開発され、gdb を使用して簡単にデバッグできます。具体的な手順は次のとおりです。
まず、php をコンパイルするときに ** --enable-debug** パラメータを追加する必要があります
./configure --enable-debugmake && make install
私の ubuntu マシンでテストしたところ、拡張ディレクトリはデフォルトになっています/usr/ local/lib/php/extensions/debug-non-zts-20131226/
これは、PHP ソース コードをデバッグする場合にも非常に便利です。
次のステップは拡張機能を作成することです。PHP ソース コードの ext ディレクトリに入り、
./ext_skel --extname=mydebug
を実行します。mydebug ディレクトリが現在のディレクトリに自動的に生成されます。ディレクトリに入り、 config.m4 ファイルを編集し、次のように 10 ~ 12 行の dnl を削除します
PHP_ARG_WITH(mydebug, for mydebug support,Make sure that the comment is aligned:[ --with-mydebug Include mydebug support])
最後の行に
if test -z "$PHP_DEBUG"; then AC_ARG_ENABLE(debug, [--enable-debg compile with debugging system], [PHP_DEBUG=$enableval], [PHP_DEBUG=no] )fi
を追加しますこれは、拡張機能をデバッグできることを意味します。拡張機能をコンパイルするには、コマンド
phpize ./configure --enable-debugmake && make install
を使用します。ここで、phpize と php-config は事前に環境変数を設定してから、拡張機能をロードする必要があります。私のマシンのアドレスは /usr/local/lib/php/extensions/debug-non-zts-20131226/ です。 mydebug 拡張ソース コード ディレクトリを入力します。デフォルトで生成される関数はconfirm_mydebug_compiled で、mydebug.c で定義され、自動生成される関数を拡張します。
PHP_FUNCTION(confirm_mydebug_compiled){ char *arg = NULL; int arg_len, len; char *strg; if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &arg, &arg_len) == FAILURE) { return; } len = spprintf(&strg, 0, "Congratulations! You have successfully modified ext/%.78s/config.m4. Module %.78s is now compiled into PHP.", "mydebug", arg); RETURN_STRINGL(strg, len, 0);}
おそらく、文字列パラメーターを取得し、それを文字列に綴って返すことを意味します。 nm コマンドを使用して、生成された mydebug.so によってエクスポートされたシンボルを表示します。
运行 nm mydebug.so返回 zif_confirm_mydebug_compiled ……
PHP_FUNCTION は実際には関数名の前に zif_ を追加し、gdb デバッグを実行します
第一步运行: gdb php然后运行: break zif_confirm_mydebug_compiled终端提示:Function "zif_confirm_mydebug_compiled" not defined.Make breakpoint pending on future shared library load? (y or [n]) 输入: y输入: run /tmp/test.php此时会回显:Breakpoint 1, zif_confirm_mydebug_compiled (ht=1, return_value=0xb7bf0d44, return_value_ptr=0xb7bd6104, this_ptr=0x0, return_value_used=1) at /...../php-5.6.6/ext/mydebug/mydebug.c:56然后输入: l显示:54 PHP_FUNCTION(confirm_mydebug_compiled)55 {56 char *arg = NULL;57 int arg_len, len;58 char *strg;5960 if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &arg, &arg_len) == FAILURE) {
ファイル /tmp/test.php の内容は次のとおりです:
<?phpecho confirm_mydebug_compiled("hello world");
ご覧のとおり、関数のソース コードが公開されており、デバッグに一般的な gdb コマンドを使用できます。
さらにエキサイティングなオリジナル コンテンツは http://www.codefrom.com/ にあります