zoukankan      html  css  js  c++  java
  • [Socket网络编程]一个封锁操作被对 WSACancelBlockingCall 的调用中断。

    原文地址:http://www.cnblogs.com/xiwang/archive/2012/10/25/2740114.html记录在此,方便查阅。

    C#中在使用UDPClient循环监听端口,在断开UPDClient的时候,使用try...catch捕获了异常,System.NET.Sockets.SocketException一个封锁操作被对 WSACancelBlockingCall 的调用中断”,ErrorCode=10004。

          接收时的代码如下:

    复制代码
    IPEndPoint ipendpoint = new IPEndPoint(IPAddress.Any, 0);
                Thread thread = new Thread(() =>
                        {
                            while (!m_StopListen)
                            {
                                try
                                {
                                    if (m_udpClient.Client == null) return;
                                    byte[] bytes = m_udpClient.Receive(ref ipendpoint);
    
                                    string str = Encoding.Default.GetString(bytes);
                                    Console.WriteLine(string.Format("接收的数据是: {0},来自IP:{1} ,端口 : {2}", str, ipendpoint.Address.ToString(), ipendpoint.Port));
    
                                }
                                catch (Exception ex)
                                {
                                    Console.WriteLine(ex.Message);
                                }
                                Thread.Sleep(100);
                            }
                        });
                thread.IsBackground = true;
                thread.Start();
    复制代码

           停止监听的代码:

                this.m_StopListen = true;
                m_udpClient.Close();
                m_udpClient = null;

           解决办法:

          在开始调用UDPClient的Receive方法之前对UDPClient.Available属性进行判断,当Available属性大于0时才开始从缓冲区读取网络数据:

    复制代码
                                try
                                {
                                    if (m_udpClient.Available <= 0) continue; 
                                    if (m_udpClient.Client == null) return;
                                    byte[] bytes = m_udpClient.Receive(ref ipendpoint);
    
                                    string str = Encoding.Default.GetString(bytes);
                                    Console.WriteLine(string.Format("接收的数据是: {0},来自IP:{1} ,端口 : {2}", str, ipendpoint.Address.ToString(), ipendpoint.Port));
    
                                }
    复制代码

           原因:MSDN对Available的解释是:

          “Available 属性用于确定在网络缓冲区中排队等待读取的数据的量。 如果数据可用,可调用 Read 获取数据。 如果无数据可用,则 Available 属性返回 0。

        如果远程主机处于关机状态或关闭了连接,则 Available 属性将引发SocketException如果远程主机处于关机状态或关闭了连接,则 Available 属性将引发SocketException”。

               也就是说,错误的原因在于,但调用Close后,线程恰好继续向网络缓冲区中读取数据,所以引发SocketException。

         

  • 相关阅读:
    linux系统数据落盘之细节
    不同类型文件“可读写”的含义
    zz存储系统中缓存的三种类型
    library满(磁带紊乱、虚拟机恢复失败)
    TSM日常维护
    入门级磁带机使用方法
    关于 tsm 磁带槽位
    TSM lan-free原理及配置
    TSM中备份(Backup)和归档(Archive)的区别
    指定stg备份 (即指定tape 磁带)
  • 原文地址:https://www.cnblogs.com/wolf-sun/p/3366353.html
Copyright © 2011-2022 走看看