nodejs 的 socket 是怎么回事

2020-12-04 12:48:30 +08:00
 zxCoder
server.on('connection', (client) => {
        client.on('data', (msg)=> {
        });
        client.on('error',  (e)=> {
            client.end();
        });
        client.on( 'close', ()=> {
            console.log(`客户端下线了`);
        });
    });

怎么像别的语言一样,不是要定义一个缓冲区吗,然后缓冲区满再读取数据解析,这里直接在 data 事件中接收数据是什么意思,客户端如果 for 循环发送,服务端要怎么接收呢

2515 次点击
所在节点    Node.js
8 条回复
echowuhao
2020-12-04 14:33:52 +08:00
node js event loop 学习一下。
ruoxie
2020-12-04 15:10:50 +08:00
borisz
2020-12-04 15:15:00 +08:00
服务器端的确是会有时候接收多,有时候少的, 需要自己缓存切分
cheneydog
2020-12-04 15:21:54 +08:00
不都是这样么?哪个语言难道会帮你自动分包。
no1xsyzy
2020-12-04 15:23:41 +08:00
运行时帮你建议缓冲区、读取了不少信息,然后把缓冲区的内容建立成 msg 传给你的函数,然后你还需要再建一个缓冲区去保存这些 msg 并且解析 —— 当然大部分情况下拼接字符串了事。

可能你没明白 on 注册回调的意思,你的这个 on 进去的 (msg) => {} 是一个被保存并可反复调用的回调函数。如果客户端发送了不少,你的回调函数会被调用多次。
Mutoo
2020-12-04 19:21:18 +08:00
粘包警察呢 :doge:
viakiba
2020-12-04 19:23:35 +08:00
length key payload
togou
2021-02-01 12:27:37 +08:00
这根 epoll 有可读消息 然后读好了的数据返回在 msg 里面有什么区别么 你存起来然后解析一下就行

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/732072

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX