• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

如何利用Debugview方式来调试MySQL UDF_MySQL

mysql 搞代码 4年前 (2022-01-09) 29次浏览 已收录 0个评论

MySQL的UDF实质就是一个不需要设置入口点的动来源gaodai#ma#com搞@代~码$网态连接库(*Nix称之为共享库)。对于DLL的调试可谓个人有个法。现在我介绍一下一个非常简单的易用的调试方法。这一方法直接利用Windows API,语言无关、开发工具无关、项目类型无关,典型的三无调试方法。并且,我们从这里讨论的调试方法支持远程调试,对于一时无法掌握开发工具原本调试器而又急于寻找程序错误的朋友此方法非常实用!

首先我们需要下载接收端,当然有心人也可以自己写一个。

透过debugview手册我们可以知道这个工具支持win9x/nt系列,并且支持内核调试!由于其调用的API均只能接收一个char * 类型参数,所以有些时候我们需要利用其他的函数有机组合产生人性可读提示。

1、简单输出一行信息,在调试开始时输出一条简单的信息便于我们了解debug到什么地方了。

在程序代码中根据需要加入下边一行:

OutputDebugStringA("--UDF:my_name()被调用");

这样一来我就知道我定义的my_name被客户用到了,接着我要关心返回值如何。

2、输出返回值。

输出返回值方法很多,可以自由组合。自由组合的最终目的是将一个有效的 char * 类型参数传递给WiNDOWS API。这里简单的以C语言字符控制函数为例。

例子:

#include   /* 函数- sprintf */ #include  /* 挂接windows api */ /* ...........省略   */ char* __stdcall my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error) { OutputDebugStringA("--UDF:my_name()被调用"); /* 调用了?*/ char *me = "my name"; /*---- debuger start----*/ char debugermsg[256]={0}; sprintf(debugermsg, "%s", me); OutputDebugStringA(debugermsg); /*---- debuger end----*/  return me; }

当在程序中加入了类似代码那么调试就可以开始了,利用这种方式即便不使用“debuger”方式编译仍然可以得到所需的调试信息。

接收调试信息

接收调试信息只要打开debugview程序即可,程序主窗口可以实时返回所需要的调试信息。

其它平台请自行查阅手册获得对应的api,利用这种方式调试方法适当并不会造成任何困扰。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:如何利用Debugview方式来调试MySQL UDF_MySQL

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址