Многопоточная программа - соображения дизайна - PullRequest
2 голосов
/ 07 марта 2011

Это может быть довольно сложно, так что извините за многословный вопрос.

1) Сейчас я собираюсь перестроить свое приложение, чтобы работать с несколькими потоками (точнее, со специалистами по фону). У меня, вероятно, будет 5 или 6 BGW для конкретного интерфейса. Моя первая проблема, у меня есть один вызов метода, который необходим графическому интерфейсу для получения его «основных» данных. Различные части этих данных затем используются для различных других вызовов мест, которые также формируют данные, которые отображаются на той же странице, что и основные данные. Как я могу обработать это с различными фоновыми работниками так, что backgroundworker1 получает основные данные, backgroundworker2 использует определенный элемент ядра для получения дополнительных данных, backgroundworker3 использует некоторые основные данные и так далее? Таким образом, мой графический интерфейс и основной поток остаются в разблокированном состоянии

2) Как я уже говорил ранее, графический интерфейс должен сначала получить набор основных данных, а затем несколько других обращений к базе данных, чтобы получить остальные важные данные. Как я уже видел, мне нужно получить эти данные за пределами конструктора графического интерфейса, поэтому при создании графического интерфейса нет таких больших требований. С точки зрения дизайна, как я должен построить свой графический интерфейс таким образом, чтобы он имел доступ к данным, которые затем просто необходимо отобразить при создании, а не получить к ним доступ, а затем отобразить?

Надеюсь, это не слишком многословные вопросы? Я уже вижу, что многое из этого сводится к разработке программ, что для новичка довольно сложно (на мой взгляд, конечно). Надеюсь, кто-нибудь посоветует мне, что они будут делать в этой ситуации.

Спасибо

Ответы [ 2 ]

1 голос
/ 07 марта 2011

Звучит как хорошая задача для рабочей очереди.Основная идея заключается в том, чтобы добавить рабочий элемент в очередь, и этот рабочий элемент будет иметь связанную функцию для работы с данными.Работа обычно распространяется на любое количество потоков, которые вы укажете.

Некоторые из них существуют, просто Google для этого.

0 голосов
/ 07 марта 2011

Вы смотрели параллельную библиотеку задач .net 4? Task Parallel Library
Посмотрите на область под названием «Создание продолжений задач» почти на полпути вниз по странице.

Это пример связанного сайта

Task<byte[]> getData = new Task<byte[]>(() => GetFileData());
Task<double[]> analyzeData = getData.ContinueWith(x => Analyze(x.Result));
Task<string> reportData = analyzeData.ContinueWith(y => Summarize(y.Result));
getData.Start();

System.IO.File.WriteAllText(@"C:\reportFolder\report.txt", reportData.Result);

// или ...

Task<string> reportData2 = Task.Factory.StartNew(() => GetFileData())
                                        .ContinueWith((x) => Analyze(x.Result))
                                        .ContinueWith((y) => Summarize(y.Result));

System.IO.File.WriteAllText(@"C:\reportFolder\report.txt", reportData.Result);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...