Подключение к Quik и запуск DDE
Atom
24.01.2011
vvt


Пробую подключение к Quik и запуск DDE из примеров (Sample, SampleSMA).
Все происходит очень медленно, поискал по форуму, есть несколько сообщений с такими же проблемами.
Железо вроде не самое слабое (Phenom II X2 555/8Gb/SSD), система Windows 7 Ultimate 64bit.
Запускаются Quik и примеры от имени администратора.
Хотелось бы все-таки с помощью Михаила докопаться до возможных причин таких тормозов.

В связи с этим первый вопрос:
после установки соединения с Квиком через QuikTrader.Connect() и поступления события Connected секунд где-то через 10 в Квике появляется окно "Выбор активных счетов и задание их очередности", которое висит и пропадает где-то через 30 секунд.
Так и должно быть?


Вот код этого консольного приложения:
Код
            Console.WriteLine("Запуск...");

            try
            {
                var waitHandle = new AutoResetEvent(false);

                // создаем шлюз к Quik-у
                var trader = new QuikTrader(@"C:\FinamJunior\info.exe");

                // подписываемся на событие успешного подключения
                // все действия необходимо производить только после подключения
                trader.Connected += () =>
                {
                    Console.WriteLine("Подключение было произведено успешно.");

                    // извещаем об успешном соединени
                    waitHandle.Set();
                };

                Console.WriteLine("Производим подключение...");

                trader.Connect();

                // дожидаемся события об успешном соединении
                waitHandle.WaitOne();
                Console.ReadKey();

                trader.Dispose();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex);
                Console.ReadKey();
            }

Теги:


Спасибо:


< 1 2 3 4  > >>
Alexander

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


Артем_2
У меня на рабое семерка(работает в домене), дома виста, и есть комп с XP еще, поэтому есть возможность сравнивать:
W7- я плачу
Vista - в депрессии
XP - Летает

Особенно поражает разница в скорости работы верифаера... В XP он как на межгалактической станции отрабатывает, а в W7 или Vista гораздо медленнее. При разработке, во время тестов - это ОЧЕНЬ ограничивает, поэтому лучше сидеть на XP, т.к. в W7 при такой сорости могут нервы не выдержать.
После фикса стал быстрее отрабатывать запуск Quik, но на запуске экспорта я че-то не очень ощутил изменения.
Я вот думаю, может это все связано с появлением WPF в новых операционках,который многослоен, может это как-то увеличивает количество окон, участвующих в поиске, надо Spy++ поковырять...


Оставь почту, вечером вышлю файл с экспортом
Спасибо:

Артем_2

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


Спасибо, вот она!
nazaroid2@mail.ru
Спасибо:

Артем_2

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


Увы, че-то не получил ничего...
Спасибо:

Alexander

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


Артем_2
Увы, че-то не получил ничего...


Вчера очень занят был, сейчас отправил.
Спасибо:

Артем_2

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


Понял... Спасибо, все получил! Будем разбираться...
Спасибо:

Den

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


Артем_2
Понял... Спасибо, все получил! Будем разбираться...


У меня тоже на XP экспорт по DDE летает. На Win7 жутко тормозит - пробовал на 3.2.2, отлаживаться вообще нервов не хватает.
Возможно коммент #8 может помочь разобраться...
Спасибо:

Артем_2

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


Есть идеи как сделать оптимизацию, но к сожалению, пока не пробовал их воплотить, т.к. нахожусь в отпуске. Обязательно сообщу че и как, когда поковыряюсь
Спасибо:

Артем_2

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


Если не получится, то по форумам вопросы раскидаю...
Спасибо:

Артем_2

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


Всем доброго дня!
Пока что изыскания следующие:

1. Небольшая статистика запуска 2-х таблиц квика (инструменты и позиции по деривативам) по дде показала, что разница весьма существенная. В моем примере виста отработала в 9 раз медленнее. Статистика условная, т.к. конфигурации компьютеров были разными, хотя и похожими.

Vista

Запуск экспорта по ДДЕ
Выпонение метода GetQuikWindows(Process process) заняло 0,3300634 секунд. Метод вернул 12 из 565 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,3549551 секунд. Метод вернул 12 из 565 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,329384 секунд. Метод вернул 13 из 566 окон
Открытие DDE окна => Выпонение метода WaitFor заняло 0,6904268 секунд
Остановка DDE вывода => Выпонение метода WaitFor заняло 0,0019952 секунд
Запуск DDE вывода => Выпонение метода WaitFor заняло 0,004298 секунд
Выпонение метода GetQuikWindows(Process process) заняло 0,355389 секунд. Метод вернул 12 из 566 окон
Закрытие DDE окна => Выпонение метода WaitFor заняло 0,355694 секунд
Запуск окна с заголовком <инструменты> занял 1,3918877 секунд

Выпонение метода GetQuikWindows(Process process) заняло 0,3480023 секунд. Метод вернул 12 из 565 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,3566171 секунд. Метод вернул 12 из 565 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,3168064 секунд. Метод вернул 13 из 566 окон
Открытие DDE окна => Выпонение метода WaitFor заняло 0,6788765 секунд
Остановка DDE вывода => Выпонение метода WaitFor заняло 0,0020404 секунд
Запуск DDE вывода => Выпонение метода WaitFor заняло 0,0029838 секунд
Выпонение метода GetQuikWindows(Process process) заняло 0,3298589 секунд. Метод вернул 12 из 566 окон
Закрытие DDE окна => Выпонение метода WaitFor заняло 0,3300634 секунд
Запуск окна с заголовком <позиции по деривативам> занял 1,3701531 секунд

Запуск ДДЕ занял: 2,762106 секунд

XP

Запуск экспорта по ДДЕ
Выпонение метода GetQuikWindows(Process process) заняло 0,0347218 секунд. Метод вернул 15 из 263 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,0358152 секунд. Метод вернул 15 из 263 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,0357294 секунд. Метод вернул 16 из 264 окон
Открытие DDE окна => Выпонение метода WaitFor заняло 0,0836615 секунд
Остановка DDE вывода => Выпонение метода WaitFor заняло 0,0018648 секунд
Запуск DDE вывода => Выпонение метода WaitFor заняло 0,0039082 секунд
Выпонение метода GetQuikWindows(Process process) заняло 0,0349754 секунд. Метод вернул 15 из 263 окон
Закрытие DDE окна => Выпонение метода WaitFor заняло 0,0351794 секунд
Запуск окна с заголовком <инструменты> занял 0,1647161 секунд

Выпонение метода GetQuikWindows(Process process) заняло 0,036516 секунд. Метод вернул 15 из 263 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,0351818 секунд. Метод вернул 15 из 263 окон
Выпонение метода GetQuikWindows(Process process) заняло 0,0350804 секунд. Метод вернул 16 из 264 окон
Открытие DDE окна => Выпонение метода WaitFor заняло 0,0727249 секунд
Остановка DDE вывода => Выпонение метода WaitFor заняло 0,0012032 секунд
Запуск DDE вывода => Выпонение метода WaitFor заняло 0,0029322 секунд
Выпонение метода GetQuikWindows(Process process) заняло 0,0363536 секунд. Метод вернул 15 из 263 окон
Закрытие DDE окна => Выпонение метода WaitFor заняло 0,0365615 секунд
Запуск окна с заголовком <позиции по деривативам> занял 0,1561724 секунд

Запуск ДДЕ занял: 0,320936 секунд


2. Удалось локализовать функцию, которая тормозит. - Это AllToplevelWindows, эта функция вызывается в S# для получения списка окон квика.- AllToplevelWindows в свою очередь вызывает из библиотеки ManagedWinapi.dll функцию FilterToplevelWindows.
3. В тестах видно, что AllToplevelWindows в висте возвращает гораздо большее количество окон 565 чем в XP 263. Интересно, что удаление значков из трея в висте значительно уменьшило количество окон (565 скатилось до 415) и работа с окнами в моем случае стала работать примерно в 2 раза быстрее. Но если наоткрывать вкладок в браузере, то скорость очень значительно снижается.
4. Я вывел заголовки окон в висте и XP, в висте оказалось гораздо больше пока непонятных окон без заголовков (330), чем в XP, где такие тоже имеются, но их меньше 152.
5. Пока это все, что удалось выяснить. Если у кого-то есть идеи и мнения на этом этапе, которые смогут ускорить процесс решения проблемы, пишите, пожалуйста.
Спасибо: Alexander sun

Alexander

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


Артём, спасибо.
Посмотрю сегодня чего да как.

Кроме тебя ни у кого нет доступа к этим методам, поэтому названия остальным мало что скажут :)
Спасибо:
< 1 2 3 4  > >>

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

loading
clippy