Dies geschieht nur auf einer meiner Maschinen. Ich denke, es ist ein Umgebungsprojektionsproblem. Auf allen Computern wird die Firewall der ESET Smart Security-Software ausgeführt. Irgendwelche Ideen?DownloadStringAsync blockiert Thread für 14 Sekunden beim ersten Aufruf
using System;
using System.Net;
using System.Diagnostics;
using System.Threading;
namespace Test
{
static class Program
{
[STAThread]
static void Main()
{
bool exit = false;
WebClient wc = new WebClient();
DateTime before = DateTime.Now;
wc.DownloadStringAsync(new Uri("http://74.125.95.147"), "First"); // IP Address of google, so DNS requests don't add to time.
wc.DownloadStringCompleted += delegate(object sender, DownloadStringCompletedEventArgs e)
{
Debug.WriteLine(e.UserState + " Call: " + (DateTime.Now - before));
if ((string)e.UserState == "First")
{
before = DateTime.Now;
wc.DownloadStringAsync(new Uri("http://74.125.95.147"), "Second");
}
else
exit = true;
};
/*
*
* Output:
*
* First Call: 00:00:13.7647873
* Second Call: 00:00:00.0740042
*
*/
while (!exit)
Thread.Sleep(1000);
}
}
}
Dies kann auf automatische Proxy-Erkennung zurückzuführen sein. Jede Änderung, wenn Sie WebClient.Proxy auf GlobalProxySelection.GetEmptyWebProxy festlegen? http://msdn.microsoft.com/en-us/library/system.net.webclient.proxy.aspx http://msdn.microsoft.com/en-us/library/system.net.globalproxyselection.getemptywebproxy.aspx – dtb
Ja, das hat es behoben. Vielen Dank! Erster Anruf: 00: 00: 00.1680096 Zweiter Anruf: 00: 00: 00.0400023 – Mango
@ dtb, fügen Sie das als Antwort hinzu. Es verdient eine oder zwei Stimmen. –