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

как дождаться снятия заявки
Atom
7/8/2010
Tauler


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

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

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

Tags:


Thanks:


1 2  >
Mikhail Sukhov

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Tauler

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Mikhail Sukhov

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Tauler

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Mikhail Sukhov

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Tauler

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Mikhail Sukhov

Avatar
Date: 7/8/2010
Reply


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

Thanks:

Tauler

Avatar
Date: 7/9/2010
Reply


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

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

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

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

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

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

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

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

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

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

Thanks:

Mikhail Sukhov

Avatar
Date: 7/12/2010
Reply


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

Thanks:

Tauler

Avatar
Date: 7/12/2010
Reply


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

Thanks:
1 2  >

Attach files by dragging & dropping, , or pasting from the clipboard.

loading
clippy