inputstring Symb0 = "EURUSD";
inputbool Trade0 = true;
int MA_Shift0=1;
inputint MA_Per0 = 100;
//+-----------------------------------+inputstring Symb1 = "USDCHF";
inputbool Trade1 = true;
int MA_Shift1=1;
inputint MA_Per1 = 100;
bool MA (int Number,
string Symbol_, // имя символаbool Trade,
int MA_Per, // период для расчета средней линииint MA_Shift // смещение индикатора по горизонтали
)
{
//---- проверка запрета на торговлюif(!Trade)return(true);
//---- объявление переменной для хранения итогового размера массивов переменныхstaticint Size_=0;
//---- объявление массива для хранения хэндлов индикаторов как статической переменнойstaticint Handle[];
staticint Recount[],MinBars[];
double ma[20];
if(Number+1>Size_) // вход в блок инициализации только на первом старте
{
Size_=Number+1; // для этого номера вход в блок закрыт//---- изменение размеров массивов переменныхArrayResize(Handle,Size_);
ArrayResize(Recount,Size_);
ArrayResize(MinBars,Size_);
//---- определение минимально количества баров, достаточного для расчета
MinBars[Number]=3*MA_Per;
//---- предварительное обнуление ячеек массивов//---- используем массив как таймсериюArraySetAsSeries(ma,true);
//---- получение хендла индикатора
Handle[Number]=iMA(Symbol_,0,MA_Per,MA_Shift,MODE_SMA,PRICE_CLOSE);
Print("+++++++++Handle[Number]= ",Handle[Number]);
}
//---- проверка количества баров на достаточность для расчета if(Bars(Symbol_,0)<MinBars[Number])return(true);
//---- Получение торговых сигналов if(IsNewBar(Number,Symbol_,0) || Recount[Number]) // вход в блок на смене бара или при неудачном копировании данных
{
//---- используя хэндлы индикатора, копируем значения индикаторного буфера//---- в специально подготовленный для этого статический массивif(CopyBuffer(Handle[Number],0,0,20,ma)<0)
{
Recount[Number]=true; // так как данные не получены, то следует вернуться // в этот блок получения торговых сигналов на следующем тике!return(false); // выходим из функции TradeSignalCounter() без получения торговых сигналов
}
//---- все операции копирования из индикаторного буфера завершены успешно
Recount[Number]=false; // можно не возвращаться в этот блок до очередной смены бараPrint("+++++++++ma[0]= ",ma[0]);
Print("+++++++++ma[1]= ",ma[1]);
Print("+++++++++ma[2]= ",ma[2]);
Print("+++++++++ma[3]= ",ma[3]);
Print("+++++++++ma[4]= ",ma[4]);
Print("+++++++++ma[5]= ",ma[5]);
Print("+++++++++ma[6]= ",ma[6]);
Print("+++++++++ma[7]= ",ma[7]);
Print("+++++++++ma[8]= ",ma[8]);
Print("+++++++++ma[9]= ",ma[9]);
Print("+++++++++ma[10]= ",ma[10]);
Print("+++++++++ma[11]= ",ma[11]);
Print("+++++++++ma[12]= ",ma[12]);
Print("+++++++++ma[13]= ",ma[13]);
Print("+++++++++ma[14]= ",ma[14]);
Print("+++++++++ma[15]= ",ma[15]);
Print("+++++++++ma[16]= ",ma[16]);
Print("+++++++++ma[17]= ",ma[17]);
Print("+++++++++ma[18]= ",ma[18]);
Print("+++++++++ma[19]= ",ma[19]);
}
return(true);
}
//+------------------------------------------------------------------+//| Expert initialization function |//+------------------------------------------------------------------+intOnInit()
{
//---//---return(0);
}
//+------------------------------------------------------------------+//| Expert deinitialization function |//+------------------------------------------------------------------+voidOnDeinit(constint reason)
{
//---
}
//+------------------------------------------------------------------+//| Expert tick function |//+------------------------------------------------------------------+voidOnTick()
{
//---
MA(0,Symb0,Trade0,MA_Per0,MA_Shift0);
MA(1,Symb1,Trade1,MA_Per1,MA_Shift1);
}
//+------------------------------------------------------------------+//+------------------------------------------------------------------+//| IsNewBar() function |//+------------------------------------------------------------------+bool IsNewBar(int Number,string symbol,ENUM_TIMEFRAMES timeframe)
{
//----staticdatetime Told[];
datetime Tnew[1];
//---- объвление переменной для хранения размеров массивов переменныхstaticint Size_=0;
//---- изменение размеров массивов переменныхif(Number+1>Size_)
{
uint size=Number+1;
//----if(ArrayResize(Told,size)==-1)
{
string word="";
StringConcatenate(word,"IsNewBar( ",Number,
" ): Ошибка!!! Не удалось изменить размеры массивов переменных!!!");
Print(word);
//---- int error=GetLastError();
ResetLastError();
if(error>4000)
{
StringConcatenate(word,"IsNewBar( ",Number," ): Код ошибки ",error);
Print(word);
}
//----
Size_=-2;
return(false);
}
}
CopyTime(symbol,timeframe,0,1,Tnew);
if(Tnew[0]!=Told[Number])
{
Told[Number]=Tnew[0];
return(true);
}
//----return(false);
}
我对开发者有一个建议--为所有内置类型制定默认值。在这个意义上,C++不是一个模型。
你将真正为你自己和那些如上回答问题的人节省大量的时间和神经。
while((a/b)<1 && !IsStopped())//---------
什么等于A?
默认情况下(在上面的例子中)a=2.652664430987377e-314 ,但在这种情况下,while循环的方式是a+b=30。
当然,你可以立即赋值双a=1。
但情况并没有改变。
输出总是a+b=30
而返回值为0,调试器显示了这一切。
这些故障是什么,还是我错过了什么?
变量的初始化:
任何变量在定义时都可以被初始化。如果变量没有被明确初始化,存储在变量中的值可以是你想要的任何东西。 不进行隐式初始化。
Fia:
输出总是a+b=30
而返回值为0,调试器显示了这一切。
我几乎无法相信这一点。
是什么阻止了你去检查它呢?
特别是为了这个目的,我给出了一个简单的代码。
我有两个687的版本(在不同的经纪商上),试着编译这两个版本,结果都一样(但有时我得到30个正确的结果),我不明白是我笨还是滑雪板没动静!我不知道。
检查 我不知道该怎么想。
到目前为止,它还不可能重现。因此,让我们从头开始。
什么比特率,操作系统?
还没有找到繁殖的方法。
什么比特率,操作系统?
Win7 64位
甚至不知道,刚刚卸下刚刚加载的MT5 编译,同样的事情。
我可以脱下视频(会认为我在取笑它)。
P.S.现在我刚点了一下,又一次工作了30分钟,我把它编译了一下,现在又工作了几次,都是空的(神奇)。
下午好。
我正在尝试使用MQL5。我拆解了exp_tema.mq5 并修改了代码。现在我应该打印每根蜡烛的MA日志(最后20根)。但我不明白为什么日志中缺少一些条目。我注意到, 如果日志中缺少ma[3],那么就没有ma[13]。为什么会发生这种情况?那里的错误在哪里呢?
Win7 64位
我不知道,现在刚卸下MT5,运行了一个副本,同样的事情。
我可以摘下一个视频或其他东西(我想我只是在跟你开玩笑)。
你不需要屏幕截图。
在代码中做一个详细的Print,这样我们就可以在日志中看到中间的变量等于什么了。