nodejs的Buffer如何能像c语言结构体那样方便的组织数据?


nodejs的Buffer如何能像c语言结构体那样方便的组织数据?

数据字段多的时候不方便啊,有什么办法能方便的存取各个字段的数据呢?

node.js web node JavaScript

缺舟—帆渡 9 years, 7 months ago

你先要区分缓冲和数组的概念, 缓冲是一大片常驻内存, 用数组来表示以提供方便的操作. 使用缓冲的时候, 你总应该指定一个 2 的幂次方的长度, 1024, 4096 是常用的长度.

每次填充缓冲一片区域, 并要记住此时的偏移, 也就是空闲缓冲的开始位置, 用于下一次的内容填充.

exmaple:


 const BUFF_SIZE = 1024            // 设置缓冲区的大小, 应该是一个不可修改的常量值
var buff = new Buffer(BUFF_SIZE)  // 新建一个内存缓冲
var offset = 0                    // 内存缓冲的起始偏移为 0
var string = "abcdefg"            // 新建一个测试字符串
var bytes = Buffer.byteLength(string1) // 测试字符串的二进制长度

var size = BUFF_SIZE              // 缓冲区当前剩余的可以填充的二进制字符数


// 把字符串填充到缓冲区
for (;;) {
    // 将测试字符串填入缓冲区, 返回实际填充的二进制字符数
    var writeSize = buff.write(string, offset, size)

    // 剩余需要填充的二进制字符数
    size = size - writeSize

    // 当前的缓冲偏移
    offset = offset + writeSize

    // 字符串没有填充完, 仍有部分未填充
    if (writeSize < bytes) {
        // 缓冲区已经填满了
        if (offset === BUFF_SIZE) {
            // 把缓冲区的数据发送出去, 重新填充
            // 或者也可以做其他操作, 重新填充
            sendfunc(buff, writeSize);
            offset = 0
        } else {
        // 缓冲区没有填满, 这很可能是操作系统错误, 一般不应该出现
            throw new Error(// lalala);
        }
    } else {
    // 字符串填充完
        sendfunc(buff, writeSize)
        break;        
    }
}

量产型冬瓜 answered 9 years, 7 months ago

获取数据,转成字符串对象,
JSON.parse方法转成JSON对象
接下来就是按属性名取数据啦~~

海协会副会长 answered 9 years, 7 months ago

Your Answer