MySQL UDF調(diào)試方式debugview的相關(guān)方法
更新時(shí)間:2007年07月29日 18:02:48 作者:
MySQL的UDF實(shí)質(zhì)就是一個(gè)不需要設(shè)置入口點(diǎn)的動(dòng)態(tài)連接庫(*Nix稱之為共享庫)。對(duì)于DLL的調(diào)試可謂個(gè)人有個(gè)法?,F(xiàn)在我介紹一下一個(gè)非常簡(jiǎn)單的易用的調(diào)試方法。這一方法直接利用Windows API,語言無關(guān)、開發(fā)工具無關(guān)、項(xiàng)目類型無關(guān),典型的三無調(diào)試方法。并且,我們從這里討論的調(diào)試方法支持遠(yuǎn)程調(diào)試,對(duì)于一時(shí)無法掌握開發(fā)工具原本調(diào)試器而又急于尋找程序錯(cuò)誤的朋友此方法非常實(shí)用!
首先我們需要下載接收端,當(dāng)然有心人也可以自己寫一個(gè)。在 http://www.sysinternals.com/ntw2k/freeware/debugview.shtml 。透過debugview手冊(cè)我們可以知道這個(gè)工具支持win9x/nt系列,并且支持內(nèi)核調(diào)試!由于其調(diào)用的API均只能接收一個(gè)char * 類型參數(shù),所以有些時(shí)候我們需要利用其他的函數(shù)有機(jī)組合產(chǎn)生人性可讀提示。
為了減少?gòu)?fù)雜程度簡(jiǎn)單的以來自 http://delphi.ktop.com.tw/topic.asp?TOPIC_ID=35166 討論為例,講解我是如何利用這里工具進(jìn)行調(diào)試的。
1 簡(jiǎn)單輸出一行信息,在調(diào)試開始時(shí)輸出一條簡(jiǎn)單的信息便于我們了解debug到什么地方了。
在程序代碼中根據(jù)需要加入下邊一行
OutputDebugStringA("--UDF:my_name()被調(diào)用");
這樣一來我就知道我定義的my_name被客戶用到了,接著我要關(guān)心返回值如何。
2 輸出返回值
輸出返回值方法很多,可以自由組合。自由組合的最終目的是將一個(gè)有效的 char * 類型參數(shù)傳遞給WiNDOWS API。這里簡(jiǎn)單的以C語言字符控制函數(shù)為例。
例子:
#include /* 函數(shù)- sprintf */
#include /* 掛接windows api */
/* ...........省略 */
char* __stdcall my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)
{
OutputDebugStringA("--UDF:my_name()被調(diào)用"); /* 調(diào)用了?*/
char *me = "my name";
/*---- debuger start----*/
char debugermsg[256]={0};
sprintf(debugermsg, "%s", me);
OutputDebugStringA(debugermsg);
/*---- debuger end----*/
return me;
}
當(dāng)在程序中加入了類似代碼那么調(diào)試就可以開始了,利用這種方式即便不使用"debuger"方式編譯仍然可以得到所需的調(diào)試信息。
接收調(diào)試信息
接收調(diào)試信息只要打開debugview程序即可,程序主窗口可以實(shí)時(shí)返回所需要的調(diào)試信息。
其它平臺(tái)請(qǐng)自行查閱手冊(cè)獲得對(duì)應(yīng)的api,利用這種方式調(diào)試方法適當(dāng)并不會(huì)造成任何困擾。
首先我們需要下載接收端,當(dāng)然有心人也可以自己寫一個(gè)。在 http://www.sysinternals.com/ntw2k/freeware/debugview.shtml 。透過debugview手冊(cè)我們可以知道這個(gè)工具支持win9x/nt系列,并且支持內(nèi)核調(diào)試!由于其調(diào)用的API均只能接收一個(gè)char * 類型參數(shù),所以有些時(shí)候我們需要利用其他的函數(shù)有機(jī)組合產(chǎn)生人性可讀提示。
為了減少?gòu)?fù)雜程度簡(jiǎn)單的以來自 http://delphi.ktop.com.tw/topic.asp?TOPIC_ID=35166 討論為例,講解我是如何利用這里工具進(jìn)行調(diào)試的。
1 簡(jiǎn)單輸出一行信息,在調(diào)試開始時(shí)輸出一條簡(jiǎn)單的信息便于我們了解debug到什么地方了。
在程序代碼中根據(jù)需要加入下邊一行
OutputDebugStringA("--UDF:my_name()被調(diào)用");
這樣一來我就知道我定義的my_name被客戶用到了,接著我要關(guān)心返回值如何。
2 輸出返回值
輸出返回值方法很多,可以自由組合。自由組合的最終目的是將一個(gè)有效的 char * 類型參數(shù)傳遞給WiNDOWS API。這里簡(jiǎn)單的以C語言字符控制函數(shù)為例。
例子:
#include /* 函數(shù)- sprintf */
#include /* 掛接windows api */
/* ...........省略 */
char* __stdcall my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)
{
OutputDebugStringA("--UDF:my_name()被調(diào)用"); /* 調(diào)用了?*/
char *me = "my name";
/*---- debuger start----*/
char debugermsg[256]={0};
sprintf(debugermsg, "%s", me);
OutputDebugStringA(debugermsg);
/*---- debuger end----*/
return me;
}
當(dāng)在程序中加入了類似代碼那么調(diào)試就可以開始了,利用這種方式即便不使用"debuger"方式編譯仍然可以得到所需的調(diào)試信息。
接收調(diào)試信息
接收調(diào)試信息只要打開debugview程序即可,程序主窗口可以實(shí)時(shí)返回所需要的調(diào)試信息。
其它平臺(tái)請(qǐng)自行查閱手冊(cè)獲得對(duì)應(yīng)的api,利用這種方式調(diào)試方法適當(dāng)并不會(huì)造成任何困擾。
相關(guān)文章
2022最新版MySQL 8.0.30 安裝及配置教程(小白入門)
這篇文章主要介紹了2022最新版MySQL 8.0.30 安裝及配置教程,安裝過程算是比較簡(jiǎn)單的,今天給大家分享的此文比較適合mysql數(shù)據(jù)庫的小白,需要的朋友可以參考下2022-09-09mysql中迅速插入百萬條測(cè)試數(shù)據(jù)的方法
最近想到創(chuàng)建一個(gè)大量數(shù)據(jù)的測(cè)試環(huán)境,于是找了一下怎么插入100W條數(shù)據(jù),我用的是20個(gè)字段2012-04-04Mysql服務(wù)器的安裝配置與啟動(dòng)關(guān)閉方法詳解
MySQL 是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),在 WEB 應(yīng)用方面 MySQL 是最好的 RDBMS(Relational Database Management System:關(guān)系數(shù)據(jù)庫管理系統(tǒng))應(yīng)用軟件之一2021-10-10MySQL數(shù)據(jù)庫遷移data文件夾位置詳細(xì)步驟
這篇文章主要介紹了MySQL數(shù)據(jù)庫遷移data文件夾詳細(xì)步驟,需要的朋友可以參考下2014-03-03mysql數(shù)據(jù)庫優(yōu)化需要遵守的原則
這是我在網(wǎng)上看到的一篇不錯(cuò)的mysql數(shù)據(jù)庫優(yōu)化文章,拿出來和大家分享,希望可以幫助你們2012-12-12Windows下通過cmd進(jìn)入DOS窗口訪問MySQL數(shù)據(jù)庫
這篇文章主要介紹了Windows下通過cmd進(jìn)入DOS窗口訪問MySQL數(shù)據(jù)庫的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03Mysql表創(chuàng)建外鍵報(bào)錯(cuò)解決方案
這篇文章主要介紹了Mysql表創(chuàng)建外鍵報(bào)錯(cuò)解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09