gpt4 book ai didi

node.js - 缓冲器、 socket 。 Node .js

转载 作者:可可西里 更新时间:2023-11-01 02:33:33 26 4
gpt4 key购买 nike

我正在尝试利用 Node.js 中的 TCP 套接字与 Lua 程序进行通信。我试图解决两个问题。首先是缓冲区。

缓冲区 据我了解,当数据从套接字提供给您的代码时,它将是目前已收到的任何数据(流而不是数据包)。因此,当您读取接收到的数据时,它可能与发送的数据不同。

即收到的数据{ 学校:[“长

与发送的数据{ 学校 : [{"Longwood", "Hillbrow"}] }

解决此问题的方法是将您的数据放入“缓冲区”,并通过您使用的任何方法将其拆分以显示该信息的结尾。通常显示为换行。

我的问题:

  1. 您最终能否在缓冲区中得到更多 2 个或更多完整的数据段,您将如何处理? For 循环?
  2. 离开套接字的数据似乎也存在同样的问题。然而,我注意到在其他代码示例中,人们使用 Node.js Buffer在写入套接字之前。为什么这不用于传入数据?
  3. 如果写入的数据多于可以处理的数据量,Node 会为您处理还是您需要想出一个方法。

最后我好像误会了数据方面。是否所有发送和接收的数据都需要转换为二进制并返回?我只想来回发送 JSON 数据。我想这就是我的困惑。例如:

var myQuestion = "Is this acceptable and will I encounter any issues?
socket.write(myQuestion);

非常感谢您的宝贵时间。

最佳答案

  1. 是的,您肯定会得到几部分数据。这完全取决于您在两端编写的代码。
  2. 我不太理解您所说的“在写入前使用缓冲区”的意思。缓冲区只是纯二进制数据,它们用于传入和传出数据。 Node 通常也接受要发送的字符串,如果没有给出编码,则假定它们是 UTF8。如果您调用setEncoding,您还可以在接收时获取字符串。
  3. 操作系统在 TCP 套接字上有用于传入数据的缓冲区,当缓冲区已满( Node 清空速度太慢)时,它将停止接受数据包,直到有空间为止。

首先,Buffer 是二进制的。缓冲区只是一个字节数组,仅此而已。可以从字符串创建缓冲区,在某些情况下 Node 会自动执行此操作。对于您的情况,我建议您调用 socket.setEncoding('utf8')。这会自动将传入数据转换为字符串以简化您的解析。

至于处理和拆分数据,由您决定。 TCP 仅提供按发送顺序到达的字节流。正如您所说,您可以收集字节,当收到换行符时,您可以获取之前的所有内容并将其解析为 JSON。这应该可以正常工作。您可以使用任何不会在 JSON 中弹出的字符。只要执行 JSON 序列化的程序不添加换行符,就可以了。当发出“数据”时,您可以检查字符串中是否有换行符,如果没有,则将其添加到任何先前收到的数据中,如果找到,则将其拆分,添加现有数据。

关于node.js - 缓冲器、 socket 。 Node .js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14093990/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com