nodejs的Buffer如何能像c语言结构体那样方便的组织数据?
nodejs的Buffer如何能像c语言结构体那样方便的组织数据?
数据字段多的时候不方便啊,有什么办法能方便的存取各个字段的数据呢?
缺舟—帆渡
9 years, 7 months ago
Answers
你先要区分缓冲和数组的概念, 缓冲是一大片常驻内存, 用数组来表示以提供方便的操作. 使用缓冲的时候, 你总应该指定一个 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