HttpWebRequest使用注意(发生阻塞的解决办法)
HttpWebRequest myRequest = null;
HttpWebResponse myResponse = null;
Stream reqStream = null;
Stream resStream = null;

try
{
byte[] data = System.Text.Encoding.Default.GetBytes(param);

//想服务器端发送请求,获取照片信息
myRequest = (HttpWebRequest)WebRequest.Create(url);
myRequest.Method = "POST";
myRequest.KeepAlive = true;
myRequest.ContentType = "application/octet-stream";
myRequest.ContentLength = data.Length;
reqStream = myRequest.GetRequestStream();
reqStream.Write(data, 0, data.Length);
reqStream.Close();

myResponse = (HttpWebResponse)myRequest.GetResponse();
resStream = myResponse.GetResponseStream();
data = new byte[512];
int count = 0;
UIFactory.zZRK_MODIForm.memStream = new MemoryStream();
while ((count = resStream.Read(data, 0, data.Length)) > 0)
{
UIFactory.zZRK_MODIForm.memStream.Write(data, 0, count);
}
resStream.Close();
}
catch
{
}
finally
{
if (resStream != null)
{
resStream.Close();
}
if (reqStream != null)
{
reqStream.Close();
}
if (myResponse != null)
{
myResponse.Close();
}
}大家看下这段程序,有问题吗?乍一看,好像没有什么问题,所有的流都释放了,Response也释放了。。不过如果你写个循环无限次发起请求,你会发现,运行不了几次就阻塞了。为什么呢?大家看下面的代码
HttpWebRequest myRequest = null;
HttpWebResponse myResponse = null;
Stream reqStream = null;
Stream resStream = null;

try
{
byte[] data = System.Text.Encoding.Default.GetBytes(param);

//想服务器端发送请求,获取照片信息
myRequest = (HttpWebRequest)WebRequest.Create(url);
myRequest.Method = "POST";
myRequest.KeepAlive = true;
myRequest.ContentType = "application/octet-stream";
myRequest.ContentLength = data.Length;
reqStream = myRequest.GetRequestStream();
reqStream.Write(data, 0, data.Length);
reqStream.Close();

myResponse = (HttpWebResponse)myRequest.GetResponse();
resStream = myResponse.GetResponseStream();
data = new byte[512];
int count = 0;
UIFactory.zZRK_MODIForm.memStream = new MemoryStream();
while ((count = resStream.Read(data, 0, data.Length)) > 0)
{
UIFactory.zZRK_MODIForm.memStream.Write(data, 0, count);
}
resStream.Close();
}
catch
{
}
finally
{
if (resStream != null)
{
resStream.Close();
}
if (reqStream != null)
{
reqStream.Close();
}
if (myResponse != null)
{
myResponse.Close();
}
if (myRequest != null)
{
myRequest.Abort();
}
}多了些什么?多了这个
if (myRequest != null)
{
myRequest.Abort();
}其实很多时候释放了Stream和Response还不够,客户端的Request还是在保持着,需要等垃圾回收器来回收,所以一般很容易阻塞,导致请求发送不出去。加上这个就是让HttpWebRequest实例在不需要的时候及时释放资源。这样可以重复使用而不会阻塞。










































































































【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
2006-10-31 上网的时候出现 "Automation 服务器不能创建对象" 的解决方法
2006-10-31 showModalDialog和showModelessDialog使用心得