精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Figma 在協(xié)同編輯中使用的順序一致性算法: Fractional indexing

開發(fā) 前端
在多人同時操作同層級的多個圖形的順序時,需要保證用戶的意圖能保留,不會被其他用戶的操作覆蓋丟棄,且所有用戶最終的順序是一致的。為解決這個問題,F(xiàn)igma 使用了一種名為 Fractional Indexing 的簡單算法。

大家好,我是前端西瓜哥。

Figma 支持多人協(xié)同,那它是如何做到順序一致性的呢?

在多人同時操作同層級的多個圖形的順序時,需要保證用戶的意圖能保留,不會被其他用戶的操作覆蓋丟棄,且所有用戶最終的順序是一致的。

為解決這個問題,F(xiàn)igma 使用了一種名為 Fractional Indexing 的簡單算法。

Fractional indexing 的原理

Fractional Indexing,直譯的話,是小數(shù)索引。

該算法的原理并不復雜。

圖形對象會使用 index 屬性表示順序,記錄自己在同級圖形中的位置。

index 的值為 0 到 1 之間的 64 位浮點數(shù),不包括 0 和 1。

出于減少體積的考慮,figma 會丟掉前面的 0.,并把剩余的小數(shù)部分數(shù)字轉換成 ASCII 中的可打印字符(共 95個,表達為 95 進制數(shù))。

不能為 0 和 1, 是因為如果給某個圖形設置了 0 或 1,這個圖形的左側或右側添加的圖形的 index 就會超出了 0 到 1 的范圍。

當往兩個圖形之間插入新的節(jié)點時,我們會取這兩個圖形 index 的中點。

比如我們要在索引值分別為 0.3 和 0.4 的圖形插入圖形,這個圖形的索引值會取中間值 0.35。

移動圖形同理。

但在實現(xiàn)這個算法的時候,你需要注意兩個問題。

精度問題

首先是精度問題。

說到取中間值,容易聯(lián)想到二分查找。

二分查找效率很高,時間復雜度是 O(logn),是因為不管數(shù)據(jù)規(guī)模多大,它 每一次查找都會直接將數(shù)據(jù)量減半,給你打骨折。

index 使用的雙浮點數(shù),能表示的二進制小數(shù)部分位數(shù)為 52 位,每次二分就是進行 位右移操作,會用掉一個精度。

假設我們不斷地往 0.3 到 0.4 的區(qū)間靠近 0.3 的那邊插入新圖形,我們會看到 index 非??斓亟咏?0.3,最后因為精度用完,再也無法二分。

const getMid = (a, b) => (a + b) / 2;

const left = 0.3
let right = 0.4

for (let i = 0; i <= 50; i++) {
  right = getMid(left, right);
  console.log(right);
}

上面的代碼在 50 次左右就將精度耗盡了。

這種是很極端的場景,一般正常的用戶操作不會出現(xiàn),F(xiàn)igma 并不打算處理這種情況的。

字符串表示法

當然精度問題是有辦法解決的,那就是用無限精度的數(shù)據(jù)類型:字符串。

該算法使用 "0" 到 "9" 的字符串表示索引,并通過字典序作為排序依據(jù)。

空字符表示最小值,null 表示最大值。

  • 計算中點會做舍入,盡量不占用更多的位數(shù)。

比如 "3" 和 "6" 的中點是 "5",而不是 "45"。但 "3" 和 “4” 因為太靠近,只能得到 "35"。

  • 如果是空字符,會等價于 "0",如果是 null,等價于 "10"(會比 "9" 大)。
  • 如果有前綴相同部分,取后面不同部分計算中點,再拼回去。

假如兩個相鄰圖形的 index 分別是  "123" 和 "1234"。

我們會取后面不同的部分 ""(表示 0) 和 "4",取中點 "2",然后添加回相同前綴 "123",得到我們需要的新索引 "1232"。

另外,對比 "123" 和 "123004" 時,"123" 要補全后綴零為 "12300"。

我們來看看效果。

使用這種方式,對 "3" 和 "4" 進行 1000 次的二分,因為突破了精度限制,我們會得到非常非常長的字符串。

很長,通常通過編碼處理精簡,這里就不過多介紹了。

沖突問題

最后是沖突問題。

如果耿直地計算中點,那當多個客戶的都同時往兩個節(jié)點之間插入圖形,同步后就會出現(xiàn)多個圖形的 index 相同的場景。

對此,我們會 在中間值的基礎上,加上一個隨機的偏移值,這樣多個客戶端之間的沖突概率就非常的低。

但非常極端的情況下,沖突還是可能發(fā)生的,這種情況下就需要作為 中心權威的服務端去做修正 了,進行微小偏移,且和其他索引值不沖突。

結尾

Fractional Indexing 的優(yōu)點是實現(xiàn)簡單,不需要 CRDT 那種墓碑機制,要保留大量無用的元數(shù)據(jù)。

缺點是極端場景 index 的長度很長,有精度不夠導致二分失敗的邊緣場景(可用字符串解決),以及對圖形編輯器并無大礙的交錯問題(兩用戶分別輸入 "123" 和 "ABC",同步后可能會得到 "1A2B3C",而不是 "123ABC")。

責任編輯:姜華 來源: 前端西瓜哥
相關推薦

2024-06-17 09:01:14

2021-02-05 08:00:48

哈希算法?機器

2025-09-08 07:25:16

2022-03-22 09:54:22

Hash算法

2017-07-25 14:38:56

數(shù)據(jù)庫一致性非鎖定讀一致性鎖定讀

2019-10-11 23:27:19

分布式一致性算法開發(fā)

2021-08-13 07:56:13

Raft算法日志

2022-11-10 07:49:09

hash算法代碼

2020-03-16 11:55:28

PaxosRaft協(xié)議

2020-07-20 08:30:37

算法哈希分布式系統(tǒng)

2021-07-27 08:57:10

算法一致性哈希哈希算法

2016-12-19 18:41:09

哈希算法Java數(shù)據(jù)

2022-12-14 08:23:30

2021-09-18 08:54:19

zookeeper一致性算法CAP

2021-02-02 12:40:50

哈希算法數(shù)據(jù)

2021-02-04 06:30:26

Python編程語言

2018-03-13 08:20:48

區(qū)塊鏈數(shù)據(jù)安全

2023-12-12 08:00:50

節(jié)點哈希算法

2018-07-05 09:41:08

一致性哈希算法

2019-11-01 09:13:37

算法哈希緩存
點贊
收藏

51CTO技術棧公眾號

亚洲色在线视频| 亚洲综合免费观看高清完整版 | 久久er99精品| 欧美风情在线观看| 精品福利在线导航| 一区二区三区av| 国产91久久久| 日韩经典一区二区| 欧美激情在线一区| 美国一级黄色录像| 久久久亚洲欧洲日产| 欧美视频中文字幕| 欧美深夜福利视频| 久久久久久国产精品免费无遮挡| 国产成人福利片| 国产精品福利无圣光在线一区| 中文字幕av免费在线观看| 欧美猛男同性videos| 欧美一区二区三区视频在线观看| 狠狠爱免费视频| 中文在线手机av| 中文字幕的久久| 久久精品午夜一区二区福利| aaa国产视频| 蜜桃久久精品一区二区| 欧美亚洲国产另类| 久久一区二区三| 888久久久| 一区二区三区久久精品| 特大黑人巨人吊xxxx| 久久的色偷偷| 欧美精品一级二级| 天天操天天爱天天爽| 秋霞伦理一区| 亚洲福利一区二区| 狠狠精品干练久久久无码中文字幕| av在线天堂| 久久精品欧美一区二区三区麻豆| 国产乱码一区| 好吊色一区二区三区| 国产中文字幕精品| 成人妇女淫片aaaa视频| 中文在线观看免费高清| 水蜜桃久久夜色精品一区的特点| 精品亚洲欧美一区| 午夜精品一区二区三区在线视频| 一级黄色录像视频| 香蕉久久网站| 久久亚洲春色中文字幕| 午夜成人亚洲理伦片在线观看| 国产欧美日韩在线一区二区| 亚洲女成人图区| 精品人妻少妇嫩草av无码| 日韩av网站在线免费观看| 亚洲白拍色综合图区| 激情小说欧美色图| 777久久精品| 精品久久国产97色综合| 欧美xxxxx少妇| 久久丝袜视频| 日韩精品在线视频观看| 熟女少妇一区二区三区| 狠狠色丁香婷婷综合影院| 国产一区二区免费| 2017亚洲天堂| 在线精品小视频| 欧美极品少妇全裸体| 日韩欧美视频在线免费观看| 国产美女诱惑一区二区| 欧美综合在线观看| 免费看av在线| 国产麻豆精品久久一二三| 99国产视频| 午夜成人免费影院| 国产日本欧洲亚洲| 强开小嫩苞一区二区三区网站| 怡红院在线观看| 亚洲电影激情视频网站| 毛片av免费在线观看| jizz久久久久久| 欧美一级高清片| 欧洲一级黄色片| 精品久久久久久久| 久久99热精品这里久久精品| 国产精品第9页| 男男视频亚洲欧美| 欧美一区二区三区在线观看| 国产精品一区二区不卡视频| 天堂网在线资源| 国产亚洲一区二区三区四区| 一区二区欧美日韩| 女人天堂av在线播放| 欧美视频中文字幕在线| 日本免费色视频| 巨人精品**| 色老头一区二区三区在线观看| 欧美成人黄色网| 香蕉久久国产| 99久热re在线精品996热视频| 日本v片在线免费观看| 国产精品成人午夜| 黄色动漫在线免费看| 国产精品日韩精品在线播放| 亚洲精品按摩视频| 免费在线观看黄色小视频| 一区二区高清| 91亚洲国产成人精品性色| 水中色av综合| 一区二区久久久| www.色欧美| 九九热精品视频在线观看| 欧美黑人巨大精品一区二区| 成年人视频免费| av在线不卡电影| 黄色一级视频播放| 福利精品一区| 亚洲欧洲国产一区| 久久久久久久久久久网| 麻豆国产欧美一区二区三区| 精品九九九九| 后进极品白嫩翘臀在线播放| 在线不卡免费欧美| 黄色av免费播放| 久久国产成人| 激情欧美一区二区三区中文字幕| 成人影欧美片| 欧美日韩一级片在线观看| 国产精品无码一区二区三区| 精品1区2区3区4区| 91色p视频在线| 日本中文字幕在线播放| 综合毛片免费视频| 精品视频在线免费| 国产亚洲精品熟女国产成人| 亚洲电影在线| 亚洲在线一区二区| 成人高清免费在线| 911精品国产一区二区在线| 永久免费av无码网站性色av| 久久久青草婷婷精品综合日韩 | 高潮按摩久久久久久av免费| 丝袜美腿亚洲一区二区| 亚洲国产精品无码久久久| 91啪亚洲精品| 高清在线观看免费| 欧美一区自拍| 欧美一级大片视频| 蜜芽tv福利在线视频| 狠狠躁夜夜躁久久躁别揉| 亚洲综合自拍网| 亚洲精品1234| 成人精品水蜜桃| 中文在线字幕免费观看| 日韩精品专区在线| 精品视频在线观看免费| 成人亚洲一区二区一| 久草免费福利在线| 美女主播精品视频一二三四| 91国产美女视频| 你懂的在线视频| 在线亚洲一区二区| 免费看一级黄色| 国产福利一区二区| 日本午夜激情视频| 一区二区三区四区在线看| 国产精品96久久久久久| 日本中文字幕在线观看| 日韩欧美国产三级电影视频| 国产乡下妇女做爰| 久久日韩粉嫩一区二区三区| 国产精品涩涩涩视频网站| 成人在线国产| 99热在线国产| a一区二区三区| 色偷偷88888欧美精品久久久| 国产免费一区二区三区最新不卡| 亚洲永久精品国产| 久久精品国产一区二区电影| 亚洲成人第一网站| 国产精品狼人久久影院观看方式| 97超碰免费在线观看| 日韩一级网站| 亚洲巨乳在线观看| 中文字幕一区日韩精品| 国产成人精品久久二区二区| 美女羞羞视频在线观看| 亚洲国产精品系列| 亚洲无码精品在线观看| 亚洲午夜精品17c| 精品人妻无码一区| 国产福利一区二区三区视频| www.国产区| 欧美日韩 国产精品| 日本精品一区二区三区高清 久久| 国产精品一级在线观看| 日本乱人伦a精品| 国产色在线观看| 精品亚洲男同gayvideo网站| 国产情侣av在线| 色综合天天在线| 欧美高清视频一区二区三区| 久久亚洲影视婷婷| 精产国品一区二区三区| 久久成人免费| 男人插女人视频在线观看| 日韩av密桃| 久久久水蜜桃| 中文字幕久久精品一区二区| 国产精品电影久久久久电影网| a级片免费在线观看| 爽爽爽爽爽爽爽成人免费观看| 色猫av在线| 欧美mv和日韩mv的网站| 一二三区中文字幕| 欧美视频在线观看 亚洲欧| 国产suv一区二区三区| 欧美韩国日本综合| 国产精品无码久久久久久| 国产精品一卡二卡| 一区二区三区欧美精品| 久久久久国产精品午夜一区| 精品无码一区二区三区在线| 欧美成人国产| 日日噜噜噜夜夜爽爽| 成人精品视频| 日产国产精品精品a∨| 久久97精品| 亚洲va男人天堂| 免费视频观看成人| 国产精品va在线| 周于希免费高清在线观看| 欧美激情综合色| 人人澡人人添人人爽一区二区| xvideos成人免费中文版| yes4444视频在线观看| 夜夜嗨av一区二区三区四区| 蜜桃视频在线播放| 日韩精品极品在线观看| 日本又骚又刺激的视频在线观看| 精品国精品自拍自在线| 亚洲av无码乱码国产精品| 日韩三级中文字幕| 精品国产999久久久免费| 91精品欧美一区二区三区综合在| 亚洲一区二区三区高清视频| 欧美日韩亚洲综合| 国产一区二区三区中文字幕| 欧美日本一道本| 91精品视频免费在线观看| 91精品国产综合久久香蕉的特点| 国产又粗又大又爽视频| 91精品国产综合久久久久久漫画 | www污在线观看| 亚洲国产专区校园欧美| 国产成人无码精品久久久性色| 亚洲精品日本| 男女av免费观看| 日韩在线一区二区| 男人添女人下面免费视频| 美洲天堂一区二卡三卡四卡视频 | 高清国产一区二区三区四区五区| 国产在线视频欧美| 精品午夜av| 狠狠爱一区二区三区| 蜜臀91精品国产高清在线观看| 日本不卡一区| 国产精品久久占久久| 亚洲精品少妇一区二区| 一区二区三区国产盗摄| 91看片就是不一样| 久久66热re国产| 亚洲熟女一区二区三区| a在线欧美一区| 免费一级做a爰片久久毛片潮| 国产精品欧美一级免费| 欧美黑人一级片| 日韩欧美在线免费| 91中文字幕在线视频| 精品国产一区二区在线观看| 日韩av高清在线| www.欧美三级电影.com| 金瓶狂野欧美性猛交xxxx | 日韩免费一级视频| 日本sm残虐另类| 91精品人妻一区二区三区四区| 久久综合色之久久综合| 免费黄色国产视频| 亚洲成人综合在线| 涩涩视频在线观看| 日韩精品一区二| 91视频在线观看| 国模吧一区二区| 免费成人高清在线视频| 九九九九九九精品| 91精品精品| 中文字幕无码不卡免费视频| 国产一区二区三区精品视频| 日韩网站在线播放| 一区二区日韩电影| 真实新婚偷拍xxxxx| 亚洲精品在线电影| 欧美一区二区三区| 欧美一级淫片videoshd| 免费一区二区三区在线视频| 日韩av一区二区三区在线观看 | 中文字幕一区二区三区不卡| 三级黄色在线视频| 日韩亚洲欧美中文三级| 国产精品二线| 97av在线视频免费播放| 欧美a在线观看| 亚洲欧美综合一区| 久久久久国内| 黄色短视频在线观看| 亚洲精品免费在线播放| 中国女人真人一级毛片| 日韩成人性视频| www.综合网.com| 69堂成人精品视频免费| 成人3d精品动漫精品一二三| 乱妇乱女熟妇熟女网站| 国产成人日日夜夜| 日韩a级片在线观看| 精品视频一区二区不卡| 国产中文字幕在线视频| 3344国产精品免费看| 91蜜桃臀久久一区二区| 992tv成人免费观看| 久久精品99国产精品日本| 欧美做受高潮6| 色哟哟国产精品| 牛牛热在线视频| 国产精欧美一区二区三区| 九九视频精品全部免费播放| 女性女同性aⅴ免费观女性恋| 国产精品1区二区.| 欧洲猛交xxxx乱大交3| 欧美一区在线视频| 欧美性videos| 成人黄色激情网| 久久亚洲影视| 奇米影视四色在线| 国产精品人人做人人爽人人添 | 日韩三级视频在线观看| 黄色网在线看| 亚洲精品日韩激情在线电影| 国产精品成人a在线观看| 欧美成人乱码一二三四区免费| 国产精品视频yy9299一区| 亚洲图片在线播放| 久久久国产一区| 精品一区二区三区四区五区 | 欧洲在线视频| 不卡一区二区三区视频| 欧美网站在线| 无码精品一区二区三区在线播放| 亚洲成人777| 美国成人毛片| 国产精品免费一区豆花| 99精品视频在线观看免费播放| 天堂av在线8| 有码一区二区三区| 色婷婷av一区二区三区之红樱桃 | 一区二区视频免费| www.亚洲男人天堂| 亚洲大奶少妇| 大肉大捧一进一出好爽视频| 久久久五月婷婷| 亚洲天堂免费av| 欧美高清视频在线| 精品在线观看入口| 欧美特黄aaa| 亚洲成人综合在线| 国产高清视频在线| 97视频中文字幕| 亚洲在线成人| 美女三级黄色片| 精品国产乱码久久| 成人涩涩视频| 99国产精品白浆在线观看免费| 菠萝蜜视频在线观看一区| 波多野结衣黄色| 精品中文字幕视频| 夜夜春成人影院| 久久精品国产99久久99久久久| 性久久久久久久久| aaa在线观看| 国产精品三区www17con| 日韩国产高清在线| 欧美片一区二区| 亚洲图片在线综合| 天堂va欧美ⅴa亚洲va一国产| 国产综合免费视频| 亚洲人成网站色在线观看| 色久视频在线播放| 成人精品网站在线观看| 亚洲欧美视频一区二区三区| 日韩av片在线免费观看| 亚洲国产日韩欧美在线99| 欧美成人黄色|