错误、漏洞、问题 - 页 1857

 

以及如何重载[]和=运算符,以便你可以这样写。

class A
{
private:
   int arr[5];
};

A *obj = new A();

for(int i = 0; i < 5; ++i)    obj[i] = i;

 
Konstantin:

以及如何重载[]和=运算符,以便你可以这样写。

class A
{
   int arr[5];
   
   int CurrentPos;
   
public:
  A* operator []( const int Pos )
  {
    this.CurrentPos = Pos;
    
    return(&this);
  }

  void operator =( const int Value )  
  {
    this.arr[this.CurrentPos] = Value;
  }
};
 
fxsaber:


谢谢你,但我如何再次重载[]运算符,以便我可以在上面写的内容之外再写。

class A
{
   int arr[5];
   
   int CurrentPos;
   
public:
  A* operator []( const int Pos )
  {
    this.CurrentPos = Pos;
    
    return(&this);
  }

  void operator =( const int Value )  
  {
    this.arr[this.CurrentPos] = Value;
  }
};

for(int i = 0; i < 5; ++i)

   int _value = obj[i];

 
Konstantin:

谢谢你,但我如何再次重载[]运算符,以便我可以在上面写的基础上再写?

class A
{
   int arr[5];
   
   int CurrentPos;
   
public:
  A* operator []( const int Pos )
  {
    this.CurrentPos = Pos;
    
    return(&this);
  }

  void operator =( const int Value )  
  {
    this.arr[this.CurrentPos] = Value;
  }

  int operator []( const uint Pos ) const
  {
    return(this.arr[Pos]);
  }
};

void OnStart()
{
  A obj;

  for (int i = 0; i < 5; ++i)  
    obj[i] = i;
    
  for (uint i = 0; i < 5; ++i)  
    int _value = obj[i];
}
 
fxsaber:

再次感谢,我不知道该如何处理这些过载,分别做可以,但不能一起做 ))
 

文件中的错别字?

https://www.mql5.com/ru/docs/series/copyticksrange

int  CopyTicks(
   const string     symbol_name,           // имя символа
   MqlTick&         ticks_array[],         // массив для приёма тиков
   uint             flags=COPY_TICKS_ALL,  // флаг, определяющий тип получаемых тиков
   ulong            from_msc=0,            // дата, начиная с которой запрашиваются тики
   ulong            to_msc=0               // дата, по которую запрашиваются тики
   );
Документация по MQL5: Доступ к таймсериям и индикаторам / CopyTicksRange
Документация по MQL5: Доступ к таймсериям и индикаторам / CopyTicksRange
  • www.mql5.com
Доступ к таймсериям и индикаторам / CopyTicksRange - справочник по языку алгоритмического/автоматического трейдинга для MetaTrader 5
 

测试仪在25K交易后进入可怕的制动模式。

运行1585,在ticks上,RTS-6.17,Metaquotes-Demo

#include <MT4Orders.mqh>

void OnTick()
{  
  static bool Error = false;  
  static int Type = OP_BUY;
  
  if (Error)
    return;
  
  MqlTick Tick;    

  if (OrderSelect(0, SELECT_BY_POS) && (OrderType() <= OP_SELL))
    OrderClose(OrderTicket(), OrderLots(), OrderClosePrice(), 0);    
  else if ((OrdersTotal() == 0) && SymbolInfoTick(_Symbol, Tick) && (Tick.bid != 0) && (Tick.ask != 0))
  {
    Error = (OrderSend(_Symbol, Type + OP_BUYLIMIT, 1, (Type == OP_BUY) ? Tick.ask : Tick.bid, 0, 0, 0, "", 0, 0, INT_MAX) == -1);        
    
    if (!Error)
    {
      OrderSend(_Symbol, Type + OP_BUYLIMIT, 1, (Type == OP_BUY) ? Tick.ask : Tick.bid, 0, 0, 0);
      
      Type = OP_SELL - Type;
    }    
  }
}

我没有看到任何滞后的原因。感觉像是写了ArrayResize(Orders, ArraySize(Orders) + 1)。也就是说,Reserve_Size没有被使用。

 
当过期记录正在进行时,测试员日志中没有时间。
2017.04.19 10:46:15.165 2017.04.06 23:09:37   sell limit 1.00 RTS-6.17 at 114300 (114290 / 114300 / 114300)
2017.04.19 10:46:15.168 order expired [#284  sell limit 1.00 RTS-6.17 at 114300]
2017.04.19 10:46:15.168 2017.04.07 09:45:04   buy limit 1.00 RTS-6.17 at 114170 (114140 / 114180)
 
除了历史时间外,请在测试员日志中添加毫秒。
 

关于交易、自动交易系统和交易策略测试的论坛

虫子、虫子、问题

fxsaber, 2017.04.19 08:58

测试仪在25K交易后进入令人毛骨悚然的制动模式。

运行1585,在ticks上,RTS-6.17,Metaquotes-Demo

#include <MT4Orders.mqh>

void OnTick()
{  
  static bool Error = false;  
  static int Type = OP_BUY;
  
  if (Error)
    return;
  
  MqlTick Tick;    

  if (OrderSelect(0, SELECT_BY_POS) && (OrderType() <= OP_SELL))
    OrderClose(OrderTicket(), OrderLots(), OrderClosePrice(), 0);    
  else if ((OrdersTotal() == 0) && SymbolInfoTick(_Symbol, Tick) && (Tick.bid != 0) && (Tick.ask != 0))
  {
    Error = (OrderSend(_Symbol, Type + OP_BUYLIMIT, 1, (Type == OP_BUY) ? Tick.ask : Tick.bid, 0, 0, 0, "", 0, 0, INT_MAX) == -1);        
    
    if (!Error)
    {
      OrderSend(_Symbol, Type + OP_BUYLIMIT, 1, (Type == OP_BUY) ? Tick.ask : Tick.bid, 0, 0, 0);
      
      Type = OP_SELL - Type;
    }    
  }
}

它是否有效?测试仪设置如下

结果

Tester  RTS-6.17,M1: 254907 ticks, 785 bars generated. Test passed in 0:15:54.180 (including ticks preprocessing 0:00:00.047).

即在16分钟内跑完250K次。


如何在测试器中测量性能下降?我试过GetTickCount和全局变量,都失败了。