MQL5编程学习之MT5中的调试功能(Debug)应用

2019-09-18 20:38:52 阅读 :
MetaTrader发展到MT5版本后,虽然相比起专业化的开发工具还有一定距离,但终于初具一个现代化软件开发工具的雏形了,这其中在MetaEditor5中提供的Debug功能(调试功能)就是一个巨大的进步。涉足过MT4编程的朋友可能都有过痛苦的经历:对照着网上的众多代码,东抄西凑,经过一番天昏地暗的折腾后,终于弄出了一个颇为得意的EA或指标,好了,挂到图表上开始享受高科技的便利吧!兴冲冲的等了半天,就是没啥反应!抓狂吧,还不知道抓哪里。。。可能是某个变量忘记赋值了,或者把应该赋给B变量的数值赋给A变量了,怎么办?从头开始慢慢检查,代码少的还能扳着手指头算一下程序运行到哪里了,变量该是多少了,如果成百上千行的代码,那就哭吧。。。 

废话少说(都说了那么多。。。),还是用一个例子来介绍一下Debug的使用方法吧,没有接触过Debug概念的朋友也可藉此机会学习这个强大的功能。 

首先我们来设想一下:假设现在代码中有一个循环,循环中每一次都会给一个变量加1,那么如何知道这个加1的操作是否正确的执行了呢?借助MetaEditor5提供的Debug功能,我们来窥视一下MT5的内部运作吧。新建一个EA,名字随便起,这里姑且叫作DebugDemo吧,其它属性保持默认,确定。生成DebugDemo的代码框架后,首先添加一个int类型的全局变量sum:
int sum = 0;
for (int i=0; i<100; i++) 

sum += 1; 
}
复制代码上面这段代码如具有一定编程基础的朋友应该都能看懂了,就是循环100次,每次给sum这个变量+1。那么,我们现在希望EA运行的时候是逐遍地运行循环,每次循环我们都能观察到sum这个变量里面的数据变化,该怎么做呢?首先,我们给这段代码加入一个断点(BreakPoint)。什么是断点呢?这里作个简单的解释:断点是程序开发中的一个专业术语,通俗来说就是告诉MT5运行到这个断点的时候,就打住了,别往下走了,听候上级吩咐吧!那么,我们的断点放在哪里好呢?(大家往下看之前可以自己想想这个问题的答案)答案是:放在sum被赋值的地方。好了,目标有了,领导发话了那就干活吧,但是,还有个问题,怎么添加断点呢?把鼠标放到希望加入断点的地方(以行为单位),单击右键,选择"Toggle Breakpoint"选项,或直接按快捷键F9,就会在这行的行号位置出现一个蓝色的圆圈,这就表明在当前位置添加了一个断点,当EA代码运行到这个断点位置时,就会停下来了。 

加入断点后,编译代码,运行EA。这时会自动切换到MT5软件上去了,我们这时切换回MetaEditor5,大家可以看到在下方的输出窗口: 

我们在"Expression"下方输入变量名sum: 

按下回车: 

好了,我们刚才干了些什么呢?嗯,我们把变量sum加入了监视列表,从现在起,只要变量sum里面的数据发生任何变化,这里都会即时更新的,通过这种方式,我们就可以实时跟踪变量sum的数值变化,从而达到所谓的调试目的了。 

现在,我们看到"Value"一列中,数值为0,这表明目前为止,sum里面的数据是0,还是我们初始化时候赋的值。但我们这个EA的功能不是让sum循环100遍的+1么?怎么没完成任务就开始休息了呢?呵呵,这就是断点的作用了,由于这行存在断点,所以程序运行到sum第一次赋值之前就停下来了,领导不发话,谁敢动啊。。。 

这时候,我们看看工具栏,有3个本来是灰色的按钮变成可用状态了: 

我们点击一下第一个按钮"Setp into",这时就会发现value一栏的数值发生了变化,从0变为1了,这是因为程序跑了一遍循环,给变量sum进行+1了。顾名思义,setp into,就是步进,也就是一步步的来运行。举个例子,大家应该都参加过军训吧?在练习正步走的时候,教官通常都会进行分解动作练习(不堪回首的记忆啊。。。),教官喊“一”,大家踢左脚,喊“二”,大家踢右脚。。。我们这里也大概是那么回事了,每按一下"Setp into"按钮,EA就动一下,由于这里总共要循环100遍,所以每次EA就循环一遍,变量sum就被+1一次,如此往复循环。。。 

好了,至此就结束了关于Debug功能的简单介绍,由于笔者能力所限,只能起个抛砖引玉的作用,希望有经验的朋友能在论坛上不吝分享关于Debug的使用心得,或来人来函来电以及来而不往非礼也之进行关于MQL5开发方方面面之热烈洽谈。。。 

作者:阿郎(shawnyau)

本文标题:MQL5编程学习之MT5中的调试功能(Debug)应用 - 外汇智能交易编程
本文地址:http://whb.kaifamei.cn/fxschool/autotrading/3248.html

相关文章

你可能感兴趣