成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

牛氣的JavaScript,讓雪花算法成為空氣

開發 前端 算法
因為xjjdog的修為主要體現在后端上,所以愛屋及烏。這體現了斗爭是人類的基本屬性:程序員除了要干產品經理、項目經理,內部也并不是鐵板一塊。

[[353520]]

本文轉載自微信公眾號「小姐姐味道」,作者小姐姐養的狗 。轉載本文請聯系小姐姐味道公眾號。 

 沒錯。前端,就是用來坑后端的。

我也只能在這里,發表這樣無恥的言論。因為xjjdog的修為主要體現在后端上,所以愛屋及烏。這體現了斗爭是人類的基本屬性:程序員除了要干產品經理、項目經理,內部也并不是鐵板一塊。

不過這次要聊的問題,確實是很坑。它幾乎斷送了整個系統,讓暴躁的老板臉上爆炸式的長滿了痘痘。

它的影響不限于此。擴大到整個業界:

原來能發財的,破產了。

原來能結婚的,分手了。

原來能摸魚的,加班了。

原來搞前端的,搞后端了。

原來能退休的,延期了。

原來能活著的,去世了。

原來能雙休的,大小周了。

為什么牛氣的js,會有這么大的威力?請聽我細細道來。

1. 事出有因

就如標題所說,這個會和雪花算法有關。

我們有個系統,使用的是MySQL數據庫,所以在數據庫的主鍵選擇上,使用的是自增ID。

  1. ID INT  PRIMARY KEY AUTO_INCREMENT 

這樣的ID簡單流暢,但有一系列的弊端,不過用在一般的系統上,夠用了。

在臨上線之前,項目組邀請公司里最牛x的架構師,對項目進行了一次集中體檢。其中的一項重要舉措,就是針對于ID生成器的。

“不知道現在的開發系統,都至少要使用Snowflake作為ID生成器么?” 架構師對自增ID的方案非常的不滿意。

它指出,哪怕你使用UUID,在遇到系統擴容、分庫分表、數據遷移等場景的時候,也比自增ID強。

大家伙一討論,覺得非常合理。UUID太無序,美團Leaf這種又太復雜,還不如直接使用老掉牙的Snowflake,直接生成最簡單的ID即可。

類似于這種。

  1. 527574217068392807 
  2. 527574217068392808 

為了讓你有個直觀的認識,我們看一下Java中Long的最大值。

  1. 9223372036854775807 

再看一下Int的最大值。

  1. 2147483647 

可以看到生成的Snowflake ID,是比Int大,比Long小的數值(和最大的比較),所以在數據庫中使用bigint存儲,再好不過了。

說干就干,批量腳本一改,主鍵就變大變長了~~~

2. 問題發生

別說,這樣子的ID,看起來還比較順眼。ID在URL里傳遞,在formdata里傳遞,一看就比較的專業!

  1. /edit.do?id=527574217068392810 

系統按照建議改完之后,單元測試很流暢。黑盒測試草草的點了一下,就算通過了。

靈異事件是被客戶發現的。

客戶說,很多記錄,無法編輯、無法刪除。提示找不到記錄。

很多公司的尿性你也是知道的,和客戶交流的,通常不太懂技術。對著客戶的屏幕用牛x的手機拍照,原圖發過來就有十幾MB。但靈異的是圖片大,內容卻模模糊糊。

后端程序員,瞇著眼睛打開圖片,把里面顯示的ID給摳出來,放在系統里一查。

沒有此記錄。

肯定是瞇眼的姿勢有問題。后端程序員不得不再錄一遍。可惜的是,依然沒有這條記錄。

沒辦法,只好把客戶的數據庫拷貝一份過來。頁面上一點擊,果然有問題!

瀏覽器response里返回的數據竟然和preview里的不一樣

3. 問題驗證

也就是說,一個好好的數字:527183991665594368,經過瀏覽器一翻譯,變成了527183991665594400。

我們在瀏覽器的devtools里面調試一下。

為了進一步驗證,我們從typescript到js,都試驗一下。

  1.  # cat test.ts 
  2. let a = 527183991665594368; 
  3. console.log(a); 
  4.  # tsc test.ts 
  5.  # cat test.js 
  6. var a = 527183991665594368; 
  7. console.log(a); 
  8.  # node test.js 
  9. 527183991665594400 

可以看到,在整個js的生態里,都存在這個問題,真是坑壞了后端。

4. Why?

這是因為。在JavaScript中,存在兩種數字。Number和BigInt。最常用的,就是number。

最大的Number,叫做Number.MAX_SAFE_INTEGER,它的值為:

2^53-1 或者

+/- 9,007,199,254,740,991

眾所周知,Java中的Long,是64位的。Js中的這個安全Integer,完全達不到Java中定義的長度。

這就是萬惡的IEEE_754規范,它在Long長度大于17位時會出現精度丟失的問題。

在最新的TypeScript3.2中,可是直接使用BigInt這個類型進行編碼,或者使用long.js這種封裝后的苦,但還是太麻煩了,需要編碼太多,而且還可能漏掉。

使用數字類型,傳輸數據,實在是不太靠譜,轉來轉去,就物是人非了。

最好的方式,就是使用string進行傳遞。哪怕以后后臺ID的長度變成了128位的,也不懼怕這種轉換。

在Java中,如果你用的是jackson,直接通過注解,就可以完成字符串更改,不需要再改動數據庫。

  1. @JsonSerialize(using=ToStringSerializer.class) 
  2. private Long id; 

這問題,明顯不是后端的鍋。后端傳遞了正確的數據到前端,能不能處理、處理的正確不正確,根本和后端一點關系都沒有。JS的這種按照規范的不規范處理,已經讓很多人踩坑。不管是萌新,還是老鳥,依然前赴后繼的掉到坑里,不得不說這個特性是非常反人類的。

不過,我們還是在后端解決了。誰讓咱走的是全棧路線呢?必要時,連產品的活兒都能做!

作者簡介:小姐姐味道 (xjjdog),一個不允許程序員走彎路的公眾號。聚焦基礎架構和Linux。十年架構,日百億流量,與你探討高并發世界,給你不一樣的味道。我的個人微信xjjdog0,歡迎添加好友,進一步交流。

責任編輯:武曉燕 來源: 小姐姐味道
相關推薦

2021-08-26 13:22:46

雪花算法隨機數

2023-10-10 16:20:38

JavaScript代碼技巧

2024-10-09 14:45:41

2023-09-20 23:01:03

Twitter算法

2009-07-07 08:52:52

光纖光子晶體

2023-03-27 23:57:25

JavaScrip開發技巧

2023-06-27 17:42:24

JavaScript編程語言

2012-11-28 16:24:02

2015-09-28 14:27:12

硬編默認選擇

2013-06-28 14:30:04

2012-12-27 15:26:28

2023-02-06 16:46:59

JavaScript程序員技巧

2018-07-12 16:03:26

SLAM技術定位

2024-11-26 06:53:01

雪花算法最大值

2010-01-05 15:45:51

Linux成為路由器

2015-05-25 14:32:15

翻轉課堂華為

2020-06-24 09:43:55

CIOIT技術

2022-05-24 10:10:33

顧問CIO首席信息官

2010-01-20 22:17:00

TrunkVLAN交換機配置

2015-07-22 08:47:59

數據中心數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩av啪啪网站大全免费观看 | 九九亚洲 | 国产成人精品一区二区三区四区 | 亚洲精品成人在线 | 久久久免费在线观看 | 亚洲成av人片在线观看 | 毛片免费观看视频 | 国产一区二区久久 | 欧美日韩一区二区在线 | 日本免费在线看 | 一区二区三区四区在线视频 | 色婷婷亚洲国产女人的天堂 | www.99热这里只有精品 | 中文字幕视频一区二区 | 久久久久国产一区二区三区 | 美女一级黄 | 精品美女视频在线观看免费软件 | 精品国产高清一区二区三区 | 91久久综合 | 逼逼视频 | 国产精品电影在线观看 | 中文字幕一区二区三区精彩视频 | 国产日韩欧美一区 | 青青草原综合久久大伊人精品 | 久久国产精品久久久久久 | 亚洲欧美激情精品一区二区 | 日日骚网 | 成人国产在线视频 | 成人三区四区 | 亚洲综合无码一区二区 | 亚洲欧美日韩国产综合 | 精品日韩一区二区 | 亚洲视频一区二区三区 | 中文字幕在线播放不卡 | 国产成人亚洲精品 | 91精品一区二区三区久久久久久 | 不卡视频一区二区三区 | 免费国产黄网站在线观看视频 | 久久99久久99久久 | 亚洲精品视频在线看 | 亚洲成人网在线播放 |