send返回0解析

今天为了检测一下send的过程和closesocket如果同时出现是否会冲突,所以故意把send的缓冲区设置的很大(我设置的为2000000,还没有溢出int),但是发现不能正常收发数据,各自检测server和client,发现server可以接收到不全的数据,但是client的send函数却返回了0,看了一下MSDN,声明说:如果传给send的第三个参数len为0,则send会返回一个有效值0,其他的也没多说了,网上查看了一下send返回0的情况,很多人说如果socket突然断开会出现返回0的情况,我没有试,但因此特意检查了一下server端看看是否socket已经断开,由于server用的是IOCP所以当有socket断开时会受到一个特定的完成消息,但是发现socket连接正常。

根据上面的结果在综合一下网友的说法只有一个解释比较恰当:每次可以成功发送的数据包的最大值跟操作系统的缓冲区上限有关,关于操作系统的socket缓冲区不了解,问题已经定位好了,可以自己去查缓冲区的问题了。

Ajax(Asynchronous JavaScript and XML)是一种前端技术,它允许网页在无需刷新整个页面的情况下,通过JavaScript向服务器异步发送请求并接收响应。当服务器返回JSON数据时,Ajax可以将这些JSON数据解析成JavaScript对象,以便于客户端直接操作。 解析JSON的过程通常是这样的: 1. **创建XMLHttpRequest对象**:首先,你需要创建一个XMLHttpRequest对象,这是在浏览器中处理AJAX请求的主要工具。 2. **发起请求**:然后,使用`open()`方法指定请求的类型(如GET或POST)、URL以及是否异步(通常设为true),接着调用`send()`发送请求。 3. **设置回调函数**:在发送请求之前,需要设置一个`onreadystatechange`事件监听器,该事件会在服务器响应状态改变时触发。在其中的`responseText`属性包含了服务器返回的数据。 4. **解析JSON**:当`readyState`等于4(表示请求已完成且响应可用)并且`status`为200(成功响应)时,你可以用`JSON.parse()`方法将`responseText`转换为JavaScript对象。这是因为JSON格式就是键值对的字符串形式,而`parse()`函数能将其解析成对象或数组。 ```javascript function handleResponse() { var xhr = new XMLHttpRequest(); xhr.open('GET', 'your-api-url', true); xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { var data = JSON.parse(xhr.responseText); // 现在data是一个JavaScript对象,你可以直接操作其内容 console.log(data); } }; xhr.send(); } ```
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值