※ 本文為 TLdark 轉寄自 ptt.cc 更新時間: 2022-01-23 11:27:10
看板 C_Chat
作者 標題 [閒聊] 工程師才懂的笑話
時間 Fri Jan 21 16:21:30 2022
剛剛看到的
https://i.imgur.com/UeBuvTy.jpg
https://i.imgur.com/1qUWOKJ.jpg
https://i.imgur.com/JZPY3pH.jpg
https://i.imgur.com/hsR0C39.jpg
所以為什麼有多0.00000004
0.1 + 0.2 不是 0.3 嗎
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 39.10.227.236 (臺灣)
※ 文章代碼(AID): #1XwcqDca (C_Chat)
※ 文章網址: https://www.ptt.cc/bbs/C_Chat/M.1642753293.A.9A4.html
推 : 一加一等於多少......1F 01/21 16:22
推 : 笑死,浮點數的bug2F 01/21 16:22
推 : 表示編碼常數設定有問題3F 01/21 16:23
推 : 你的浮點運算壞掉了4F 01/21 16:23
→ : 世界上有10種人,懂二進制的跟不懂的6F 01/21 16:23
→ : 殺小7F 01/21 16:23
推 : google的到0.1+0.28F 01/21 16:23
→ : 笑死 你可以Google一下精度損失 有滿多講解的9F 01/21 16:24
推 : XDDDDD10F 01/21 16:24
推 : 就叫你%d中間要加數字了11F 01/21 16:24
推 : ; ;12F 01/21 16:24
推 : js吧13F 01/21 16:25
推 : 浮點數本身的誤差14F 01/21 16:25
推 : 再精確一點是 3.00000000000000044409e-0115F 01/21 16:27
推 : 表示他用的是 double float ?17F 01/21 16:27
→ : 浮點數是 IEEE754 規定的18F 01/21 16:27
推 : IEEE75419F 01/21 16:27
→ : (single) float 去算出來會是 0.320F 01/21 16:28
→ : single point 是 3.00000011920928955078e-0122F 01/21 16:29
→ : int!!!先int!!!!23F 01/21 16:29
推 : 考慮用decimal嗎24F 01/21 16:31
推 : 記得round啦 很多bug都是這樣來的25F 01/21 16:32
推 : 這反映的是浮點數的等號沒太大意義。LeetCode上面就有問26F 01/21 16:32
→ : 題是跟這個有關係
→ : 題是跟這個有關係
→ : js的浮點數問題 有名到被拿來當考題28F 01/21 16:32
→ : 最近我還有遇到空白檢查不出來的狀況-_-
→ : 最近我還有遇到空白檢查不出來的狀況-_-
推 : 午告靠北30F 01/21 16:34
推 : 笑死31F 01/21 16:34
推 : IEEE 754精度問題w32F 01/21 16:34
→ : 我上次就遇到數學函式的定義域傳入float 但在運算的過程33F 01/21 16:35
→ : 就是多了後面導致error
→ : 就是多了後面導致error
→ : 然後不要對兩個浮點數比較是否相等www35F 01/21 16:35
推 : 直接宣告int啦36F 01/21 16:35
→ : 要避免這種問題可以依照需要的精度乘以10^n37F 01/21 16:36
→ : 全部用整數運算 然後轉換回去之後四捨五入
→ : 不只是js 只要是IEEE754就有這問題 精度是有限的
→ : 全部用整數運算 然後轉換回去之後四捨五入
→ : 不只是js 只要是IEEE754就有這問題 精度是有限的
推 : 我笑了XD40F 01/21 16:37
推 : 那就跟猴子被電還有買牛奶的笑話一樣41F 01/21 16:38
→ : 工程師在笑 其他人都不懂
→ : 工程師在笑 其他人都不懂
→ : 特別是牽扯到金錢或者科學運算的時候...43F 01/21 16:38
推 : 幹,我居然笑了 真的有夠宅wwww44F 01/21 16:39
推 : 16樓證明js就是邪教45F 01/21 16:41
→ : 每個坑都能讓工程師debug一整天
→ : 每個坑都能讓工程師debug一整天
推 : 軟體工程師47F 01/21 16:42
推 : 這問題大概要等到量子電腦普及才有解48F 01/21 16:42
→ : 那個 其實如果你從c開始寫 就沒差了..w49F 01/21 16:42
→ : 量子電腦嗎...我不認為現在的"量子"電腦能夠處理連續
→ : 量子電腦嗎...我不認為現在的"量子"電腦能夠處理連續
推 : 1.0 + machine epsilon = 1.0 阿51F 01/21 16:44
→ : 所以浮點數 ==, != 是有一個 espilon 範圍的
→ : 所以浮點數 ==, != 是有一個 espilon 範圍的
→ : 記得這遊戲很硬核 一般人要玩很久才搞懂53F 01/21 16:45
推 : machine epsilon 就是為了科學計算定義的咩...54F 01/21 16:45
→ : 其實不是 是因為連續計算 特別是乘法之後...
→ : 然後與其去為了程式語言或者平台調整 不如直接算整數.
→ : 其實不是 是因為連續計算 特別是乘法之後...
→ : 然後與其去為了程式語言或者平台調整 不如直接算整數.
推 : 詳細可以看LAPACK DLMACH 的定義57F 01/21 16:46
→ : 特別是金融 交易所 公開市場這種應用..58F 01/21 16:47
推 : 記得digicurrency 也有人用python去抓虛擬幣值59F 01/21 16:49
推 : 有時候遇到這種情況真的會找Bug找到哭出來,尤其是兩60F 01/21 16:49
→ : 個浮點數比較數值的時候,真的只有一個幹字
→ : 個浮點數比較數值的時候,真的只有一個幹字
推 : 應該說量子電腦應該無法超過戈德爾不完備62F 01/21 16:49
→ : 結果沒考慮的浮點數 結果自動交易賠錢 XD63F 01/21 16:49
→ : 抓歸抓啊 爬蟲隨便抓 反正是string..64F 01/21 16:49
→ : 是啊 XD
→ : 是啊 XD
→ : 遇到浮點數我一律轉成字串用BigDecimal計算==66F 01/21 16:49
→ : 處理浮點數比較一定要考慮精度啦..67F 01/21 16:50
推 : 以前被這個問題搞過,從此再也不信任浮點數68F 01/21 16:50
→ : 其實電腦是無法表示整個實數域的...69F 01/21 16:51
→ : 我記得可以用鴿籠原理證明
→ : 然後又會牽扯到哥德爾不完備
→ : 所以計算機處理浮點數 就跟上面講的一樣 要定義
→ : 最極限的 epsion
→ : epislon
→ : 我記得可以用鴿籠原理證明
→ : 然後又會牽扯到哥德爾不完備
→ : 所以計算機處理浮點數 就跟上面講的一樣 要定義
→ : 最極限的 epsion
→ : epislon
推 : 除了 machine epsilon 還有safe minimum75F 01/21 16:53
→ : underflow threshold, largest exponent before over
→ : underflow threshold, largest exponent before over
→ : 我記得只要是數值運算的套件都會有工具幫忙77F 01/21 16:53
→ : flow, overflow threshold78F 01/21 16:53
推 : 因為浮點數79F 01/21 16:53
→ : 之前就遇過有人沒搞清楚這個寫出來的python跑結果80F 01/21 16:54
→ : 然後論文出去之後被...
→ : 然後論文出去之後被...
推 : 這篇好臭82F 01/21 16:54
→ : 所以科學計算是蠻複雜的 除了演算法本身 連機器的運算83F 01/21 16:55
→ : 精準度都要考慮
→ : 精準度都要考慮
推 : 西洽果然一堆肥宅工程師,好可憐85F 01/21 16:55
→ : 所以最好裝computing server的時候IT要設好啊...86F 01/21 16:56
→ : 以前在lab有用science linux與python設定過一次
→ : 不過當時其實也是照著套件的README去搞 也沒多想XD
→ : 以前在lab有用science linux與python設定過一次
→ : 不過當時其實也是照著套件的README去搞 也沒多想XD
推 : 某方面來說這不是bug就是了,語言就照他設計的方式在運作89F 01/21 17:02
推 : 那張js 的圖看一次笑一次w90F 01/21 17:03
推 : 這東西竟然可以在C洽討論的這麼熱烈91F 01/21 17:04
→ : 這不是bug啊 是計算理論的極限92F 01/21 17:04
推 : 如果電腦一個位元剛好有10種狀態的話 0.1+0.2不是問題93F 01/21 17:04
→ : ECMAScript那種坑是因為這東西本來就是疊床架屋的..95F 01/21 17:05
→ : 但現實剛好只有兩種狀態,所以0.1和0.2他其實都不認識96F 01/21 17:05
推 : 不過這個只要是電資的學生大概就都會知道了吧,沒在97F 01/21 17:06
→ : 唸的除外
→ : 唸的除外
→ : 電腦只認識0.5, 0.25, 0.125, 0.0625, 0.03125 ......99F 01/21 17:06
推 : 幹你娘的js100F 01/21 17:06
→ : 然後用他們組成盡可能接近0.1和0.2的東西101F 01/21 17:06
→ : 恩...這樣說數學上其實不太對 因為就算十進位系統102F 01/21 17:06
→ : 只要是離散的符合圖靈機的 就無法處理連續 所以勢必
→ : 有精度問題
→ : 只要是離散的符合圖靈機的 就無法處理連續 所以勢必
→ : 有精度問題
推 : 但像0.1或0.2這麼簡單的東西 用十進位沒問題105F 01/21 17:08
→ : pumping lemma會讓狀態機變成indefinite106F 01/21 17:08
→ : 你如果把IEEE754直接魔改成十進位 那就是科學記號而已107F 01/21 17:09
→ : 對 但這本身就已經限制了精度啦108F 01/21 17:09
→ : 當然你來個1/3他一樣是直接擺爛109F 01/21 17:09
→ : 所以才會需要上面提到的各種限制來解釋限制110F 01/21 17:09
推 : js一堆神奇的特例阿...111F 01/21 17:10
→ : js那個不是特例 是語法糖 然後糖的背後就是惡夢..XD112F 01/21 17:10
→ : 跟php早期一樣 很多人懶得處理type轉換的問題
→ : 跟php早期一樣 很多人懶得處理type轉換的問題
→ : js的compiler就是個病嬌 你給什麼她都硬吞114F 01/21 17:11
→ : 所以請愛用typescript :P115F 01/21 17:11
→ : 最近我正在把整個團隊轉為typescript
→ : 最近我正在把整個團隊轉為typescript
→ : 請工程師小圈圈放過西洽117F 01/21 17:13
推 : 最近我們公司的前端也在轉型TypeScript 該不會..118F 01/21 17:14
→ : 一定不是 因為我不是帶前端 是全端團隊...119F 01/21 17:14
→ : 但這是一個大勢所趨 特別是不管vue/reactjs/angular
→ : node生態系混亂夠久了 該有一個哲學出現了
→ : 但這是一個大勢所趨 特別是不管vue/reactjs/angular
→ : node生態系混亂夠久了 該有一個哲學出現了
推 : 笑死XD122F 01/21 17:16
噓 : 不是工程師也會知道好嗎==123F 01/21 17:17
推 : 寫C的表示看不懂這個梗124F 01/21 17:18
推 : 寫C的應該更痛吧...125F 01/21 17:19
推 : 寫C的不是沒這問題,是沒事不會去看126F 01/21 17:19
→ : 如果你說Java或C#我信XD127F 01/21 17:19
→ : 不是沒去看 是沒遇到過
→ : 不是沒去看 是沒遇到過
→ : float x = 0.1f; float y = 0.2f;129F 01/21 17:20
推 : 幹你js130F 01/21 17:20
→ : 我是以前自己寫3D引擎做矩陣運算才遇到的...131F 01/21 17:20
→ : printf("%f + %f = %f\n", x, y, x + y);132F 01/21 17:20
推 : 我C#仔 我都直接decimal 我就爛 (攤手)133F 01/21 17:20
→ : 你這樣執行出來也只會看到正常的六位小數134F 01/21 17:20
→ : 沒考慮這問題整個向量會轉到歪掉135F 01/21 17:20
→ : fprintf的顯示是他的顯示而已啊
→ : fprintf的顯示是他的顯示而已啊
推 : 倒是真的沒有看過6位後面的137F 01/21 17:21
推 : 寫C/C++的更死好不好,你來寫金融軟體試試,少1毛錢都被罵死138F 01/21 17:21
→ : 應該說啦 你拿C寫科學運算照樣要考慮這問題139F 01/21 17:21
→ : fprintf基本上已經是砍過精度輸出char*啦
→ : 沒有語言不會遇到這個問題的
→ : 不信的話可以寫矩陣乘法然後不考慮精度給他一直乘
→ : fprintf基本上已經是砍過精度輸出char*啦
→ : 沒有語言不會遇到這個問題的
→ : 不信的話可以寫矩陣乘法然後不考慮精度給他一直乘
推 : 其實我想表達的是寫C通常不會用js, python那種打一行143F 01/21 17:23
→ : 看結果的介面 所以不會有0.1+0.2(按Enter)0.300000004
→ : 這種體驗 你真的去印而且故意印十幾位才會發現
→ : 看結果的介面 所以不會有0.1+0.2(按Enter)0.300000004
→ : 這種體驗 你真的去印而且故意印十幾位才會發現
推 : 原來是這樣,不過寫C通常都FW,還真的很少碰浮點數146F 01/21 17:24
→ : 那只是fprintf的%d %f %s做掉啦...147F 01/21 17:24
→ : 沒有看到這篇我還真不知道這個問題148F 01/21 17:24
→ : 如果是操作interrupt與ioctl是不太會遇到啦149F 01/21 17:25
→ : 嗯,只是寫的人沒事不會看到而已,腦中應該都有概念150F 01/21 17:25
→ : 但是做遊戲一定會遇到151F 01/21 17:25
→ : 浮點數還要看你拿來做啥,用float32計算金融會出大事152F 01/21 17:26
推 : 當你客戶算出來的錢少1毛然後被罵到臭頭開始debug看的時候153F 01/21 17:26
→ : 就會印出來一個個找了...
→ : 就會印出來一個個找了...
推 : 哈哈哈哈哈哈哈當初被JS搞超久155F 01/21 17:26
→ : 但如果是單純的影像運算你用double會被老鳥罵時間太多156F 01/21 17:26
→ : 金融計算一律規定好精度到小數幾位之後乘以10^n157F 01/21 17:26
→ : 用整數算 不要用小數去加減...
→ : 用整數算 不要用小數去加減...
推 : 今天學到了這個知識159F 01/21 17:26
→ : 至少以前我在中央信託局看到的db與code是這樣寫的XD160F 01/21 17:27
→ : 影像運算?你是說傅立葉轉換嗎
→ : 影像運算?你是說傅立葉轉換嗎
→ : 影像處理其實就會出事了 算一個小區域的平均和標準差162F 01/21 17:27
→ : 然後你開GOOGLE按F12打一次就知道為什麼了w163F 01/21 17:27
→ : 不,那麼複雜的東西當然你要自己考慮好精度問題164F 01/21 17:28
→ : 但如果你算個平均值還用double,一定會被電
→ : 但如果你算個平均值還用double,一定會被電
→ : 標準差啊 可是是頻域還是空間域?166F 01/21 17:28
→ : 因為影像的空間域都是整數啊....
→ : 因為影像的空間域都是整數啊....
→ : 就很單純的一個21x21區域內像素的標準差 沒用到頻率域168F 01/21 17:29
→ : RGBA四channel?169F 01/21 17:30
→ : 喔我大概知道意思了 是要算entropy?
→ : 喔我大概知道意思了 是要算entropy?
→ : 用double會被電,用float32合理,但如果區域一片平坦171F 01/21 17:30
推 : @tsunami 金融相關追求精確度是這樣啦,但是有些應用求快,172F 01/21 17:30
→ : 是真的在乎decimal/float運算速度差的就...
→ : 是真的在乎decimal/float運算速度差的就...
→ : 你就會被親愛的電腦算出一個負值的variance174F 01/21 17:30
→ : 代入sqrtf()直接爆炸,後面被汙染到的數值也整串爆炸
→ : 代入sqrtf()直接爆炸,後面被汙染到的數值也整串爆炸
推 : 剛剛測試了一下,變數0.1加上變數0.2 再乘上100000,後176F 01/21 17:31
→ : 面就有值了
→ : 平時還真的被printf屏蔽了雙眼
→ : 面就有值了
→ : 平時還真的被printf屏蔽了雙眼
→ : 怎麼有人自殺179F 01/21 17:32
→ : 所以我一律閉著眼睛寫sqrtf(max(variance, 0.0f))180F 01/21 17:32
推 : 靠北,第一眼看不懂,再看就知道是在講什麼,以前也有被搞過181F 01/21 17:32
推 : 我懂了 這個我遇過wwww182F 01/21 17:32
→ : 所以真的像上面版友一樣先轉string再用BigDecimal計算183F 01/21 17:33
→ : 整數運算一定比較快吧?184F 01/21 17:33
→ : variance變成負數的原因也跟0.30000000000000004一樣185F 01/21 17:33
→ : 計算儲存全部都整數喔 只有最後顯示才轉小數186F 01/21 17:33
推 : 所以金融計算都是乘10^N 用正整數去算嗎?187F 01/21 17:35
→ : 我遇過的案例都是平均值和標準差一起算 這時就會用到188F 01/21 17:35
→ : 應該說我看到過這樣的解法 也許有專門寫這種系統的189F 01/21 17:35
→ : 會有更方便的系統或者工具啦
→ : 因為這樣可以一開始就規定好精度
→ : 會有更方便的系統或者工具啦
→ : 因為這樣可以一開始就規定好精度
→ : Var(X) = E[X^2] - E[X]^2 後面還是需要浮點數192F 01/21 17:36
→ : 然後常識告訴你這一定大於等於0 你就會被捅了
→ : 另外如果你要算一張大圖的標準差時int32會撐不住
→ : 然後常識告訴你這一定大於等於0 你就會被捅了
→ : 另外如果你要算一張大圖的標準差時int32會撐不住
→ : 是啊 因為計算機無法處理整個實數域...195F 01/21 17:37
→ : 所以數學上成立的式子不代表計算機算得出來...
→ : 所以數學上成立的式子不代表計算機算得出來...
推 : 我自己用的類decimal class是用整數去算然後再顯示小數沒198F 01/21 17:40
→ : 錯,可是看到過很多次其他人死在直接拿double在算
→ : 錯,可是看到過很多次其他人死在直接拿double在算
推 : 整數轉小數寫法還有一個隱藏風險 就是無論經驗多豐富200F 01/21 17:40
→ : 的人也可能在寫昏頭之際 不小心對整數發動整數除法
→ : 的人也可能在寫昏頭之際 不小心對整數發動整數除法
→ : 'float算出來有誤差,那就改用double啊' by職場前輩202F 01/21 17:41
→ : 這種前輩我一率回恭喜發財203F 01/21 17:43
推 : 我這邊是"給我一個你非得用double不可的理由"204F 01/21 17:44
→ : 你前輩應該創造了不少工作機會 要感謝它205F 01/21 17:46
推 : 工作機會不知道,加班機會是很多...還好跑了206F 01/21 17:48
推 : 其實這一串討論的在那本紅色封面的"數值計算"課本都有207F 01/21 17:49
→ : 但現在好像資工系都不太修那本了?
→ : 但現在好像資工系都不太修那本了?
→ : 沒有type casting成職缺的工作機會就是加班囉209F 01/21 17:50
→ : 其實就離散會講的無窮可數/不可數問題 資工應該都會學
→ : 其實就離散會講的無窮可數/不可數問題 資工應該都會學
→ : 離散是計算理論部分 數值分析那本是講寫程式的時候211F 01/21 17:53
→ : 怎麼樣處理數字精度的問題XD
→ : 怎麼樣處理數字精度的問題XD
推 : 精確度213F 01/21 17:54
推 : 這年頭程式猴出生地很多種,不是只有資工就是了...另外實務214F 01/21 17:55
→ : 上也遇過寫COBOL幾十年的客戶RD問為啥float有誤差問題,因
→ : 為COBOL都是類似decimal的變數種類他們根本不知道有這問題
→ : 上也遇過寫COBOL幾十年的客戶RD問為啥float有誤差問題,因
→ : 為COBOL都是類似decimal的變數種類他們根本不知道有這問題
推 : 對啊 因為COBOL從一開始就是為了會計金融設計的XDD217F 01/21 17:55
→ : 直接就要規定好精度了 畢竟算錢哪
→ : 直接就要規定好精度了 畢竟算錢哪
→ : 解釋半天之後被回一句 C語言好爛 lol219F 01/21 17:57
推 : c發明的時候從機械語言想要抽象化成數學語言的努力220F 01/21 17:58
→ : 正是最熱切的時候哪 現在則是都是盡可能工程導向
→ : 能用>>>>泛用
→ : 這也是ECMAScript長成那樣的原因之一...
→ : 本來沒有給人想要弄成多複雜的東西的...
→ : 當初設計的人絕對不會想到vuejs那種東西wwww
→ : functional? lambda? Javascipt!?
→ : 正是最熱切的時候哪 現在則是都是盡可能工程導向
→ : 能用>>>>泛用
→ : 這也是ECMAScript長成那樣的原因之一...
→ : 本來沒有給人想要弄成多複雜的東西的...
→ : 當初設計的人絕對不會想到vuejs那種東西wwww
→ : functional? lambda? Javascipt!?
→ : 其實都是設計問題 放到現在看有理數運算會偏掉很爛227F 01/21 18:01
→ : 應該說本來是有專門為了數理計算設計的語言的...228F 01/21 18:01
→ : 但8bit cpu年代IEEE754這種犧牲精度換值域的設計是必然229F 01/21 18:02
→ : 我就是說現在沒多少人記得的fortran...230F 01/21 18:02
→ : 其實不管多大的register空間 精度永遠都有限制的..
→ : 包括所謂的量子計算
→ : 其實不管多大的register空間 精度永遠都有限制的..
→ : 包括所謂的量子計算
推 : 讚233F 01/21 18:08
→ : 有保證精度的math lib但沒人會用那種東西234F 01/21 18:09
推 : 我也笑了 幹235F 01/21 18:09
→ : 除非你要算甚麼高能物理之類的...236F 01/21 18:09
推 : 有人又沒寫測試囉237F 01/21 18:14
推 : 靠妖看推文我還以為我走錯板238F 01/21 18:18
推 : c洽到底多少工程師啊 笑死239F 01/21 18:19
推 : 這問題本質上是因為floot用二進制表達小數部分,只要240F 01/21 18:22
→ : 沒辦法被2整除都會有精度問題,想要治本就是用10進制
→ : 表達小數,部分語言也會提供這類class如c#的decimal
→ : *float
→ : 沒辦法被2整除都會有精度問題,想要治本就是用10進制
→ : 表達小數,部分語言也會提供這類class如c#的decimal
→ : *float
噓 : 誰跟你寫c的看不懂 自己c爛在那邊開地圖砲啊244F 01/21 18:23
推 : 記得decimal在某些情況下會有誤差,但不是高精度似乎沒差245F 01/21 18:29
→ : 不是高精度的計算*
→ : 不是高精度的計算*
推 : 所以這到底是哪款遊戲247F 01/21 18:30
推 : 糟糕,我笑了248F 01/21 18:33
推 : 氣死 之前被搞過249F 01/21 18:36
推 : 以前學C踩過的雷 好懷念XD250F 01/21 18:37
推 : 好臭喔251F 01/21 18:44
推 : 沒遇過的鄉民是不是計概被當XD252F 01/21 18:47
推 : 讀完這篇推文長了一堆知識XD253F 01/21 18:50
推 : 電腦連個十進位都不會254F 01/21 18:58
推 : 浮點數ww255F 01/21 19:00
推 : 我碩論還真的是靠fortran算出來的,在部分科系還是有在用,256F 01/21 19:03
→ : 不過不過快1年沒碰coding都忘了一大半了
→ : 不過不過快1年沒碰coding都忘了一大半了
推 : 高階顯卡也一樣給你算錯258F 01/21 19:06
推 : 遊戲名:艾倫的自動機工坊259F 01/21 19:07
→ : 幹笑死XD,確實是工程師笑話xd,看完秒想到浮點數260F 01/21 19:19
推 : 推推 受教了261F 01/21 19:21
→ : 文組嗎 連這都不知道262F 01/21 19:23
推 : 第一次聽說好像是以前修離散的時候XD263F 01/21 19:32
→ : fortran其實工程類還是在用啦,像我認識化工的有在用
→ : fortran其實工程類還是在用啦,像我認識化工的有在用
→ : 算錢用浮點 遲早被人扁265F 01/21 19:35
→ : 幹我計概和離散都修完完全沒聽過這東西,是教授教太簡266F 01/21 19:46
→ : 單的意思哦
→ : 單的意思哦
→ : 是啊 以前計概都學過268F 01/21 19:53
推 : 計概教太簡單 離散不會教這個269F 01/21 20:03
→ : 離散教的是實數沒辦法用有限的長度表示 不過跟這篇碰到
→ : 的問題還沒有扯到那麼遠
→ : 離散教的是實數沒辦法用有限的長度表示 不過跟這篇碰到
→ : 的問題還沒有扯到那麼遠
推 : 沒用 BigDecima272F 01/21 20:07
推 : 浮點數不要來亂啦273F 01/21 20:12
推 : 浮點數有這缺點 就是因為伴隨而來的優點真的太大了274F 01/21 20:16
→ : 不過拿float32算錢一樣是要斷手斷腳的
→ : 不過拿float32算錢一樣是要斷手斷腳的
推 : 算錢用浮點,遲早被人扁。 黑大說過要記得276F 01/21 20:44
推 : 黑大是誰呀?277F 01/21 21:11
推 : 拿上面那句喂狗就有了,長期追蹤的Blog278F 01/21 21:31
推 : 這什麼遊戲279F 01/21 21:53
推 : 這個好笑哈哈哈哈280F 01/21 21:57
→ : 我以前剛出社會在PS2上寫的一個遊戲AI就因為有個浮點數等號281F 01/21 22:14
→ : 沒修正造成無限卡死
→ : 沒修正造成無限卡死
推 : XDDDD283F 01/21 22:21
推 : 簡單來說 電腦沒有小數這個概念 是用逼近的284F 01/21 22:31
推 : 轉型TypeScript的那位等你轉完型也會發現TS也只是疊床架屋285F 01/21 23:03
→ : 用C/C++-like的型別系統,然後C++的部分寫得四不像
→ : 上一間公司的案子有個完美的use case for mixin
→ : 結果TS的mixin有兩個官方implementation
→ : 還都很hacky,不知到啥時才成熟
→ : 用C/C++-like的型別系統,然後C++的部分寫得四不像
→ : 上一間公司的案子有個完美的use case for mixin
→ : 結果TS的mixin有兩個官方implementation
→ : 還都很hacky,不知到啥時才成熟
推 : 先推,假裝我知道在說三小290F 01/21 23:33
推 : 幹 這串真的是各種血淚史 (?)291F 01/21 23:34
推 : 看到選項2直接笑出來XD 還不用到後面的回應292F 01/21 23:55
推 : 我先講好笑,以防人家說我不懂293F 01/22 01:02
推 : 看到浮點數就猜到要玩這個梗294F 01/22 02:45
推 : 大一計算機程式實作會遇到的295F 01/22 04:12
推 : 這串好可怕296F 01/22 09:48
推 : C洽到底多少工程師看板297F 01/22 10:42
推 : 不要用浮點 給我用INT298F 01/22 22:15
→ : 浪費記憶體的傢伙
→ : 浪費記憶體的傢伙
--
※ 看板: ACG 文章推薦值: 0 目前人氣: 0 累積人氣: 626
作者 Wardyal 的最新發文:
- 10F 7推
- 298F 49推 195噓
- 8F 5推
- 13F 6推
- 剛剛我看對面選ZED 我後選石頭人來打 結果對線到邊線真的都好打 不過在出到第四件裝的時候感覺要補一點輸出 我就補魔穿棒了 (記得說什麼魔防>50 CP值就很高) 剛剛看Blitz 他是推薦我出 …99F 37推 7噓
點此顯示更多發文記錄
回列表(←)
分享