Как ограничить количество одновременных операций асинхронного ввода-вывода?

// let's say there is a list of 1000+ URLs
string[] urls = { "http://google.com", "http://yahoo.com", ... };

// now let's send HTTP requests to each of these URLs in parallel
urls.AsParallel().ForAll(async (url) => {
    var client = new HttpClient();
    var html = await client.GetStringAsync(url);
});

Здесь проблема, он запускает более 1000 одновременных веб-запросов. Есть ли простой способ ограничить количество одновременных http-запросов? Таким образом, в любой момент времени загружается не более 20 веб-страниц. Как это сделать максимально эффективно?

Ответы на вопрос(12)

Ваш ответ на вопрос