Merkmale der Sprache mql4, Feinheiten und Techniken - Seite 33

 
Nauris Zukas:
Guten Tag!
Ein Broker ist ständig (ein- oder zweimal am Tag) MarketInfo() fliegt ab, bekommt den Wert 0 ( speziell MODE_MARGINREQUIRED). Das ist ziemlich normal, aber gleichzeitig gibt es keinen Versuch, den iCustom()-Indikator zu erreichen (der über eine Ressource verbunden ist). Selbst nachdem MarketInfo() Daten erhalten hat, bleibt iCustom() stumm. Nur ein Neustart des Terminals hilft. Wie kann ich auf den Indikator zugreifen, ohne das Terminal neu zu starten? Haben Sie eine Idee? Kann der Indikator irgendwo aus einer Ressource verschwinden?

Nach einem Monat mit allen möglichen Tests kann ich schon ziemlich sicher sagen, dass es ein Problem gibt, nur kann ich nicht sagen, ob die Ressource fehlt oder ob iCustom() kaputt ist. Das Problem wird nur bei einem Broker festgestellt, was für den realen Handel sehr unangenehm ist. Bevor Sie mit Worten wie MT4 oder MQL um sich werfen, dass es ein Fehler ist, werde ich Ihnen den neuesten und einfachsten Code und die Testausführung geben. Ich werde auch die Ergebnisse veröffentlichen. Vielleicht gibt es einen Fehler in meinem Code, den ich nicht kenne. Ich erinnere Sie noch einmal daran, dass das Problem nur bei einem Makler auftritt (Sie werden es im Logbuch sehen).

Indikator:

//+------------------------------------------------------------------+
//|                                               Test_Lost_Indi.mq4 |
//|                                                     Nauris Zukas |
//|                             https://www.mql5.com/ru/users/abeiks |
//+------------------------------------------------------------------+
#property copyright "Nauris Zukas"
#property link      "https://www.mql5.com/ru/users/abeiks"
#property version   "1.00"
#property strict
#property indicator_chart_window

double OutputBuffer[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit()
  {
//--- indicator buffers mapping

   IndicatorBuffers(1);
   SetIndexBuffer(0,OutputBuffer,INDICATOR_CALCULATIONS);
   SetIndexEmptyValue(0,0.0);


//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total,
                const int prev_calculated,
                const datetime &time[],
                const double &open[],
                const double &high[],
                const double &low[],
                const double &close[],
                const long &tick_volume[],
                const long &volume[],
                const int &spread[])
  {
//---

   Print("-4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): ",TimeCurrent());
   OutputBuffer[0]=(double)TimeCurrent();
//--- return value of prev_calculated for next call
   return(rates_total);
  }
//+------------------------------------------------------------------+

Experte:

//+------------------------------------------------------------------+
//|                                           Test_Lost_Resource.mq4 |
//|                                                     Nauris Zukas |
//|                             https://www.mql5.com/ru/users/abeiks |
//+------------------------------------------------------------------+
#property copyright "Nauris Zukas"
#property link      "https://www.mql5.com/ru/users/abeiks"
#property version   "1.00"
#property strict

#resource "\\Indicators\\Test_Lost_Indi.ex4"
//+------------------------------------------------------------------+
//| Expert initialization function                                   |
//+------------------------------------------------------------------+
int OnInit()
  {
//---
   EventSetTimer(60);
//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Expert deinitialization function                                 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
  {
//---
   EventKillTimer();
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void OnTimer()
  {
   double Output1=iCustom(NULL,PERIOD_M1,"::Indicators\\Test_Lost_Indi.ex4",0,0);
   datetime ReceiveTime=(datetime)(int)Output1;
   if(TimeCurrent()>ReceiveTime+61)
      Print("-4002- INCORECT LAST INDICATOR TIME ReceiveTime: ",ReceiveTime, " TimeCurrent(): ",TimeCurrent());

   Print("-4003- OnTimer() ReceiveTime: ",ReceiveTime, " TimeCurrent(): ",TimeCurrent());
  }
//+------------------------------------------------------------------+

Empfängt die letzten Daten des Indikators.
Der Indikator reagiert nicht mehr.
Expertenprotokoll:

0       09:08:42.942    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:08:41
0       09:08:42.942    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:08:41 TimeCurrent(): 2020.10.27 09:08:41
0       09:09:42.955    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:09:42
0       09:09:42.955    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:09:42 TimeCurrent(): 2020.10.27 09:09:42
0       09:10:42.966    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:10:42
0       09:10:42.966    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:10:42 TimeCurrent(): 2020.10.27 09:10:42
0       09:11:42.979    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:11:42
0       09:11:42.979    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:11:42 TimeCurrent(): 2020.10.27 09:11:42
0       09:12:43.080    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:12:32
0       09:12:43.080    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:12:32 TimeCurrent(): 2020.10.27 09:12:32
0       09:13:43.010    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:12:48
0       09:13:43.010    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:12:48
0       09:14:43.012    Test_Lost_Resource GBPNZD,H1: -4002- INCORECT LAST INDICATOR TIME ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:14:42
0       09:14:43.012    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:14:42
0       09:15:43.025    Test_Lost_Resource GBPNZD,H1: -4002- INCORECT LAST INDICATOR TIME ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:15:42
0       09:15:43.025    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:15:42
0       09:16:43.039    Test_Lost_Resource GBPNZD,H1: -4002- INCORECT LAST INDICATOR TIME ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:16:42
0       09:16:43.039    Test_Lost_Resource GBPNZD,H1: -4003- OnTimer() Broker MarketInfo error ReceiveTime: 2020.10.27 09:12:48 TimeCurrent(): 2020.10.27 09:16:42
0

MT4-Protokoll zu diesem Zeitpunkt:

0       07:13:36.398    '21035322': login datacenter on RoboForex-Pro through DataCenter Europe #3 (ping: 53.56 ms)
0       07:13:36.802    '21035322': previous successful authorization performed from 87.110.24.238
1       09:12:42.982    '21035322': ping failed
0       09:12:43.690    '21035322': login on RoboForex-Pro through DataCenter Europe #3 (ping: 53.56 ms)
0       09:12:44.907    '21035322': login datacenter on RoboForex-Pro through DataCenter Europe #3 (ping: 53.56 ms)
0       09:12:45.317    '21035322': previous successful authorization performed from 87.110.24.238
1       09:12:58.925    '21035322': datacenter connecting failed [6]
0       09:12:59.475    '21035322': login on RoboForex-Pro through DataCenter Europe #3 (ping: 53.56 ms)
0       09:13:02.919    '21035322': ping to current access point DataCenter Europe #3 is 48.62 ms
0       09:13:59.826    '21035322': login datacenter on RoboForex-Pro
0       09:14:05.639    '21035322': login on RoboForex-Pro through DataCenter Europe #5 (ping: 68.86 ms)
0       09:14:06.482    '21035322': login datacenter on RoboForex-Pro through DataCenter Europe #5 (ping: 68.86 ms)
0       09:14:07.048    '21035322': previous successful authorization performed from 87.110.24.238
0       09:14:17.958    '21035322': ping to current access point DataCenter Europe #5 is 89.81 ms
1       11:12:31.864    '21035322': ping failed
1       11:12:31.864    '21035322': datacenter connecting failed [6]
 
Nauris Zukas:

Nach einem Monat mit allen möglichen Tests kann ich schon ziemlich sicher sagen, dass es ein Problem gibt, nur kann ich nicht sagen, ob die Ressource fehlt oder ob iCustom() kaputt ist. Das Problem wird nur bei einem Broker festgestellt, was für den realen Handel sehr unangenehm ist. Bevor Sie mit Worten wie MT4 oder MQL um sich werfen, dass es sich um einen Fehler handelt, werde ich Ihnen den neuesten und einfachsten Code und die Tests geben. Ich werde auch die Ergebnisse veröffentlichen. Vielleicht gibt es einen Fehler in meinem Code, den ich nicht kenne. Ich erinnere Sie noch einmal daran, dass das Problem nur bei einem Makler auftritt (Sie werden es im Logbuch sehen).

Indikator:

Experte:

Empfängt die letzten Daten des Indikators.
Der Indikator reagiert nicht mehr.
Expertenprotokoll:

MT4-Protokoll zu diesem Zeitpunkt:

TimeCurrent() im Indikator, der von iCustom aufgerufen wird, funktioniert nicht mehr, wenn ich mich neu einlogge?

Warum brauchen SieTimeCurrent() im Indikator?

Werden Zeitreihen (time[], open[], etc.) aktualisiert?

 
Andrey Khatimlianskii:

Funktioniert TimeCurrent() in einem Indikator, der von iCustom aufgerufen wird, nicht mehr, wenn er neu eingeloggt wird?

Wozu dient die FunktionTimeCurrent() im Indikator?

Werden die Zeitreihen (time[], open[], usw.) aktualisiert?

Alles funktioniert nicht mehr, als ob es keinen Indikator mehr gäbe. TimeCurrent() nur zur Kontrolle, das letzte Mal, um zu sehen. Nichts (nicht time[], open[], etc.) funktioniert, weil der Indikator einfach nicht mehr reagiert. Dies ist der letzte Druck von Indikator, es gibt keinen mehr:

0       09:13:43.010    Test_Lost_Indi.ex4 GBPNZD,M1: -4005- - - - OnCalculate() Broker MarketInfo error  Broke indicator next TimeCurrent(): 2020.10.27 09:12:48
 
Um die MQL4-Beschränkung zu umgehen, müssen Sie wie folgt schreiben.
#property strict

class A
{
protected:
  template <typename T>
  void f( const T* ) {}
};

class B : public A
{
public:
  void f( const B* b )
  {
  #ifdef __MQL5__
    this.A::f(b);
  #else
    this.f((const A*) b); // Обходим Stack overflow.
  #endif
  }  
};

void OnStart()
{  
  B b;
  
  b.f(&b);
}
 
fxsaber:
Um die MQL4-Beschränkung zu umgehen, muss ich es auf diese Weise schreiben.

Religion ist sicherlich eine gute Sache (das meine ich ausdrücklich.*), aber es ist besser, sie der Kirche zu überlassen.

class A
{
protected:
  template <typename T>
  void f( const T* ) {Print(typename(T));}
};

class B : public A
{
public:
  void f( const B* b )
  {
    A::f(b);
  }  
};

void OnStart()
{  
  B b;
  
  b.f(&b);
}

Ich denke, das wäre prägnanter.

 
Vladimir Simakov:

Religion ist sicherlich eine gute Sache (das meine ich ausdrücklich.*), aber es ist besser, sie der Kirche zu überlassen.

Ich denke, das wäre prägnanter.

class A
{
protected:
  static void f( const A* ) { Print(__FUNCSIG__); }
  
  template <typename T>
  void f( const T* ) {Print(typename(T));} // Почему B?
};

class B : public A
{
public:
  void f( const A* a )
  {
    A::f(a); // как вызвать static-метод?
  }  
};

void OnStart()
{  
  B b;
  
  b.f(&b); // deprecated behavior, hidden method calling will be disabled in a future MQL compiler version
}
Es steht unter einem A.
 
fxsaber:
Dies ist unter 5.

Fragen Sie die Entwickler: Warum wird die Vorlagenmethode aus der geschützten Zone aufgerufen?

UPD: es ist diejenige, die der Compiler im Aufruf ersetzt, nicht B::f(const A*)

 

Hilfe bei der Umgehung eines MQL4-Compiler-Fehlers, der nicht mehr entwickelt wird.

class A
{
public:
  static bool f() { return(true); }
};

template <typename T>
void g( )
{
  bool Res = T::f(); // '::' - unexpected token, 'f' - function not defined.
  
  T::f(); // OK
}

void OnStart()
{
  g<A>();
}

Suchbegriff: Oshibka 021.

 
fxsaber:

Hilfe bei der Umgehung eines MQL4-Compiler-Fehlers, der nicht mehr entwickelt wird.

So kompiliert MQL4:

class A
{
public:
  static bool f() { return(true); }
};

template <typename T1, typename T2>
void g( )
{
  
  T1 tmp;
  T2 res = tmp.f(); // OK
}

void OnStart()
{
  g<A,bool>();
}
//+------------------------------------------------------------------+

UPD:

Grundsätzlich kompiliert auch ohne typename T2

 
Igor Makanu:

So wird es in MQL4 kompiliert:

UPD:

Grundsätzlich kompiliert auch ohne typename T2

Ich danke Ihnen!