EATC

 找回密码
 立即注册
查看: 872|回复: 2

MQL4数组处理相关函数(三)

[复制链接]

192

主题

1118

帖子

1210

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1210
发表于 2022-8-22 11:53:35 | 显示全部楼层 |阅读模式

用于数组处理的一组函数。

数组的最大维数为四维。每一维索引编号为0至(数组大小 减 1)。例如,在50个元素的一维数组中,调用第一个元素用array[0],最后一个元素用array[49]。

  • ArrayBsearch() – 数组搜索
  • ArrayCopy() – 数组复制
  • ArrayCopyRates() – 复制柱体(K线)数据到二维数组
  • ArrayCopySeries() – 复制柱体(K线)数据到一维数组
  • ArrayDimension() – 返回数组维数
  • ArrayGetAsSeries() – 判断序列数组
  • ArrayInitialize() – 数组初始化
  • ArrayIsSeries() – 判断数组是否序列化
  • ArrayMaximum() – 返回数组中最大值的位置
  • ArrayMinimum() – 返回数组中最小值的位置
  • ArrayRange() – 获取数组元素个数
  • ArrayResize() – 重设数组大小
  • ArraySetAsSeries() – 设置为序列化数组
  • ArraySize() – 获取数组大小
  • ArraySort() – 数组排序

ArrayRange() – 获取数组元素个数int ArrayCopy(object array[], int range_index)

返回给定数组指定维数中元素的个数。由于下标从零开始,数组的大小要比最大下标数多1。

参数:

array[] - 需要检查的数组。 range_index - 指定的维数。

示例:

int    dim_size;double num_array[10,10,10];dim_size=ArrayRange(num_array, 1);ArrayResize() – 重设数组大小int ArrayResize(void array[], int new_size)

设定数组第一维的新大小。如果执行成功的话,函数将返回新数组的元素个数,否则,返回-1,数组大小并不改变。

注:函数执行完成后,在函数内局部定义和重设大小的数组将维持原样不变。在函数被重新调用后,这种数组的大小将会与定义时大小有差异。

参数:

array[] - 需重设大小的数组。 new_size - 第一维数组大小的新值。

示例:

double array1[][4];int    element_count=ArrayResize(array1, 20);// 新的大小 - 80个元素(每维20个元素,共4维)ArraySetAsSeries() – 设置为序列化数组bool ArraySetAsSeries(void array[], bool set)

设定数组的排列方向。如果设置参数值为TRUE,数组将按逆序排列,也就是说,数组元素下标为0的值是最后的值。如果其值为FALSE,表明数组是一个正常的排列顺序,此函数原样返回以前的数组。

参数:

array[] - 数值型数组。 set - 数组索引顺序,true 或者 false。

示例:

double macd_buffer[300];double signal_buffer[300];int    i,limit=ArraySize(macd_buffer);ArraySetAsSeries(macd_buffer,true); for(i=0; i<limit; i++)   macd_buffer=iMA(NULL,0,12,0,MODE_EMA,PRICE_CLOSE,i)-iMA(NULL,0,26,0,MODE_EMA,PRICE_CLOSE,i);   for(i=0; i<limit; i++)   signal_buffer=iMAOnArray(macd_buffer,limit,9,0,MODE_SMA,i);ArraySize() – 获取数组大小int ArraySize(object array[])

返回数组元素的个数。对于一个一维数组,用ArraySize()函数返回的大小和ArrayRange(array, 0)的结果相等。

参数:

array[] - 任何类型的数组。  

示例:

int count=ArraySize(array1);for(int i=0; i<count; i++)  {   // 一些计算.  }ArraySort() – 数组排序int ArraySort(void array[], void count, void start, void sort_dir)

根据数值型数组的第一维进行排序。ArraySort() 函数不能排序序列数组。

参数:

array[] - 需要排序的数值型数组。 count - 参加排序的元素个数。 start - 排序的起始下标。 sort_dir - 排序方式,可以选择下面的值            MODE_ASCEND  顺序排列,            MODE_DESCEND 逆序排列。

示例:

  double num_array[5]={4,1,6,3,9}; // 数组包含4,1,6,3,9   ArraySort(num_array); // 排序后新数组1,3,4,6,9   ArraySort(num_array,WHOLE_ARRAY
回复

使用道具 举报

2529

主题

4329

帖子

2万

积分

交易元老

Rank: 8Rank: 8

积分
22136
发表于 2023-9-20 11:01:01 | 显示全部楼层
回复

使用道具 举报

2290

主题

3822

帖子

2万

积分

交易元老

Rank: 8Rank: 8

积分
26746
发表于 2024-3-13 12:20:53 | 显示全部楼层
楼主88888
回复

使用道具 举报

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

本版积分规则

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

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