微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JSON 的大小

如何解决JSON 的大小

编辑:感谢@zenoh 提供的计数方法。 gzipping 产生双字节计数的字符,所以这很有趣。我仍然想知道人们如何减少他们通过 WebRTC 发送的数据的大小?

我想通过 WebRTC 发送一些 JSON。数据量很大,所以我需要尽量减少。

我需要计算正在发送的数据的实际大小。 我需要一些提示和技巧来将这种情况保持在最低限度。

比如说,我有一个对象:

{
    myString: "Yabba Dabba Doo",myInt: 42,myFloat: 1.6666666666666666666666666666666666666666666....,// Recurring
}

我一直(误解)认为 JSON 将所有内容都放入字符串形式中。因此,例如,浮点数将被写为“1.6666666666666”,之后加载 6,直到它感到无聊为止。这显然是大量的字节。那不好。

那么有人能告诉我如何计算我发送的 JSON 的确切字节大小吗?

我应该让我的钥匙尽可能小吗?因此,与其让它可读,即 'myfloat' 作为一个键,而是让它变小,即 'f' 作为一个键?

我有一个小 zip 例程,我为整数编码。我认为在小数点后第 9 位之后,浮点数变得几乎与它们所需要的无关,所以我想将浮点数乘以 1000000 去除剩余的小数位,然后在 int 上使用我的小 zip 例程。然后在通过 WebRTC 发送时执行相反的操作。

我的另一个想法是对对象进行 JSON 化,然后对结果字符串进行 gzip 压缩并发送。

非常感谢您对这个主题的任何想法。

解决方法

JSON.stringify(obj) 应该以 UTF-8 格式输出字符串,然后您可以使用 UFT-8 字符串长度和字节计数器计算大小,如下所示:https://mothereff.in/byte-counter

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。