как дождаться снятия заявки
Atom
08.07.2010
Tauler


Михаил, а как в асинхронном режиме реализовать такое

1.Снять заявку
2.дождаться результат снятия - успешно снята или знятие не прошло

мне нужно отправить запрос на снятие и в результати от успеха/
неуспеха снятия предпринимать те или иные действия

Теги:


Спасибо:


1 2  >
Mikhail Sukhov

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


OrdersChanged пока не придет State Done

Спасибо:

Tauler

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


мутить блокировки с помощью ManualSetEvent?

Спасибо:

Mikhail Sukhov

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


Да, видимо придется как в примере SampleConsole раз у вас шаг за
шагом... Надо бы глянуть на этот новый WF. Рекомендуете статью для
начинающего?

Спасибо:

Tauler

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


Да я как то так ,по мсдну разбирался. и по примерам. я пару статей по
3.5 прочитал, начинал с него. но думаю в этом плане 3.5 и 4 - разницы
никакой нет.

Спасибо:

Mikhail Sukhov

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


Вы пишите, что там state режима нет. Так что есть.

Спасибо:

Tauler

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


в смысле state режима? там есть Flowchart

Спасибо:

Mikhail Sukhov

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


Так а зачем тогда Вы while чиклы пишите? Торговые алгоритмы опираются
на события. Думаю не спроста такие системы как ВетЛаб и Квант
предоставляют именно событийную модель работы. Понятно, что внутри иет
логика последовательная ввиде условий и циклов. Но отправная точна
всегда событие: закончился бар, начался новый, цена превысила, заявка
изменилась и т.д. Может все же идти по пути именно событий? Его до нас
уже протоптали.

Спасибо:

Tauler

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


Писал развернутый ответ - и тырнет крякнул.

Суть в том что все эти танцы с бубном лишь для того, чтобы сварганить
инструмент, в ктором трейдер будет робота РИСОВАТЬ, а рисовать он
может только в виде детерминированых блок-схем. трейдеру будет трудно
рассказать, как пользовать события, почему вмсето того, чтобы на
снятие заявки получить ответ - успешно или неспешн опрошло снятие, он
должен слушать событие, да и мне - разработчику намного удобнее было
бы написать

if(trader.CancelOrder(order))
{
действия при успешном снятии

else
{
при неуспешном

чем отменять заявку, а потом в событии получть заявку, выснять что
именно это за заявка, и какие действия были с ней в прошлом, и что
делать в будущем..

так же намного удобнее проверять заявку

if( status.Done && PartiallyMatched)
чем слушать событие.

а если заявок много, кторые надо проверять? тут уже в событийно
модели начинаются неудобства :)

Вообще конечно, как мне кажется, много пользы прнес бы смешаный режим,
т.к. выстаявлять заявки удобно в асинхронном - и там уже слушать
событии, а вот снимать например лучше в синхроноом - там сразу ясно -
снял или не снял.А так придется блокировки ставить пояле запроса на
снятии, в событии снимать - ну вы сами понимаетет прелести
ассинхронного программирования. :) Извините что так сумбурно :)

P.S. События жутко удобная вещь для написания всяческого рода
индикаторов, тут они выше всяких похвал.

Спасибо:

Mikhail Sukhov

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


Напрашивается обертка над ITrader (по аналогии с SyncTrader). Может
сами сделаете? У меня сейчас приоритеты другие.

Спасибо:

Tauler

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


так GuaranteeCancelOrder вроде решение проблемы.А насчет обертки -
буду думать. у меня счас приоритет арбитражер. :) Ежели обертку
синхринизирвоаную намучу - дам вам знать - может сгодится в
стокшарпе :)

Спасибо:
1 2  >

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

loading
clippy