EATC

 找回密码
 立即注册
查看: 530|回复: 0

MQL4基础:编译预处理

[复制链接]

192

主题

1118

帖子

1210

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1210
发表于 2022-8-19 11:43:55 | 显示全部楼层 |阅读模式
  • 预定义常量
  • 编译控制
  • 文件包含
  • 函数导入

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

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

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

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

预定义常量

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

#define identifier value

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

#define ABC          100#define PI           0.314#define COMPANY_NAME "myEAtrade Inc."
...
void ShowCopyright()  {   Print("版权所有 © 2001-2007, ",COMPANY_NAME);   Print("http://www.myeatrade.com");  }编译控制

每个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        "http://www.myeatrade.com"#property copyright   "myEAtrade Inc."#property library#property stacksize   1024

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

文件包含

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

#include <file_name>#include "file_name";

示例:

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

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

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

函数导入

函数可从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文件夹中加载。

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

收藏本站|法律声明|Archiver|小黑屋|support@ea198.com|EATC ( 桂ICP备2022005787号 )

风险提示与免责声明:擅自从事外汇保证金交易的双方不受法律保护!社区内展示内容,均为网友自发分享,不构成投资建议,社区无法全面监控由第三方上传至社区的资源,因此不保证资源的合法性、安全性、完整性、真实性或品质等。您下载时,同意自行判断并承担所有风险。社区内的资源,仅限用于学习和研究目的,不得将用于商业或者非法用途,否则,一切后果请用户自负。社区信息来自网络,版权争议与社区无关,您下载后须在24个小时之内进行删除。如果您喜欢该内容,请支持正版。如有侵权请邮件与我们联系处理。