int GetRecalcIndex(int& total, constint ratesTotal, constint prevCalculated)
{
total = ratesTotal - 2 - barsig;
if (cb > 0 && cb < total)
total = MathMin(cb, total);
if (prevCalculated < ratesTotal - 1)
{
InitializeBuffers(); // Это функция, которая должна заново инициализировать все индикаторные буфера, т. к. имеем дело с первой загрузкой индикатора или подкачкой историиreturn (total);
}
return (MathMin(ratesTotal - prevCalculated, total));
}
使用方法如下。
int total;
int limit = GetRecalcIndex(total, rates_total, prev_calculated);
for (int i = limit; i >= 0; --i)
{
...
}
它仍然在踢出。
你有[i+1],你需要检查+2更多。
一般来说,你应该做这样的事情
因为这张支票从根本上是错误的。比方说,Bars返回1000,cb也返回1000。然后在第一次迭代的循环中,我得到的数值是1000。在循环体的第一个条件中。
在数组外 同时有两个出口: 访问一个索引为1000的柱子和一个索引为1001的柱子。如果图表有1000个柱子,第一个柱子的索引是0,最后一个柱子的索引是999。
再往前走,通过环形体,在历史中提到了更遥远的酒吧。
所有这些都需要在初步检查中加以考虑。
要进行适当的检查,请参阅MQL4参考中的IndicatorCounted()函数的例子。只是现在,IndicatorCounted()应该被分享rate_total(这是Bars)和prev_calculated(这是IndicatorCounted())取代。
谢谢,找到了。
我应该把它与什么相比较? 在例子中,它以极限 开始
limit=Bars-counted_bars;
我应该把这个 "Cb "与什么相比较?
谢谢你,找到了。
在这个例子中,它以极限 开始。
我应该把这个 "Cb "与什么相比?
如果你想限制显示指标数据的条数,你最好这样做。
使用方法如下。
总值是历史上最深的柱子的指数,可以根据指标的设置值来访问。你有[i+1],你需要检查+2更多。
一般来说,你应该做这样的事情
我这样做了,但它说......阵列超出了'HiLo.mq4'的范围(122,15)。
我应该通过+2来检查什么?
如果你想限制显示指标数据的条数,最好是这样做。
使用方法如下。
总数的值是历史上最深的柱子的指数,可以根据指标设置的值来调用。编译者发誓。
'InitializeBuffers' - 函数未定义 HiLo.mq4 161 7
编译器抱怨说
'InitializeBuffers' - 函数未定义 HiLo.mq4 161 7
我在评论中写道,这是一个应该初始化所有指标缓冲区的函数。这是一个自定义函数。我是这样想的。
你会有一个不同的,因为缓冲区是不同的。如果指标与图形对象一起工作,你需要在这里删除所有的图形对象,因为要进行读数的初始绘制。
我在评论中写道,这是一个应该初始化所有指标缓冲区的函数。这是一个自定义函数。我是这样想的。
你会有一个不同的,因为缓冲器是不同的。如果指标与图形对象一起工作,你必须在这里删除所有对象,因为要进行读数的初始绘制。
谢谢,但没有任何变化......'HiLo.mq4'中的数组超出了范围(130,15)。
.有什么问题吗?
谢谢你,但一切都没有改变。怎么了?
当然,结果不会改变。毕竟,你还没有删除主要原因(cb循环)。这个循环的组织方式是不正确的。
它应该被移除,并被替换成限位环。 在这两个地方。
当然,结果不会改变。毕竟,你还没有删除主要原因(cb循环)。这个循环的组织方式是不正确的。
它应该被移除,并在其位置上放置限位环。 在这两个地方。
有3个这样的循环。我更换了它们,端子挂了起来。
我做了,它没有冻结或崩溃,但在第一个缓冲区(fx2)有3个值:价格、0.0和164874239.218492。
如果值sell_1_B!=EMPTY_VALUE和sell_1_B!=0,这并不意味着有价格。
我怎样才能获得信号?