可以安全地假設從strconv.Parse函數返回的任何錯誤一定是由于錯誤的輸入數據造成的嗎?這個問題涉及到了對于strconv.Parse函數的錯誤處理的理解。通常情況下,strconv.Parse函數返回的錯誤確實是由于輸入數據不符合預期格式而導致的。然而,也有一些特殊情況需要考慮。一些錯誤可能是由于輸入數據的類型錯誤,例如將字符串轉換為整數時,字符串中包含了非數字字符。此外,還有一些邊界情況,例如整數溢出或浮點數精度丟失,也可能導致錯誤的返回值。因此,對于從strconv.Parse函數返回的錯誤,我們不能完全假設是由于錯誤的輸入數據造成的,而是需要綜合考慮其他可能的因素。
問題內容
在最近的一次代碼審查中,審查者對我如何處理從 strconv.ParseUint()
返回的錯誤提出了疑問。該函數被記錄為返回轉換后的 uint 值和 *strconv.NumError
具體類型的錯誤。文檔提到了可以返回的該類型的兩個哨兵錯誤(ErrSyntax
和 ErrRange
),這兩個錯誤都意味著向其提供了錯誤數據。根據該函數的接口,也可能出現任何其他錯誤。
對于我的用例,我需要知道我擁有的字符串值是否值得轉換為 uint。如果 ParseUint
返回錯誤,并且它是哨兵錯誤之一,那么我得到了答案。但如果返回的錯誤不是這些,那么我返回它并停止執行。我的審閱者斷言,我應該假設從 ParseUint
返回的任何錯誤意味著我給了它錯誤的數據,并且不需要檢查哨兵錯誤,沒有理由檢查哨兵錯誤,也不會返回該錯誤(在我的用例中)。他們鏈接到 go 標準庫中的一個示例,其中來自 ParseUint
的錯誤被視為對錯誤輸入數據的檢查并且從未返回,并表示有很多這樣的示例。
雖然我當然可以理解,一定存在一種算法,只要提供良好的數據和足夠的資源,就始終能夠計算出所需的結果,但現實世界并不總是符合理論理想。我在圖書館的文檔中找不到任何內容表明它不會也永遠不會因除錯誤數據之外的任何其他原因返回錯誤。標準庫有一個或者可能有很多這樣的例子,一方面令人放心,另一方面令人恐懼,介于“兩個錯誤不能構成正確”和“他們正在這樣做,所以對我們來說一定是安全的”之間在這種情況下也這樣做。
這只是圖書館文檔缺少一句話的情況嗎?或者當這兩個錯誤都不是時返回錯誤是好的嗎?我該如何推理?
解決方法
是的,可以安全地假設 strconv.ParseXXX
函數的錯誤是由于錯誤的輸入數據造成的。
從您提到的文檔頁面:
我閱讀此內容的方式是“strconv.ParseXXX 中的任何錯誤都是 NumError
,并且可能是由于無效數字或位大小范圍錯誤”。我的理解是,godocs 試圖盡可能完整地概述函數調用的期望范圍。
因此,我認為可以安全地假設這些是您可能會看到從 strconv.ParseXXX
函數返回的唯一錯誤。如果有其他東西回來,我會認為它是一個文檔錯誤。
回答您的最后一個問題:您在標準庫調用此函數時觀察到的模式是正確的。返回整個錯誤并讓調用者決定如何處理它。哨兵錯誤旨在幫助您了解出了什么問題,并代表了這些函數可能出現的錯誤的全部范圍。