当前位置: 首页 > news >正文

变长字节的数字表示法vb224

开始

数字有大有小,用多少字节表示呢?
本文描述的方案,采用变化的长度。vb是varying bytes的意思,224是表示它特征的一个数。

第一版:

每个字节8比特,最高的1比特用来表示“是否连续”,0表示终止,1表示继续,如:
单字节模式:0×××××××
双字节模式:1××××××× 0×××××××
三字节模式:1××××××× 1××××××× 0×××××××
一直延续下去,理论上说可以表示无穷大。
这一版叫做vb128。

第二版:

为表示0到255做了优化。
单字节模式:0至223
双字节模式:224至255,0×××××××
三字节模式:224至255,1××××××× 0×××××××
也能表示无穷大。
首字节中,224至255是32个数,即5比特。
后边的字节,每个字节表示7比特。

比较:

题目:表示0到255,以及保留继续变大的可能。
解一:表示0到255需要256个字节,要想保留继续变大的可能,需要用双字节、四字节、八字节等。占用空间较大。
解二:采用vb128。前128个数字用1字节,后128个数字用2字节,总共128+2×128=384字节。
解三:采用vb224。前224个数字用1字节,后32个数字用2字节,总共224+2×32=288字节。
比较结果:
解一很占空间,且不能表示无穷大,退出比较。
解三比解二省下384-288=96字节。

总结:

当你需要表示一个数字,却又不能确定数字所占字节数的时候,可以考虑vb224编码。
截止2025年6月,该方案尚未实现,你可以自己动手实现,并应用于项目之中。

http://www.lryc.cn/news/576490.html

相关文章:

  • 互联网大厂Java求职面试实录
  • c# sugersql 获取子表数据排序
  • Java 识别和处理 HTML 标签内容
  • Spring MVC参数解析:深入剖析415异常与@RequestBody处理机制问题场景
  • Flutter基础(FFI)
  • pytorch中的几个概念
  • NLP中的同义词替换及我踩的坑
  • 《Python 实现 B 站视频信息爬虫:从批量获取到 CSV 保存》
  • 数字孪生技术引领UI前端设计新革命:实时交互与模拟预测
  • LINUX628 NFS 多web;主从dns;ntp;samba
  • 鸿蒙5:ArkTS基本介绍
  • VR训练美国服务器:高性能解决方案与优化指南
  • 【LeetCode 热题 100】438. 找到字符串中所有字母异位词——(解法三)不定长滑动窗口+数组
  • 构建 AI 系统的 4 大 Agentic AI 设计模式
  • 网关ARP防护的措施
  • qt和qtcreator版本关系
  • n8n-nodes-puppeteer截图中文变方块乱码解决方法
  • 在单片机中如何实现一个shell控制台
  • Launcher3中的CellLayout 和ShortcutAndWidgetContainer 的联系和各自职责
  • 前端react面试题之实现网页多选搜索框
  • 【学习笔记】深入理解Java虚拟机学习笔记——第12章 Java内存模型与线程
  • python中学物理实验模拟:瞬间推力与摩擦力作用下的物体运动
  • 力扣网C语言编程题:在数组中查找目标值位置之二分查找法
  • 解决cursor无法下载插件等网络问题
  • 深入详解:随机森林算法——概念、原理、实现与应用场景
  • screen用法
  • Gradio全解13——MCP详解(4)——TypeScript包命令:npm与npx
  • 服务器的维护技术都有哪些?
  • Flutter基础(Isolate)
  • 【论文阅读笔记】知网SCI——基于主成分分析的空间外差干涉数据校正研究