Nikolai Semko: 尝试用#define做一些事情。我只是现在不在我的电脑前。也许你可以在调试器中以某种方式处理俄文变量名,如果你不能没有它们的话。
为了方便公众,我把我的解决方案代码翻译成了英文。
//+------------------------------------------------------------------+//| Новый бар 2.mq4 |//| Peter Konow |//| https://www.mql5.com |//+------------------------------------------------------------------+#property copyright"Peter Konow"#property link"https://www.mql5.com"#property version"1.00"#property strict//+------------------------------------------------------------------+datetime Last_Bar_Time;
int Periodicity = 25;
int All_symbols;
string Symbols[];
int Timeframes[7] = {PERIOD_M1,PERIOD_M5,PERIOD_M15,PERIOD_M30,PERIOD_H1,PERIOD_H4,PERIOD_D1};
int All_Timeframes = 7;
int All_bars_table[][7];
bool New_Bar_Events[][7];
//+------------------------------------------------------------------+//+------------------------------------------------------------------+//| Expert initialization function |//+------------------------------------------------------------------+intOnInit()
{
//--- create timerEventSetMillisecondTimer(25);
//-------------------------------------------------------------//Записываем время последнего бара на момент загрузки эксперта. //Для корректного начала работы, робота нужно запустить на М1. //-------------------------------------------------------------
Last_Bar_Time = Time[0];
//------------------------------------------------------------- //Узнаем сколько символов есть в обзоре рынка.//---------------------------------------------------------
All_symbols = SymbolsTotal(true);
//--------------------------------------------------------- //Устанавливаем размер массива Symbols. Внутри него будут записаны//имена всех символов, которые есть в окне обзоре рынка.//---------------------------------------------------------ArrayResize(Symbols,All_symbols);
//---------------------------------------------------------//Устанавливаем размеры массивов "All_bars_table[]" и "New_Bar_Events[]".//В массиве "All_bars_table[]" будет записыватся текущее количество баров каждого символа//и каждого таймфрейма. А в массиве "New_Bar_Events[]" устанавливаться флаги//события нового бара для каждого символа и каждого таймфрейма. //---------------------------------------------------------ArrayResize(All_bars_table,All_symbols);
ArrayResize(New_Bar_Events,All_symbols);
//---------------------------------------------------------//Записываем наименования символов обзора рынка в массив "Symbols[]".//---------------------------------------------------------for(int a1 = 0; a1 < All_symbols; a1++)
{
Symbols[a1] = SymbolName(a1 + 1,true);
//Возможно, нумерация символов в обзора рынка идет с нуля.//Тогда: Symbols[a1] = SymbolName(a1,true);
}
//---------------------------------------------------------return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+//| Expert deinitialization function |//+------------------------------------------------------------------+voidOnDeinit(constint reason)
{
//--- destroy timerEventKillTimer();
}
//+------------------------------------------------------------------+//| Expert tick function |//+------------------------------------------------------------------+voidOnTick()
{
}
//+------------------------------------------------------------------+//| Timer function |//+------------------------------------------------------------------+voidOnTimer()
{
staticbool Start_count;
staticint Current_period;
//---------------------------//Нам нужен корректный старт отсчета. Это должно быть время начала бара.//---------------------------if(!Start_count && Last_Bar_Time != Time[0])Start_count = true;
//--------------------------- if(Start_count)Current_period++;
//--------------------------- //В следующем цикле, мы будем обращатся к функции iBars для получения количества баров на //каждом из символов и таймфреймов, которые будем проходить в цикле.//Далее, будем сравнивать записанное количество баров с текущим и при //наличии разницы установим флаг события нового бара в массив "New_Bar_Events[]".//---------------------------if(Current_period*Periodicity >= 1000)
{
for(int a1 = 0; a1 < All_symbols; a1++)
{
string This_symbol = Symbols[a1];
//---------------------------------for(int a2 = 0; a2 < All_Timeframes; a2++)
{
int This_timeframe = Timeframes[a2];
//------------------------------------------int All_current_bars = iBars(This_symbol,This_timeframe);
//------------------------------------------if(All_current_bars > All_bars_table[a1][a2])
{
//------------------------------------------------------------//Если это не самая первая запись в массив All_bars_table,//то фиксируем событие нового бара.//------------------------------------------------------------if(All_bars_table[a1][a2])
{
New_Bar_Events[a1][a2] = true;
}
//------------------------------------------------------------//Устанавливаем новое значение текущего количества баров.//------------------------------------------------------------
All_bars_table [a1][a2] = All_current_bars;
}
//------------------------------------------
}
}
//---------
Current_period = 0;
}
//-----------------------------------------------//Здесь наш код...//Здесь наш код...//Здесь наш код...//-----------------------------------------------//После завершения всех вызовов на этом событии таймера//снимаем флаги событий нового бара.if(!Current_period)Refresh_new_bar_events_table();
//-----------------------------------------------
}
//+------------------------------------------------------------------+//+------------------------------------------------------------------+//Функция снимает флаги событий нового бара.//Эта процедура осуществляется после выполнения всего пользовательского//кода один раз в минуту. Вплоть до момента очищения массива флагов //новых баров, все функции могут их видеть обращаясь к массиву напрямую.//+------------------------------------------------------------------+void Refresh_new_bar_events_table()
{
for(int a1 = 0; a1 < All_symbols; a1++)
{
for(int a2 = 0; a2 < All_Timeframes; a2++)
{
New_Bar_Events[a1][a2] = false;
}
}
}
//+------------------------------------------------------------------+//+------------------------------------------------------------------+//Пример использования событий нового бара в пользовательском функционал.//Просто обращаемся к глобальному массиву "New_Bar_Events[a1][a2]" напрямую//и используем событие в наших торговых алгоритмах.//+------------------------------------------------------------------+void Trading_on_new_bars_strategy()
{
for(int a1 = 0; a1 < All_symbols; a1++)
{
string This_symbol = Symbols[a1];
//----------------------------------for(int a2 = 0; a2 < All_Timeframes; a2++)
{
bool New_bar = New_Bar_Events[a1][a2];
int This_timeframe = Timeframes[a2];
//----------------------------------if(New_bar && This_symbol == "EURUSD" && This_timeframe == PERIOD_M15)
{
//Buy();
}
//---------------------------------- if(New_bar && This_symbol == "AUDUSD" && This_timeframe == PERIOD_M30)
{
//Sell();
}
//----------------------------------
}
}
}
//+------------------------------------------------------------------+
没有。
不幸的是,在14.09日下午2点之前,我只剩下半个G的流量,所以我不会去看。我会照顾好这段时间的。那是什么...
谢谢你,尼古拉--多亏了你,我才知道我在对调试器一无所知的情况下收获了多少。
如果我依靠它,我现在将一无所有。也许我也会这样做,但只有一半的量。
只是因为我不会利用巨大的优势在编程中使用自己的语言。
这很奇怪,因为你比我更了解英语,尽管我住在加拿大。为什么不把长名字写成英文?除了它们不会被突出显示为红色。
在你心中的每一个字(尽管是无意识的)翻译?
母语在生物学上是根植于大脑的。理解是最快的可能。外来语言在被理解之前总是要经过处理。
纯粹的生物学。
我使用俄语理解自己的代码比使用英语要快得多。我的记忆力要好得多。
在你心中的每一个字(尽管是无意识的)翻译?
母语在生物学上是根植于大脑的。理解是最快的可能。外来语言在被理解之前总是要经过处理。
纯粹的生物学。
我使用俄语理解自己的代码比使用英语要快得多。我的记忆力要好得多。
在你心中的每一个字(尽管是无意识的)翻译?
母语在生物学上是根植于大脑的。理解是最快的可能。外来语言在被理解之前总是要经过处理。
纯粹的生物学。
我使用俄语理解自己的代码比使用英语要快得多。我记得它要好得多。
碰巧的是,我从来没有学过英语--在学校没有,在一个学院没有,在第二个学院也没有。我还是完全不懂用耳朵听。我自己也在学习,但我的第一次尝试是在我开始编程之前很久。Annygdot " - 你怎么学英语这么快?- 有什么好学的呢--他们从C++中得到了所有的词"--这就是我。
而你知道吗?由于某些原因,我的生活中从未出现过英语系的人。所以要为自己说话--不要对所有人一概而论。
尝试用#define做一些事情。我只是现在不在我的电脑前。也许你可以在调试器中以某种方式处理俄文变量名,如果你不能没有它们的话。
为了方便公众,我把我的解决方案代码翻译成了英文。
我希望我没有弄错什么。
谢谢你,尼古拉--多亏了你,我才知道自己对调试器毫无头绪的情况下获得了多少好处。
如果我依靠它,我现在将一无所有。也许我也会这样做,但只有一半的量。
只是因为我不会利用巨大的优势在编程中使用自己的语言。
为了方便公众,我把我的解决方案代码翻译成了英文。
我希望我没有犯错。
试试吧,看看结果。
我敢肯定,如果我在工作中使用像OOP和调试器这样的工具,我做任何事情都会更快更好!"。
我不会争论。时间和实践会证明我是否选择了正确的方式、方法和工具。
试着打印一下,看看结果
你的结果是什么?
你从哪里调用这个函数?