Вы упускаете торговые возможности:
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Регистрация
Вход
Вы принимаете политику сайта и условия использования
Если у вас нет учетной записи, зарегистрируйтесь
4 цикла не круто ли ? при 600 символах в обзоре рынка каждую минуту терминал будет умирать ....
Вы о чем? В таймере цикл осуществляется 1 раз за минуту. Это вообще ничто.
А к функции Новый_бар() пользователь обращается когда ему угодно.
Что касается комментария кода: А если надо в программе определить открытие только текущего периода и только по одному символу? Вся эта конструкция будет крутить все циклы? Нерационально.
Совершенно не поняли код.
События нового бара по символам фиксируются в цикле раз в минуту. Автоматически. Если текущее количество баров не равно записанному в массиве, то ставим флаг события нового бара в массиве События_нового_бара[][].
Alexey Viktorov:
ps; Да и зачем запускать миллисекундный таймер? Разве не хватит секундного???
Можно поставить и секундный. Тогда нужно записать "Частота_таймера = 1000".
Поставил, проверил, не работает
Выдаёт постоянно false4 цикла не круто ли ? при 600 символах в обзоре рынка каждую минуту терминал будет умирать ....
Интересно, у кого-то реально столько стоит ?
У меня вот 16 - и я уже подумываю, не слишком ли большая нагрузка ?
Правда, у меня минимальный таймфрейм М15... Но все же, интересно, когда нагрузка на терминал начинает быть критичной ?
Вы о чем? В таймере цикл осуществляется 1 раз за минуту. Это вообще ничто.
А к функции Новый_бар() пользователь обращается когда ему угодно.
Функция "новый бар" обычно выполняется на каждом тике... Этоn вызов на каждом тике делается для экономии ресурсов. Осознайте, как ваша функции "экономит" ресурсы, она их пожирает.
... Но все же, интересно, когда нагрузка на терминал начинает быть критичной ?
когда процессор встает на коленки и не может подняться.
с уважением.
Совершенно не поняли код.
События нового бара по символам фиксируются в цикле раз в минуту. Автоматически. Если текущее количество баров не равно записанному в массиве, то ставим флаг события нового бара в массиве События_нового_бара[][].
Давайте лучше подискутируем другой пример использования ООП.
Форум по трейдингу, автоматическим торговым системам и тестированию торговых стратегий
Мт4 Конец поддержке.
Alexey Viktorov, 2017.09.11 13:08
Мне кажется я нашёл примитивный пример удобства использования ООП. Вот функция заполнения массива указанным значением. Там их восемь разновидностей в зависимости от типа массива.
Вот представьте что вам надо написать функцию в которую надо передавать то один набор параметров, то другой, то третий... При алгоритмическом подходе получится N разных имён функций. Казалось-бы ничего страшного, можно ведь написать и 8 таких как ArrayInitializeInt() ArrayInitializeDouble() и так далее. Но ведь как приятно не задумываясь о типе массива просто применять одну функцию в любом случае и на сколько безопасно перепутать какой массив туда суёшь...
Поставил, проверил, не работает
Выдаёт постоянно false1. Запустите советник на M1.
2. Нужно подождать пока полностью закончится текущий бар. На первом баре не фиксируется событие. Сделал так специально. Дальше Вам нужно ждать столько времени, сколько предпологает тот таймфрейм, который вы посылаете в функцию.
Я сейчас попробывал на минутке и получилось.
Функция "новый бар" обычно выполняется на каждом тике... Этоn вызов на каждом тике делается для экономии ресурсов. Осознайте, как ваша функции "экономит" ресурсы, она их пожирает.