Arhn - архитектура программирования

Glimpse ADO ExecuteReaderAsync() не отвечает

При использовании Glimpse ADO ExecuteReaderAsync() не возвращал ответа навсегда:

var factory = System.Data.Common.DbProviderFactories.GetFactory("System.Data.SqlClient");
var conn = factory.CreateConnection();
conn.ConnectionString = "YourConnectionString";
conn.Open();

var cmd = conn.CreateCommand();
cmd.CommandText = "Select 1";                 // Correct SQL is not required. If use SQL "Foo" brings same result.

var result = cmd.ExecuteReaderAsync().Result; // NG. Responce did not return forever.
// var result = cmd.ExecuteReader();          // OK. Responce is return soon.

Я использую GlimpseAdo, поэтому factory.CreateConnection() создает экземпляр GlimpseDbConnection. Затем я выполняю асинхронный SQL через GlimpseDbCommand и жду асинхронного результата запроса.

Но cmd.ExecuteReaderAsync().Result никогда не возвращал никаких ответов.
Подождите более 10 минут, но время ожидания не истекло. Я приостановил отладку в VisualStudio, оператор отладки находится на var result = cmd.ExecuteReaderAsync().Result;.

Я думаю... эта проблема вызвана асинхронностью.
Вы знаете, почему и куда пропал ответ?

Спасибо за помощь!

Используется:

.Net Framework 4.5.2
Glimpse.Core 1.8.6
Glimpse ADO 1.7.3
SQL Server 2008 R2


Ответы:


1

Этот:

var result = cmd.ExecuteReaderAsync().Result;

Приводит ваш код к зависанию. Я предполагаю, что вы используете приложение, которое передает контекст синхронизации (пользовательский интерфейс, ASP.NET, универсальное приложение или подобное). Вот почему вы не должны блокировать асинхронный код< /а>

Чтобы обойти это, вам нужно сделать свой метод async Task и использовать await вместо .Result:

var result = await cmd.ExecuteReaderAsync();

Вы также можете видеть Попытка вызвать асинхронный метод синхронно. Он ждет Task.Result вечно и тупиковая ситуация даже после использования ConfigureAwait(false) в потоке Asp.Net для получения дополнительной информации.

17.02.2015
  • Спасибо за ответ! Я неправильно понял об асинхронной обработке. 17.02.2015
  • @t2k Ты не первый :) 17.02.2015
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..