VLQ & Base64 VLQ 编码方式的原理及代码实现
VLQ
VLQ (Variable-length quantity)是一种通用的,使用任意位数的二进制来表示一个任意大的数字的一种编码方式。
编码实现: ** 对数字137进行VLQ**编码,以下为分解步骤:
- 将137转成二进制形式 —— 10001001
 - 七位一组做分组,不足的补前导0 —— 0000001 0001001
 - 最后一组开头补0,其余补1(1表示连续位) —— 10000001 00001001.
 - 最终137的VLQ编码形式为 —— 10000001 00001001
 
// 1. 将137转成二进制形式 —— 10001001
let binary = (137).toString(2);
// 2. 七位一组做分组,不足的补前导0 —— 0000001 0001001
let padded = binary.padStart(Math.ceil(binary.length / 7) * 7, '0');
// 3. 最后一组开头补0,其余补1(1表示连续位) —— 10000001 00001001
let groups = padded.match(/[01]{7}/g);
groups = groups.map((item, index) => (index == groups.length - 1 ? '0' : '1') + item);
let vlqCode = groups.join('');
// 4 最终137的VLQ编码形式为 —— 10000001 00001001
console.log(vlqCode);
Base64 VLQ
- Base64 是一种可以把二进制数据编码成用 ASCII 表示的一种编码规则,
Base64 VLQ需要能够表示负数, 于是规定了需要先把数字变成无符号数, 用最后一位来作为符号标志位。 - 一个Base64字符只能表示6bit(2^6)的数据,而第一位表示连续位,Base64 VLQ需要能够表示负数,因此最后一位用作符合标志位,真正表示数字的只有中间4位,因此一个单元表示的范围是[-15,15],如果超过了就要用连续位了
 在Base64 VLQ中,编码顺序是从低位到高位,而在VLQ中,编码顺序是从高位到低位- 常见用于项目中sourceMap编码
 
编码实现: ** 对数字137进行Base64 VLQ**编码,以下为分解步骤:
- 将137转成二进制形式 10001001,如果是负数需要转成绝对值 Math.abs
 - 137是正数,末位符号位补0, 100010010 正数末位补0,负数末位补1
 - 五位一组做分组,不足的补0, 01000 10010
 - 将数组倒序排序 [ '10010', '01000' ] ,低位在前,高位在后
 - 最后一组开头补0,其余补1(1表示连续位),110010 001000
 - 转成base64,最终137的Base64 VLQ编码形式为 —— yI
 
let base64 = [
    'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',
    'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
    'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
    'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/'
];
function encode(num) {
    // 1. 将137转成二进制形式  10001001,如果是负数需要转成绝对值
    let binary = (Math.abs(num)).toString(2);
    // 2. 137是正数,末位符号位补0, 100010010 正数末位补0,负数末位补1
    binary += num >= 0 ? '0' : '1';
    // 3. 五位一组做分组,不足的补0, 01000 10010
    binary = binary.padStart(Math.ceil(binary.length / 5) * 5, '0');
    // 4. 将数组倒序排序 [ '10010', '01000' ] 低位在前,高位在后
    let parts = binary.match(/\d{5}/g);
    parts.reverse();
    // 5. 最后一组开头补0,其余补1, 110010 001000 6个位bit
    parts = parts.map((item, index) => (index == parts.length - 1 ? '0' : '1') + item);
    // 6. 转成base64
    let chars = [];
    for (let i = 0; i < parts.length; i++) {
        let base64Index = parseInt(parts[i], 2);
        chars.push(base64[base64Index]);
    }
    return chars.join('');
}
let result = encode(137); // yI
在线编码解码的网站:http://murzwin.com/base64vlq.html
VLQ & Base64 VLQ 编码方式的原理及代码实现的更多相关文章
- Oracle EBS在编码方式为AL32UTF8时的注意事项
		
现如今的EBS系统中,为了推进国际化的进程,以及系统向全球化的扩展,在Oracle数据库的编码方式上渐渐从支持中国本土简体中文的ZHS16GBK转向了更趋于国际化的AL32UTF8编码方式.但随之而来 ...
 - Base64图片编码原理,base64图片工具介绍,图片在线转换Base64
		
Base64图片编码原理,base64图片工具介绍,图片在线转换Base64 DataURI 允许在HTML文档中嵌入小文件,可以使用 img 标签或 CSS 嵌入转换后的 Base64 编码,减少 ...
 - base64编码方式
		
一.编码的两大方式: 在python3.x中,字符串编码分为unicode和bytes两大类编码方式. 直接书写s='中国人',这种方式定义的编码方式为unicode,是通用的方式. 另一种是byte ...
 - base16,base32,base64 编码方式的通俗讲解
		
作者:林冠宏 / 指尖下的幽灵 博客:http://www.cnblogs.com/linguanh/ GitHub : https://github.com/af913337456/ 腾讯云专栏: ...
 - Base64的编码转换方式
		
下面,详细介绍Base64的编码转换方式. 所谓Base64,就是说选出64个字符----小写字母a-z.大写字母A-Z.数字0-9.符号"+"."/"(再加上 ...
 - iOS 中使用Base64编码方式编码图片数据
		
最近一个项目要求对图片数据简单加密下,就是那种不能直接看到图片内容就行.于是我使用了base64编码对图片数据进行编码,把图片2进制数据变成了base64的字符串,再把这个字符串保存到server的数 ...
 - 详细介绍Base64的编码转换方式
		
下面,详细介绍Base64的编码转换方式. 所谓Base64,就是说选出64个字符----小写字母a-z.大写字母A-Z.数字0-9.符号"+"."/"(再加上 ...
 - Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一
		
Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下传递较长的标识信息.例如 ...
 - Java Base64加密、解密原理Java代码
		
Java Base64加密.解密原理Java代码 转自:http://blog.csdn.net/songylwq/article/details/7578905 Base64是什么: Base64是 ...
 
随机推荐
- [游记]CSP 2021  J/S
			
这一次,也许是我的OI生涯的转折点了--能过,学习OI的时间就不会减少:但不能过,就会减少学习OI的时间-- 上午(S组) 6:00起床.去吃早餐,结果因为边喝粥边喝牛奶导致肚子疼.(我在这里劝大家, ...
 - SiteSucker Pro for Mac 专业的网站下载工具
			
SiteSucker Mac版是Mac os平台上的一款帮助用户下载数据的mac下载工具,SiteSucker绝对是一扒网站的利器,不仅仅是下载网站的HTML源文件,他连网站整体架构以及下面的所有文本 ...
 - 第八十三篇:Vue购物车(四) 总价计算
			
好家伙, 1.总价计算 来了,又先是一波分析: 我们用一个计算属性amt 我们把item中被勾选的项用一个过滤器过滤器来 然后用一个循环相加,把商品的价格乘以商品的数量, 把这个总值返回出去, 然后组 ...
 - 03_Linux基础-文件类型-主辅提示符-第1提示符-Linux命令-内外部命令-快捷键-改为英文编码-3个时间-stat-其他基础命令
			
03_Linux基础-文件类型-主辅提示符-第1提示符-Linux命令-内外部命令-快捷键-改为英文编码-3个时间-stat-{1..100}-du-cd-cp-file-mv-echo-id-she ...
 - luogu P1488 肥猫的游戏
			
肥猫的游戏 P1488 肥猫的游戏 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题目描述 野猫与胖子,合起来简称肥猫,是一个班的同学,他们也都是数学高手,所以经常在一起讨论数学问 ...
 - Elasticsearch7.6.2 RestHighLevelClient查询用法 must should(and or 关系)
			
1. 引入jar <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId&g ...
 - Taurus.MVC 微服务框架 入门开发教程:项目集成:6、微服务间的调用方式:Rpc.StartTaskAsync。
			
系统目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 开源地址:https://github.com/cyq1162/Taurus.MVC 本系列第一篇:Tauru ...
 - python一招完美搞定Chromedriver的自动更新
			
日常的web自动化过程中,我们常常用python selenium库来操纵Chrome浏览器实现网页的自动化.这其中有个比较头疼的问题:Chrome的更新频率非常频繁,与之对应的Chromedrive ...
 - 从Java 9 到 Java 17 新特性梳理
			
Java 9 新的创建集合的方法 // [1, 2, 3, 4] List<Integer> integers = List.of(1, 2, 3, 4); // {1,2,3} ...
 - ProxySQL结构
			
Qurey Processor 用于匹配查询规则并根据规则决定是否缓存查询或者将查询加入黑名单或者重新路由.重写查询或者镜像查询到其他hostgroup. User Auth 为底层后端数据库认证提供 ...