работа с событиями
Atom
09.11.2013


Здравствуйте.

В уроке про MarketRules было сказано, что они в основном были созданы, чтобы упростить работу с событиями, в частности, чтобы не подписываться и не отписываться на события. Если я например, вместо использования MarketRule у стратегии WhenNewMyTrades, подпишусь на событие NewMyTrades, нужно ли мне где-то потом от него отписываться, например при остановке стратегии?

Теги:


Спасибо:


IvanB

Фотография
Дата: 10.11.2013
Ответить


pft_man Перейти
Здравствуйте.
Если я например, вместо использования MarketRule у стратегии WhenNewMyTrades, подпишусь на событие NewMyTrades, нужно ли мне где-то потом от него отписываться, например при остановке стратегии?

Все зависит от Вашей задачи. Если от старта к старту стратегии надо обрабатывать новые сделки разными способами, например, каждый раз Вы используете разные типы инструментов и для каждого типа своя логика обработки сделок, в таком случае надо отписываться от события и задавать новый обработчик.
Спасибо:

pft_man

Фотография
Дата: 10.11.2013
Ответить


А метод - обработчик события запускается в новом потоке, правильно? И если мы, например, хотим что-то вывести на нашу форму, то для того чтобы синхронизировать этот новый поток с GUI потоком, мы используем метод GuiAsync? Простые вещи, но начинают доходить только после 2-3го просмотра видео ;)
Спасибо:

IvanB

Фотография
Дата: 11.11.2013
Ответить


pft_man Перейти
А метод - обработчик события запускается в новом потоке, правильно?

В общем случае не обязательно, смотря как реализовано, если относительно S#.API, то там, фактически все вызываются вне потока GUI.

pft_man Перейти
И если мы, например, хотим что-то вывести на нашу форму, то для того чтобы синхронизировать этот новый поток с GUI потоком, мы используем метод GuiAsync? Простые вещи, но начинают доходить только после 2-3го просмотра видео ;)

Да, верно )
Спасибо:

pft_man

Фотография
Дата: 15.11.2013
Ответить


Подскажите. Есть два стандартных события: NewSecurities и NewPortfolios. Соответственно, в методе каждого события проверяем, пришёл ли нужный инструмент и портфель. Как сделать так, чтобы дальнейший метод CreateStrategy - создание и запуск стратегии - запускался только когда пришёл И нужный инструмент И нужный портфель?

Спасибо:

IvanB

Фотография
Дата: 15.11.2013
Ответить


pft_man Перейти
Подскажите. Есть два стандартных события: NewSecurities и NewPortfolios. Соответственно, в методе каждого события проверяем, пришёл ли нужный инструмент и портфель. Как сделать так, чтобы дальнейший метод CreateStrategy - создание и запуск стратегии - запускался только когда пришёл И нужный инструмент И нужный портфель?


Если изначально поля portfolio и security имедют значение null, то можно сделать так:



И, думаю, надо предостеречься, чтобы стратегия не создавалась повторно, используя либо проверку переменной стратегии на нуль или через флаг.

PS. Пожалуйста используйте СПОЙЛЕР для скрытия большого кода, чтоб он не был всегда виден, теги спойлера доступны в панели инструментов редактора поста.
Спасибо:

Axell

Фотография
Дата: 15.11.2013
Ответить


Может кто уже сталкивался? Квик, на счёте позиции по нескольким бумагам, все нужны для стратегии. Часто при первом срабатывании события NewPositions приходят не все бумаги по которым есть позиции, через некоторое время опять срабатывает NewPositions и приходит уже все бумаги. Иногда все позиции по бумагам приходят толко после нескольких срабатываний NewPositions. Почему сразу не приходит вся коллекция Position и как с этим бороться?
Спасибо:

Mikhail Sukhov

Фотография
Дата: 15.11.2013
Ответить


А пример Sample так же работает? Попробуйте, кстати, еще из последней версии запустить. Поменялась ли ситуация?
Спасибо:

pft_man

Фотография
Дата: 13.01.2014
Ответить


А вот, кстати, возвращаясь к теме топика, такой вопрос возник. Допустим, есть у нас метод, подписанный на событие изменения стакана.

Код


private void ProcessMarketDepth(MarketDepth md)
{
    this.GuiAsync(() =>
        {
            // здесь что-то делаем в GUI-потоке
            // например, выводим изменение стакана на форму
        });
    
    // здесь тоже что-то делаем
    // например, считаем весь объём в бидах и офферах           
}


Вторая часть, где мы считаем объём в бидах и офферах будет выполняться не в GUI-потоке, а в том потоке, в котором этот метод ProcessMarketDepth вызвался? То есть программа будет работать так: при событии изменения стакана создаётся новый поток, в котором рассчитывается объём, и одновременно с этим в GUI-потоке произойдёт вывод на форму стакана? Всё правильно?
Спасибо:

IvanB

Фотография
Дата: 13.01.2014
Ответить


pft_man Перейти
А вот, кстати, возвращаясь к теме топика, такой вопрос возник. Допустим, есть у нас метод, подписанный на событие изменения стакана.

Код


private void ProcessMarketDepth(MarketDepth md)
{
    this.GuiAsync(() =>
        {
            // здесь что-то делаем в GUI-потоке
            // например, выводим изменение стакана на форму
        });
    
    // здесь тоже что-то делаем
    // например, считаем весь объём в бидах и офферах           
}


Вторая часть, где мы считаем объём в бидах и офферах будет выполняться не в GUI-потоке, а в том потоке, в котором этот метод ProcessMarketDepth вызвался? То есть программа будет работать так: при событии изменения стакана создаётся новый поток, в котором рассчитывается объём, и одновременно с этим в GUI-потоке произойдёт вывод на форму стакана? Всё правильно?

Вторая часть суждений не очень верна. Создается ли новый поток при изменении стакана или нет, нам, как пользователям, не известно, это заботы библиотеки. Для нас важно то, что метод ProcessMarketDepth, которым мы подписались на изменение события изменения стакана, будет вызываться.
После того как метод ProcessMarketDepth вызван, блок кода:
Код

            // здесь что-то делаем в GUI-потоке
            // например, выводим изменение стакана на форму

отправляется на выполнение в пользовательском (GUI) потоке, сразу после того как выполнение кода передано потоку GUI (но код еще не обязательно выполнен), выполняется следующий код:
Код

    // здесь тоже что-то делаем
    // например, считаем весь объём в бидах и офферах 

Спасибо:

pft_man

Фотография
Дата: 13.01.2014
Ответить


Фактически вывод графики и рассчёты в алгоритме происходят одновременно. Круто! Спасибо.
Спасибо:


Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy