首页学院交易策略EA智能交易文章详细

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

外汇网2021-06-17 09:40:39 143
汇外网 - 全球专业的黄金外汇门户导航行情资讯网站

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

数组的最大维数为四维。每一维索引编号为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

for(i=0; i

ArraySize() – 获取数组大小
int ArraySize(object array[])

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

参数:

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

示例:

int count=ArraySize(array1);

for(int i=0; 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,0,MODE_DESCEND);

// 排序后新数组 9,6,4,3,1

标签:

随机快审展示
加入快审,优先展示

加入VIP