我需要听一个开放的API,根据正确的数据我需要下载一些文件并进行处理。我正在使用计时器每隔x秒自动发出一次下载请求,这样可以保持连接的有效性,因此可以重复使用。
总共有3个组成部分:
父类在单独的线程上生成侦听器,并启动计时器。计时器和侦听器都会调用父节点上的委托。
问题在于,每次从计时器下载时都会重复使用连接(从下载时间来看很明显),但是当监听器调用连接时,它不是。
裸骨代码:
using Timer = System.Timers.Timer;
namespace Hallelujah
{
public delegate void downloadData(bool process, string url);
public delegate void downloadDataInvoker(bool process, string url);
class Listener2
{
downloadData _downloadData;
public void start(string storeID, string shoes)
{
ServicePointManager.DefaultConnectionLimit = 500;
ServicePointManager.Expect100Continue = false;
ServicePointManager.MaxServicePoints = 0;
_downloadData += new downloadData(downloadDataCb);
Timer timer = new Timer(10000);
timer.Elapsed += timer_Elapsed;
timer.Enabled = true;
Listen listenTool = new Listen();
listenTool._downloadData += new downloadDataInvoker(invoker);
Thread thread = new Thread(new ParameterizedThreadStart(listenTool.init));
string[] str = { params };
thread.Start(str);
F1.updateStatus(System.Threading.Thread.CurrentThread.ManagedThreadId.ToString());
}
void timer_Elapsed(object sender, ElapsedEventArgs e)
{
_downloadData.Invoke(false, "example.com");
}
public void invoker(bool process, string url)
{
_downloadData.Invoke(process, url);
}
public void downloadDataCb(bool process, string url)
{
F1.updateStatus(System.Threading.Thread.CurrentThread.ManagedThreadId.ToString());
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(url);
req.KeepAlive = true;
req.ProtocolVersion = HttpVersion.Version10;
req.UnsafeAuthenticatedConnectionSharing = true;
req.Pipelined = true;
WebResponse res = req.GetResponse();
Stream sr = res.GetResponseStream();
//Reading response
if (process)
{
F1.updateStatus("Downloaded in " + t1.Seconds + " s " + t1.Milliseconds + "ms ");
}
else
F1.updateStatus("Downloaded NULL(from timer) in " + t1.Seconds + " s " + t1.Milliseconds + "ms ");
}
public void updateStatusCB(string status)
{
F1.updateStatus(status);
}
}
internal class Listen
{
public downloadDataInvoker _downloadDataInvoker;
public updateStatus _updateStatus;
public bool ToListen = true;
public void init(object objpass)
{
_updateStatus.Invoke(System.Threading.Thread.CurrentThread.ManagedThreadId.ToString());
while(ToListen){
//When a match is found
_downloadDataInvoker.Invoke(true, media_url);
}
}
}
知道为什么会这样发生?
答案 0 :(得分:0)
在调用计时器事件时创建一个新的保持活动请求。
根据您的需要,有很多下载任务(通过user_id?),您可以为每个任务创建一个保持活动请求,并开始请求异步,在回调事件中调用更新委托。