MarketDepthsChanged !!!
Atom Reply
12/27/2012


Добрый вечер.
Помогите разобраться вот с чем.
Как подписаться на изменения котировок конкретного стакана?
Событие MarketDepthsChanged - подписывается на изменение последнего зарегистрированного стакана. А если я зарегистрировал их несколько (к примеру 3) как подписаться на изменение котировок 2-ого стакана? Или придется 2-ой стакан снова регистрировать и к нему уже подвязываться?
Как, к примеру, через Trader.MarketDepthsChanged += Changeddepths подписаться на изменение котировок нужного стакана, а не последнего?

Tags:


Thanks:




22 Answers
Moadip

Avatar
Articles author Programmer
Date: 12/27/2012
Reply


По событию MarketDepthsChanged будут приходить изменения по всем зарегистрированным стаканам - IEnumerable<MarketDepth>.
Можно фильтрануть пришедшие стаканы по Security и взять нужный.
Код

_quikTrader.MarketDepthsChanged += enumerable =>
{
	var depth = enumerable.Where(d => d.Security == _instr1);
	...
};


Другой вариант. После того как зарегистрирован стакан по инструменту, взять его и подписаться на событие QuotesChanged
Код

private MarketDepth _marketDepth;

_quikTrader.RegisterMarketDepth(_instr1);
_marketDepth = _quikTrader.GetMarketDepth(_instr1);

_marketDepth.QuotesChanged += () =>
{
	...
};


И еще один вариант - использовать правила. Правила можно использовать как внутри стратегии так и вне ее.
Код

_instr1
	.WhenMarketDepthChanged()
	.Do(depth =>
	{
		...
	})
	.Apply();


Выбирайте что больше нравится.Smile
Thanks: Tik_Time

Tik_Time

Avatar
Date: 12/27/2012
Reply


Огромное спасибо. Очень выручили!!!
Topic starter
Thanks:

Творог

Avatar
Date: 1/7/2013
Reply


Подскажите как правильно прочитать данное выражение из примера:
Trader.MarketDepthsChanged += depths => this.GuiAsync(() => OnMarketDepthsChanged(depths));

Я так понял это лямбда-выражение. depths - это параметры, которые передаются обработчику. Но я не вижу, где объявляется depths и GuiAsync, что будет, если убрать this. В общем запутался в этом синтаксисе совсем.

Также, будет ли подобные приёмы обсуждаться на вебинаре от Смарлаба послезавтра?
Thanks:

Дюшес

Avatar
Programmer
Date: 1/8/2013
Reply


Творог Перейти
Подскажите как правильно прочитать данное выражение из примера:
Trader.MarketDepthsChanged += depths => this.GuiAsync(() => OnMarketDepthsChanged(depths));


Описано в Шилдт - C# 4.0. Полное руководство, глава 15
Thanks:

Творог

Avatar
Date: 1/8/2013
Reply


Дюшес Перейти
Творог Перейти
Подскажите как правильно прочитать данное выражение из примера:
Trader.MarketDepthsChanged += depths => this.GuiAsync(() => OnMarketDepthsChanged(depths));


Описано в Шилдт - C# 4.0. Полное руководство, глава 15


Это я и сам себе мог бы ответить. Вопрос конкретный по примеру.
Thanks:

Дюшес

Avatar
Programmer
Date: 1/8/2013
Reply


Творог Перейти

Я так понял это лямбда-выражение. depths - это параметры, которые передаются обработчику. Но я не вижу, где объявляется depths и GuiAsync, что будет, если убрать this.

Тогда не совсем понятно, что не понятно...

коллекция depths возвращается в событии MarketDepthsChanged: https://stocksharp.ru/do..._MarketDepthsChanged.htm
объявляется тут же в лямбда выражении, тип ее IEnumerable<MarketDepth>.

про GuiAsync описано тут: https://stocksharp.ru/do...1e-8ba9-e1fa98728f92.htm
это метод-расширение, просто обертка для Dispatcher.BeginInvoke(Action) для асинхронной обработки потока, определен метод в библиотеке Ecng.Xaml.XamlHelper.
Thanks:

Творог

Avatar
Date: 1/8/2013
Reply


А что означают пустые скобочки и для чего они (() =>
this. - это в данном случае объект класса QuikTrader, т.е. Trader?
Thanks:

Творог

Avatar
Date: 1/8/2013
Reply


А в этом примере 2 действия в одной строчке.

Здесь, наверное, создаётся коллекция-портфель
private readonly PortfoliosWindow _portfoliosWindow = new PortfoliosWindow();

А здесь, наверное, если происходит событие типа изменение портфеля, то куда-то добавляется новый Range, должно быть в ту же коллекцию.
Trader.NewPortfolios += portfolios => this.GuiAsync(() => _portfoliosWindow.Portfolios.AddRange(portfolios));

Сложно как-то... Huh
Thanks:

Дюшес

Avatar
Programmer
Date: 1/8/2013
Reply


Творог Перейти
А что означают пустые скобочки и для чего они (() =>
this. - это в данном случае объект класса QuikTrader, т.е. Trader?


Пустые скобки - это отсутствие параметров. В вышеназванном источнике как раз это описано. ;)
this - это текущий объект класса, вероятно MainWindow.
Thanks:

VassilSanych

Avatar
Date: 1/8/2013
Reply


Творог Перейти
А что означают пустые скобочки и для чего они (() =>

Лямбда-выражения

Thanks:

Геннадий Ванин (Gennady Vanin)

Avatar
Date: 1/8/2013
Reply


Творог Перейти
Подскажите как правильно прочитать данное выражение из примера:
Trader.MarketDepthsChanged += depths => this.GuiAsync(() => OnMarketDepthsChanged(depths));

Установите себе триал ReSharper (JetBrains) и, тогда, Вам будет видно, что:
  • при наведении мышки на GuiAsync()выдаётся описание:

    (extension) viod DispatcherObject.GuiAsync(Action action)

Что выражения:

  • Код
    Trader.MarketDepthsChanged += depths => this.GuiAsync(() => OnMarketDepthsChanged(depths));//as extension meth

  • Код
    Trader.MarketDepthsChanged += depths => XamlHelper.GuiAsync(this, () => OnMarketDepthsChanged(depths));//as static meth

  • Код
    Trader.MarketDepthsChanged += depths => XamlHelper.GuiAsync(this, delegate  {OnMarketDepthsChanged(depths) };);

  • Код
    Trader.MarketDepthsChanged += depths => this.GuiAsync(delegate { OnMarketDepthsChanged(depths);} );//as anonymous meth

  • и т.д., и т.п.

эквивалентны

Пронавигировав по "Go To Implementation" к GuiAsync(),
что он определён в в Ecng.Xaml.XamlHelper, как :
Код
public static void GuiAsync(this DispatcherObject obj, Action action)
{
  if (obj == null)
    throw new ArgumentNullException("obj");
  XamlHelper.GuiAsync(obj.Dispatcher, action);
}
//==============================================
public static void GuiAsync(this Dispatcher dispatcher, Action action)
{
  XamlHelper.GuiAsync(dispatcher, action, DispatcherPriority.Normal);
}
//==============================================
public static void GuiAsync(this Dispatcher dispatcher, Action action, DispatcherPriority priority)
{
  if (dispatcher == null)
    throw new ArgumentNullException("dispatcher");
  if (action == null)
    throw new ArgumentNullException("action");
  if (dispatcher.CheckAccess())
     action();
  else
    dispatcher.BeginInvoke((Delegate) action, priority, new object[0]);
}
Thanks:

Творог

Avatar
Date: 1/9/2013
Reply


Спасибо за наводку, ReSharper поставил.

Но я не вижу где объявляется depths, что он содержит, что возвращает. Это делегат?
Почему дважды повторяется оператор => ?
Сначала отправляются пустые параметры () => OnMarketDepthsChanged(depths), а потом всё остальное? Какая цепочка выполнения?
Thanks:

Den

Avatar
Date: 1/9/2013
Reply


Геннадий Ванин (Gennady Vanin) Перейти

Пронавигировав по "Go To Implementation" к GuiAsync(),
что он определён в в Ecng.Xaml.XamlHelper, как :
Код
public static void GuiAsync(this DispatcherObject obj, Action action)
{
  if (obj == null)
    throw new ArgumentNullException("obj");
  XamlHelper.GuiAsync(obj.Dispatcher, action);
}


А откуда у вас решарпер сорцы берет? У меня он только до декларации по "Go To Implementation" доходит... )))
Thanks:

Геннадий Ванин (Gennady Vanin)

Avatar
Date: 1/9/2013
Reply


Творог Перейти
Спасибо за наводку, ReSharper поставил.

Но я не вижу где объявляется depths, что он содержит, что возвращает. Это делегат?
Почему дважды повторяется оператор => ?
Сначала отправляются пустые параметры () => OnMarketDepthsChanged(depths), а потом всё остальное? Какая цепочка выполнения?

Я Вам удочку дал (ReSharper или R#), а Вы продолжаете требовать рыбу...


Первое depth - согласно контекстной подсказке - (parameter) IEnumerable <MarketDepth>
Объявляется он в Вашей строчке и определяется компилятором из контексту - по синтакису выражения и используемых в них типах

В частности событием, которое, опять же можно посмотреть через R#, определяется в StockSharp.Algo.BaseTrader:
Код
public virtual event Action<IEnumerable<MarketDepth>> MarketDepthsChanged
{
}

Посм., что такое Action, Event, Event Handler, delegate

Можете ничего не писать дважды, написав, для прикола:
Код
object depths2 = null;
Trader.MarketDepthsChanged += depths => OnMarketDepthsChanged(depths2);
private void OnMarketDepthsChanged(object whatEver)
{
    throw new NotImplementedException();
}


и вообще не использовать лямбда-выражения!

Возвращаясь к Вашему выражению, пишите в коде изначальное

Код
Trader.MarketDepthsChanged += whatEver => this.GuiAsync(() => OnMarketDepthsChanged(whatEver));
//вставляете, используя ReSharper, реализацию OnMarketDepthsChanged() 
private void OnMarketDepthsChanged(IEnumerable<MarketDepth> asfsdf)
{
    throw new NotImplementedException();
}

Разворачиваете, используя ReSharper, рядом стоящие закомментированные строчки - эквивалентны:

Trader.MarketDepthsChanged +=
whatEver => this.GuiAsync(() => OnMarketDepthsChanged(whatEver));

в

Код
Trader.MarketDepthsChanged += OnTraderOnMarketDepthsChangedOrWhatEver;
private void OnTraderOnMarketDepthsChangedOrWhatEver(IEnumerable<MarketDepth> whatEver)
{
//расскомментировать любую строчку - они эквивалентны
    //this.GuiAsync(() => OnMarketDepthsChanged(whatEver));

    //XamlHelper.GuiAsync(this, () => OnMarketDepthsChanged(whatEver));

    //XamlHelper.GuiAsync(this, delegate { OnMarketDepthsChanged(whatEver); });
}


Так понятнее?

Thanks:

Геннадий Ванин (Gennady Vanin)

Avatar
Date: 1/9/2013
Reply


Den Перейти
А откуда у вас решарпер сорцы берет? У меня он только до декларации по "Go To Implementation" доходит... )))

М.б., это и не ReSharper, давно пользуюсь, не помню, что откуда берётся...
У меня ещё и .NET Reflector установлен

Да там в сырцах смотреть особенно нечего - они в основном обфусцированы, за редким исключеним попадается что-то читабельное
Thanks: Den

Moadip

Avatar
Articles author Programmer
Date: 1/9/2013
Reply


Den Перейти
А откуда у вас решарпер сорцы берет? У меня он только до декларации по "Go To Implementation" доходит... )))


При первом переходе по Ctrl + LeftMouse появится окошко с предложением и предупреждением.Smile
Соглашаемся.
#R скачает какую-то примочку с сайта. После этого будет декомпилить.
Thanks: Геннадий Ванин (Gennady Vanin) Den

Den

Avatar
Date: 1/10/2013
Reply


Moadip Перейти

При первом переходе по Ctrl + LeftMouse появится окошко с предложением и предупреждением.Smile
Соглашаемся. #R скачает какую-то примочку с сайта. После этого будет декомпилить.


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

Все заработало, спасибо!
Thanks:

Творог

Avatar
Date: 1/11/2013
Reply


А почему в разделе SS API нет подраздела с описанием класса XamlHelper? Ведь там же, наверное, должно быть подробное описание, что такое GuiAsync и что за конструкции, где дважды передаются параметры в обработчик знаком =>.

Я правильно понимаю, что GuiAsync() - это метод, куда в качестве аргумента передаётся поток, который должен идти в порядке очереди, а не параллельно?
Thanks:

Moadip

Avatar
Articles author Programmer
Date: 1/11/2013
Reply


Цитата:
А почему в разделе SS API нет подраздела с описанием класса XamlHelper?

Где то я подобный вопрос уже видел.Smile

Полный путь для XamlHelper - Ecng.Xaml.XamlHelper.
Описание API есть только для основных библиотек- Stocksharp.

Посмотрите сколько библиотек начинается с Ecng и сколько там классов.

Конечно если бы кто то взялся чтобы сделать описание, было бы круто.
Thanks:

VassilSanych

Avatar
Date: 1/11/2013
Reply


Творог Перейти
Я правильно понимаю, что GuiAsync() - это метод, куда в качестве аргумента передаётся поток, который должен идти в порядке очереди, а не параллельно?


GuiAsync() оборачивает Dispatcher.BeginInvoke(), добавляя всякие ненужные проверки :)
А тот в свою очередь синхронизирует текущий поток с потоком отрисовки GUI, потому что в Windows издревле GUI программы может работать только в одном потоке.
Thanks:

Геннадий Ванин (Gennady Vanin)

Avatar
Date: 1/11/2013
Reply


Творог Перейти
Я правильно понимаю, что GuiAsync() - это метод, куда в качестве аргумента передаётся поток, который должен идти в порядке очереди, а не параллельно?

Никто ничего не прокомментировал и я уж прям засомневался в моих познаниях...

"в порядке очереди" - это синхронизированное (в частности, однопоточное всегда такое было) или согласуемое-завсисмое одно от другого выполнение? sync (Synchronized)

Асинхронное (async) - параллельное, никого не ждущее и ни с кем не согласовываемое, с той же буквы, что анархическое, или параллельное, что у меня ассоциируется с многопоточностью и хаосом

А ещё, когда что-то там синхронизируют (ставят в очередь и строят), то ставят замки (lock), семафоры, светофоры, мониторы и караульных с ружжами
Thanks:

VassilSanych

Avatar
Date: 1/12/2013
Reply


Геннадий Ванин (Gennady Vanin) Перейти
А ещё, когда что-то там синхронизируют (ставят в очередь и строят), то ставят замки (lock), семафоры, светофоры, мониторы и караульных с ружжами

Синхронизация Dispatcher - это отдельный разговор. Возможно внутрях оно так и есть.
UPD
А назвать метод синхронизации "...Async" - это конечно мощно. Внушаит.
Thanks:


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

loading
clippy