Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
4 / 4 / 0
Регистрация: 19.08.2013
Сообщений: 138
1

Асинхронное программирование

28.04.2018, 18:29. Показов 1400. Ответов 3

Author24 — интернет-сервис помощи студентам
Здравствуйте. Написал класс для работа с API сайта, и он работает, что крайне странно, потому что в асинхронном программировании я пока ничего не понимаю. Но есть проблема: судя по тому, как долго выполняется программа, я сделал вывод, что новая итерация цикла в функции GetHashrate() начинается только после окончания предыдущей. То же самое и в цикле GetHashrate(int algo). Получается, программа последовательно отправляет 31*2=62 запроса к API сайта. Как можно это исправить, что бы программа сразу отправляла все запросы?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Net.Http;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;
using System.Threading.Tasks;
 
namespace AsincExample
{
    class Program
    {
        static void Main(string[] args)
        {
            foreach (var h in Api.GetHashrate().GetAwaiter().GetResult())
                Console.WriteLine(h.Count.ToString());
        }
    }
    class Api
    {
        static string apiAdressMethod = "https://api.nicehash.com/api?method=orders.get";
        static int algorithmsQuantity = 31;
        public static async Task<List<Dictionary<float, float>>> GetHashrate()
        {
            List<Dictionary<float, float>> Hashrate = new List<Dictionary<float, float>>();
            for (byte algo = 0; algo < algorithmsQuantity; algo++)
                Hashrate.Add(await GetHashrate(algo));
            return Hashrate;
        }
        static async Task<Dictionary<float, float>> GetHashrate(int algo)
        {
            Dictionary<float, float> Hashrate = new Dictionary<float, float>();
            for (byte location = 0; location <= 1; location++)
                foreach (Order o in (await GetHashrate(location, algo)).Result.Order)
                {
                    float price = float.Parse(o.Price, CultureInfo.InvariantCulture);
                    float speed = float.Parse(o.AcceptedSpeed, CultureInfo.InvariantCulture);
                    if (o.Type == "0")
                    {
                        if (Hashrate.ContainsKey(price))
                            Hashrate[price] += speed;
                        else
                            Hashrate.Add(price, speed);
                    }
                }
            return Hashrate;
        }
        static async Task<Answer> GetHashrate(int location, int algo)
        {
            using (var http = new HttpClient())
            using (var stream = await http.GetStreamAsync(apiAdressMethod + $"&location={location}&algo={algo}"))
            {
                var serializer = new DataContractJsonSerializer(typeof(Answer));
                return (Answer)serializer.ReadObject(stream);
            }
        }
 
        [DataContract]
        class Answer
        {
            [DataMember(Name = "result")]
            public Result Result { get; set; }
            [DataMember(Name = "method")]
            public string Method { get; set; }
        }
        [DataContract]
        class Result
        {
            [DataMember(Name = "orders")]
            public Order[] Order { get; set; }
            [DataMember(Name = "timestamp")]
            public string Timestamp { get; set; }
        }
        [DataContract]
        class Order
        {
            [DataMember(Name = "limit_speed")]
            public string LimitSpeed { get; set; }
            [DataMember(Name = "alive")]
            public string Alive { get; set; }
            [DataMember(Name = "price")]
            public string Price { get; set; }
            [DataMember(Name = "id")]
            public string Id { get; set; }
            [DataMember(Name = "type")]
            public string Type { get; set; }
            [DataMember(Name = "workers")]
            public string Workers { get; set; }
            [DataMember(Name = "algo")]
            public string Algo { get; set; }
            [DataMember(Name = "accepted_speed")]
            public string AcceptedSpeed { get; set; }
        }
    }
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.04.2018, 18:29
Ответы с готовыми решениями:

Асинхронное программирование await async
Всем привет! Пытаюсь разобраться с асинхронным вызовом методов. Узнал такую вещь: если...

Клиент-Серверное приложение, асинхронное программирование
Здравствуйте, это мой первый опыт в написании приложений такого плана, но я прочитал уже довольно...

Асинхронное программирование: почему в AsyncCallback не указать метод обратного вызова
Доброго времени суток ! Не могу понять вот эту строчку r.BeginGetResponse(new...

Асинхронное логирование
Доброго времени. Пишу небольшой метод, который забирает данные и записывает их в файл. Запрос...

3
1150 / 858 / 263
Регистрация: 30.04.2009
Сообщений: 3,597
29.04.2018, 19:28 2
Лучший ответ Сообщение было отмечено fingolfin_ как решение

Решение

Если не понимаете как работает async await, то лучше не используйте.
Для выполнения параллельно задач из списка используйте Parallel.For:

C#
1
2
3
4
5
6
7
            ConcurrentBag<Dictionary<float, float>> Hashrate = new ConcurrentBag<Dictionary<float, float>>();
            Parallel.For(0, algorithmsQuantity, (algo) =>
            {
                Hashrate.Add(GetHashrate(algo));
            });
 
            return Hashrate.ToList();
Советую также статью с подробным описанием TPL (Task Parallel Library) и не только https://rsdn.org/article/dotne... Part_3.xml

Добавлено через 3 минуты
Данные в результирующем списке будут неупорядочены по индексу algo, т.к. нет гарантии, что все задачи будут заканчиваться поочередно.
1
4 / 4 / 0
Регистрация: 19.08.2013
Сообщений: 138
30.04.2018, 15:45  [ТС] 3
Спасибо! Все работает!
Правильно я понимаю, что если написать так, получится уже отсортированный по algo список?
C#
1
2
3
4
5
6
var Hashrate = new ConcurrentBag<(int algo, Dictionary<float, float> orders)>();
Parallel.For(0, algorithmsQuantity, (algo) =>
{
    Hashrate.Add((algo, GetHashrate(algo)));
});
return Hashrate.OrderBy(tuple => tuple.algo).Select(tuple => tuple.orders).ToList();
0
 Аватар для Fleder
263 / 224 / 108
Регистрация: 09.12.2015
Сообщений: 652
30.04.2018, 16:55 4
Цитата Сообщение от fingolfin_ Посмотреть сообщение
Правильно я понимаю, что если написать так, получится уже отсортированный по algo список?
Если нужен упорядоченный по индексу список, элементы которого создаются параллельно,
то его проще всего получить с помощью Parallel LINQ:
C#
1
2
return ParallelEnumerable.Range(0, algorithmsQuantity).AsOrdered()
   .Select(x => GetHashrate(x)).ToList();
2
30.04.2018, 16:55
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.04.2018, 16:55
Помогаю со студенческими работами здесь

Асинхронное выполнение
Здравствуйте имеется простой метод, который посылает запрос на сервер и получает ответ,...

Асинхронное выполнение сортировки
Помогите выполнить задание:Продемонстрируйте асинхронное выполнение, то есть не дожидаясь окончания...

Асинхронное клиент серверное приложение
Всем доброго времени суток, а так же спасибо всем кто загляну и не прошёл мимо. Сразу...

Как написать асинхронное лямбда-выражение?
Вопрос в заголовке.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как в цикле обойти все элементы map в Java
bytestream 25.01.2025
В разработке на Java одной из наиболее востребованных структур данных является интерфейс Map, который предоставляет эффективный способ хранения и управления парами "ключ-значение". Разработчики. . .
Для чего нужен UserManager.isU­serAGoat(­) в Android и как это использовать
bytestream 25.01.2025
В мире Android-разработки существует множество интересных и порой загадочных функций, о которых знают далеко не все разработчики. Одной из таких функций является метод UserManager. isUserAGoat(),. . .
Как обойти масси в JavaScript. Всё о циклах
bytestream 25.01.2025
JavaScript представляет собой мощный язык программирования, широко используемый в веб-разработке, где массивы и циклы являются фундаментальными концепциями для эффективной работы с данными. Массив в. . .
Как сделать, чтобы существующая ветка отслеживала удалённую в Git. Связывание локальных и удалённых веток
bytestream 25.01.2025
В разработке программного обеспечения системы контроля версий стали неотъемлемой частью процесса создания качественного программного продукта. Эти инструменты позволяют разработчикам эффективно. . .
Как проверить, что файл НЕ существует с помощью Bash
bytestream 25.01.2025
В системном администрировании проверка существования файлов является фундаментальной операцией, особенно при написании скриптов на Bash. Правильная обработка ситуаций, когда файл отсутствует,. . .
Как проверить, что строка пустая, неопределена или null в JavaScript
bytestream 25.01.2025
При разработке веб-приложений на JavaScript разработчики регулярно сталкиваются с необходимостью проверки строковых значений на различные состояния. Валидация данных является критически важным. . .
Как проверить существование ключа в объекте или массиве в JavaScript
bytestream 25.01.2025
При разработке веб-приложений на JavaScript программисты постоянно сталкиваются с необходимостью работать с объектами и массивами. Эти структуры данных являются фундаментальными элементами языка и. . .
Как создать ArrayList из массива (array) в Java
bytestream 25.01.2025
При разработке программного обеспечения на языке Java программисты часто сталкиваются с необходимостью эффективного управления наборами данных. Массивы и ArrayList являются двумя фундаментальными. . .
Как сгенерировать случайные целые числа (int) в указанном диапазоне в Java
bytestream 25.01.2025
В программировании генерация случайных чисел является важнейшим инструментом для решения множества практических задач. От создания игровых механик до реализации алгоритмов машинного обучения, от. . .
Как сделать, чтобы grep выводил строки до и после найденной
hw_wired 25.01.2025
Утилита grep стала незаменимым инструментом для поиска и фильтрации информации в Unix-подобных операционных системах. Эта командная утилита позволяет осуществлять поиск строк, соответствующих. . .
Как клонировать определенную ветку в Git
bytestream 24.01.2025
Одной из ключевых функций Git является возможность клонирования веток, что позволяет создавать локальные копии удаленных репозиториев и работать с определенными версиями проекта. Этот механизм. . .
Как в цикле обойти строки DataFrame в Pandas Python
bytestream 24.01.2025
DataFrame представляет собой одну из основных структур данных в библиотеке Python Pandas, которая организует информацию в виде двумерной таблицы с строками и столбцами. Эта структура данных особенно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru