MQL4基础:编译预处理

目录[hide]

  • 预定义常量
  • 编译控制
  • 文件包含
  • 函数导入

预处理程序是MQL4编译程序的一个特殊的组成部分,用于在程序被编译之前预先准备好程序源码。

预处理程序能增强程序源码的可读性。在MQL4程序中,通过包含指定的文件可以获得结构化源码,给常量取一个易于记忆的名字有助于增强源码的可读性。

预处理程序也允许MQL4程序定义特定的参数。

如果#号置于程序的第一行,那么该行就是预处理程序的控制指令。预处理程序指令以回车换行结束。

Back to Top

预定义常量

使用 #define 命令,我们可以在程序中定义符号名或符号常量代表特定的字符串。随后,编译程序会把所有符号名替换成相应的字符串。事实上,这些名称可以被任意的文本替换,并不局限于数字:

#define identifier value

常量符号名同样遵守变量名的命名规则,值可以是以下任意类型:

#define ABC          100
#define PI           0.314
#define COMPANY_NAME "myEAtrade Inc."
...
void ShowCopyright() { Print("版权所有 © 2001-2007, ",COMPANY_NAME); Print("https://www.MyFxtop.com"); }
Back to Top

编译控制

每个MQL4程序允许指定额外的特定参数,这些参数用#property命名,它不需要用户明确地启动程序,就可帮助客户端提供合适的服务。要注意的是,这个功能还与技术指标的外部设定有关。

#property 识别值
常数 类型 描述
link string 公司网站的相关连接
copyright string 公司名称
stacksize int 堆栈大小
library  
indicator_chart_window void 在图表窗口显示指标
indicator_separate_window void 在独立显示窗口显示指标
indicator_buffers int 计算指标的缓冲区个数,最大为8
indicator_minimum double 独立显示的指标窗口下端缩放比例
indicator_maximum double 独立显示的指标窗口上端缩放比例
indicator_colorN color 线1到线8的显示颜色
indicator_widthN int 线1到线8的显示宽度
indicator_styleN int 线1到线8的显示样式
indicator_levelN double 自定义指标的第N条水平线(N为1到8)
indicator_levelcolor color 自定义指标的第N条水平线颜色(N为1到8)
indicator_levelwidth int 自定义指标的第N条水平线宽度(N为1到8)
indicator_levelstyle int 自定义指标的第N条水平线样式(N为1到8)
show_confirm void 在脚本运行之前显示确认框
show_inputs void 在脚本运行之前显示它的属性表;禁用show_confirm属性

示例:

#property link        "https://www.MyFxtop.com"
#property copyright   "myEAtrade Inc."
#property library
#property stacksize   1024

在所执行模块的设置中,编译程序将会保存这些已说明的值。

Back to Top

文件包含

#include 命令行可以放置在程序的任意部分,但是所有的“文件包含”通常都被统一放置在源代码的开头。调用格式:

#include <file_name>
#include "file_name";

示例:

#include <WinUser32.mqh>
#include "mylib.mqh"

预处理程序将用WinUser32.mgh文件内容替换这一行。尖括号表示WinUser32.mqh文件将会从默认目录调用(通常默认目录为terminal_ directory/experts/include)。不会搜索当前目录。

如果文件名用引号括起来,将在当前目录中搜索该文件(源码主文件所在位置)。不会搜索标准目录。

Back to Top

函数导入

函数可从MQL4编译过的模块(*.EX4文件)和操作系统文件模块(*.DLL文件)导入过来。模块名需要在#import指令中指定。因为编译程序能够以适当的方式生成被导入的函数调用和传递参数,函数的完整说明是必需的。函数说明要紧跟在 #import "module name” 命令后而,以新的#import命令(不带参数)结束导入函数说明块。

#import "file_name"
    func1 define;
    func2 define;
    ...
    funcN define;
#import

导入函数必须有唯一的名称。相同名称的函数无法从不同的模块同时导入。导入的函数名称不能与那些内置函数冲突。

由于导入函数是在模块之外编译的,编译程序无法检查参数传递的正确性。这就是为什么,为了避免运行时错误,有必要精确地说明参数类型定义和参数顺序的原因。传递到导入函数(从EX 和从DLL模块)的这些参数不能通过默认值获得值。

示例:

#import "user32.dll"
   int    MessageBoxA(int hWnd, string lpText, string lpCaption, int uType);
#import "stdlib.ex4" string ErrorDescription(int error_code); int RGB(int red_value, int green_value, int blue_value); bool CompareDoubles(double number1, double number2); string DoubleToStrMorePrecision(double number, int precision); string IntegerToHexString(int integer_number);
#import "Expert示例.dll" int GetIntValue(int); double GetDoubleValue(double); string GetStringValue(string); double GetArrayItemValue(double arr[], int, int); bool SetArrayItemValue(double& arr[], int,int, double); double GetRatesItemValue(double rates[][6], int, int, int); int SortStringArray(string& arr[], int); int ProcessStringArray(string& arr[], int); #import

对于在MQL4程序执行期间导入的函数,采用了所谓的“后期联编”。这就意味着只要导入的函数未被调用,相应的模块(EX4或DLL)就不会被加载。

不推荐使用全路径文件名Drive:/Directory/FileName.Ext加载模块。MQL4库会从terminal_dir/experts/libraries文件夹中载入进来。如果没有找到库,就会尝试从terminal_dir/experts文件夹中加载。

Back to Top

 

 


MyFxtop迈投-靠谱的外汇跟单社区,免费跟随高手做交易!

 

免责声明:本文系转载自网络,如有侵犯,请联系我们立即删除,另:本文仅代表作者个人观点,与迈投财经无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。

著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。

風險提示

MyFxtops邁投所列信息僅供參考,不構成投資建議,也不代表任何形式的推薦或者誘導行為。MyFxtops邁投非外匯經紀商,不接觸妳的任何資金。 MYFXTOPS不保證客戶盈利,不承擔任何責任。從事外彙和差價合約等金融產品的槓桿交易具有高風險,損失有可能超過本金,請量力而行,入市前需充分了解潛在的風險。過去的交易成績並不代表以後的交易成績。依據各地區法律法規,MyFxtops邁投不向中國大陸、美國、加拿大、朝鮮居民提供服務。

邁投公眾號

聯繫我們

客服QQ:981617007
Email: service@myfxtop.com

MyFxtops 邁投