实现一个CRDT工具库——PSet
PSet
这段代码实现了一个PSet,即Positive Set,是GSet的扩展。PSet是一个集合,支持添加和删除元素,但是不支持重复元素。PSet的实现是通过两个GSet来实现的,一个GSet存储添加的元素,另一个GSet存储删除的元素。value函数返回PSet中的元素,add函数向PSet中添加元素,rem函数从PSet中删除元素,merge函数将两个PSet合并。其中,GSet是一个Grow-only Set,即只支持添加元素,不支持删除和修改元素。
PSet是一个集合,支持添加和删除元素,但是不支持重复元素。下面是各个函数的功能:
- PSet():创建一个空的PSet。
- zero():创建一个空的PSet。
- value(a: PSet):返回PSet中的元素。
- add(a: PSet, value):向PSet中添加元素。
- rem(a: PSet, value):从PSet中删除元素。
- merge(a: PSet, b: PSet):将两个PSet合并。
import GSet
def PSet():
return (GSet.zero(), GSet.zero())
def zero():
return PSet()
def value(a: PSet):
add, rem = a
return add - rem
def add(a: PSet, value):
add, rem = a
return add.add(value)
def rem(a: PSet, value):
add, rem = a
return rem.add(value)
def merge(a: PSet, b: PSet):
add_a, rem_a = a
add_b, rem_b = b
return (GSet.merge(add_a, add_b), GSet.merge(rem_a, rem_b))
import java.util.HashSet;
import java.util.Set;
public class PSet {
public static Set<Integer> value(PSetTuple a) {
Set<Integer> add = GSet.value(a.add);
Set<Integer> rem = GSet.value(a.rem);
Set<Integer> res = new HashSet<>(add);
res.removeAll(rem);
return res;
}
public static PSetTuple add(PSetTuple a, int value) {
Set<Integer> add = GSet.add(a.add, value);
Set<Integer> rem = a.rem;
return new PSetTuple(add, rem);
}
public static PSetTuple rem(PSetTuple a, int value) {
Set<Integer> add = a.add;
Set<Integer> rem = GSet.add(a.rem, value);
return new PSetTuple(add, rem);
}
public static PSetTuple merge(PSetTuple a, PSetTuple b) {
Set<Integer> add_a = a.add;
Set<Integer> rem_a = a.rem;
Set<Integer> add_b = b.add;
Set<Integer> rem_b = b.rem;
Set<Integer> add = GSet.merge(add_a, add_b);
Set<Integer> rem = GSet.merge(rem_a, rem_b);
return new PSetTuple(add, rem);
}
public static PSetTuple zero() {
return new PSetTuple(GSet.zero(), GSet.zero());
}
public static class PSetTuple {
public Set<Integer> add;
public Set<Integer> rem;
public PSetTuple(Set<Integer> add, Set<Integer> rem) {
this.add = add;
this.rem = rem;
}
}
}
class GSet {
public static Set<Integer> value(Set<Integer> a) {
return a;
}
public static Set<Integer> add(Set<Integer> a, int value) {
Set<Integer> res = new HashSet<>(a);
res.add(value);
return res;
}
public static Set<Integer> merge(Set<Integer> a, Set<Integer> b) {
Set<Integer> res = new HashSet<>(a);
res.addAll(b);
return res;
}
public static Set<Integer> zero() {
return new HashSet<>();
}
}
实现一个CRDT工具库——PSet的更多相关文章
- 如何手写一个js工具库?同时发布到npm上
自从工作以来,写项目的时候经常需要手写一些方法和引入一些js库 JS基础又十分重要,于是就萌生出自己创建一个JS工具库并发布到npm上的想法 于是就创建了一个名为learnjts的项目,在空余时间也写 ...
- [js高手之路] 跟GhostWu一起封装一个字符串工具库-架构篇(1)
所谓字符串工具库就是利用javascript面向对象的知识封装一个常用的字符串处理方法库,首先给这个库起个名字,好吧就叫ghostwu.js. 看下ghostwu.js的整体架构: ; (functi ...
- [js高手之路] 跟GhostWu一起封装一个字符串工具库-扩展trim,trimLeft,trimRight方法(2)
我们接着上一篇的继续,在上一篇我们完成了工具库的架构,本文扩展字符串去空格的方法, 一共有3个 1,trimLeft: 去除字符串左边的空格 2,trimRight: 去除字符串右边的空格 3,tri ...
- [js高手之路] 跟GhostWu一起封装一个字符串工具库-扩展字符串位置方法(4)
本文,我们接着之前的框架继续扩展,这次扩展了一共有5个与字符串位置相关的方法 between( left, right ) 返回两个字符串之间的内容, 如果第二个参数没有传递,返回的是找到的第一个参数 ...
- [js高手之路] 跟GhostWu一起封装一个字符串工具库-扩展camelize与dasherize方法(3)
在此之前,我们已经完成了4个方法: trimLeft, trimRight, trim, capitalize 本文,我们扩展驼峰式与下划线转化这两个对称的方法 camelize: 把空格,下划线,中 ...
- 一个PHP高性能、多并发、restful的工具库(基于multi_curl)
This is high performance curl wrapper written in pure PHP. It's compatible with PHP 5.4+ and HHVM. N ...
- Underscore.js工具库
Underscore 是一个 JavaScript 工具库,它提供了一整套函数式编程的实用功能,但是没有扩展任何 JavaScript 内置对象. 他解决了这个问题:“如果我面对一个空白的 HTML ...
- JavaScript工具库
jPublic 交流QQ群:1017567122 前言 在我们开发项目的时候,无论项目规模大小,在所难免会写一些工具型函数来解决一些问题,随着项目开发和维护的时间越来越长,这些工具型函数会越来越多,同 ...
- 手把手教你使用Rollup打包📦并发布自己的工具库🔧
DevUI是一支兼具设计视角和工程视角的团队,服务于华为云DevCloud平台和华为内部数个中后台系统,服务于设计师和前端工程师. 官方网站:devui.design Ng组件库:ng-devui(欢 ...
- 自己的一个LESS工具函数库
自己大概在一年前开始使用LESS编写样式,现在感觉不用LESS都不会写样式了.现在写静态页面完全离不开LESS与Zen Coding,我可以不用什么IDE,但这两个工具却必须要,当然也强烈推荐看到这篇 ...
随机推荐
- Luogu P2375 [NOI2014 D2]动物园 kmp
P2375 动物园 题目描述 近日,园长发现动物园中好吃懒做的动物越来越多了.例如企鹅,只会卖萌向游客要吃的.为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决定开设算法班,让动物 ...
- Kafka相关问题
Kafka有哪几个部分组成 生产者.消费者.topic.group.partition kafka的group1)定义:即消费者组是 Kafka 提供的可扩展且具有容错性的消费者机制.在Kafka中, ...
- C#——》Web Api 操作MySQL数据库公共类:MySql.Data
使用MySql.Data 连接mysql 数据库,需先引用MySql.Data ,用过MySql.Data.dll操作Mysql数据库. 1,在工具-Nuget包管理器-管理解决方案的Nuget程序包 ...
- svg矢量二维码加盖在PDF文件中
正常行驶的bitmap类型的二维码格式,加载到PDF中,将会导致二维码失真,无法扫描. 矢量图可根据尺寸大小进行调节,不会出现失真模糊情况 所用依赖 <PackageReference Incl ...
- 修改tomcat启动时,修改默认访问的页面
在
- Docker系列--Docker设置系统资源限制及验证
1.限制容器的资源 默认情况下,容器没有资源限制,可以使用主机内核调度程序允许的尽可能多的给定资源.Docker提供了控制容器可以使用多少内存或CPU的方法,设置docker run命令的运行时配置标 ...
- js实现指定dom节点滚动到可视窗口
const rollDom = document.getElementById('domId') // 获取想要滚动的dom节点 rollDom.scrollIntoView({ block: 'ce ...
- (五).JavaScript的数组
1. 数组 1.1 数组的基础 数组:同种或不同数据类型数据的有序集合 功能:同时存储多个数据 数据:常量 变量 表达式 数组 函数 对象 定义方式:字面量定义或者构造函数定义 字面量定义数组(本质上 ...
- How to Change Reset Retrieve the WebLogic Server Administrator Password on WLS 10.3.6 or earlier
To change the Administrator password on WLS 10.3.6 or earlier, perform the following steps depending ...
- vs调试导入功能时莫名自动结束调试
新装了vs2022,默认下图所示的地方打勾,导致调试文件导入功能时触发了自动结束调试,真是坑爹~~