[問題] 防呆寫法

看板C_Sharp (C#)作者 (別理我)時間6年前 (2018/10/04 15:10), 6年前編輯推噓10(10044)
留言54則, 11人參與, 6年前最新討論串1/1
請問關於 C# 防呆 寫法要怎樣比較妥當? 下面四種方法 Funciton 回傳 bool , 最外層再來寫錯誤訊息 或是 string 或 enum 或是自己些個 關於 Error class 代進去 或是 try catch (應該比較不推薦) 寫法讓我困擾滿久的 感謝~ public enum Error { Pass, CantOpenFile, } class Program { static void Main(string[] args) { string filePath = @"C:\123.txt"; //case1 //用 if + bool 來判斷是否成功 , if (File.checkFile(filePath)) { Console.WriteLine("檔案存在"); } else { Console.WriteLine("檔案不存在"); } //case2 // 用 message 丟進去, 再判斷是否成功 , 無回傳 bool string message = ""; File.checkFile(filePath, ref message); Console.WriteLine(message); //case3 Error error = Error.Pass; File.checkFile(filePath, ref error); Console.WriteLine(error.ToString()); //case4 try { //........ } catch (Exception) { throw; } } } class File { public static bool checkFile(string filePath) { bool result = System.IO.File.Exists(filePath); return result; } public static void checkFile(string filePath, ref string message) { if(System.IO.File.Exists(filePath)) { message = "檔案存在"; } else { message = "檔案不存在"; } } public static void checkFile(string filePath, ref Error error) { if (System.IO.File.Exists(filePath)) { error = Error.Pass; } else { error = Error.CantOpenFile; } } } -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 42.73.155.188 ※ 文章網址: https://www.ptt.cc/bbs/C_Sharp/M.1538637010.A.F0C.html

10/04 16:07, 6年前 , 1F
日防夜放家賊難防 用OpenFileDialog
10/04 16:07, 1F

10/04 16:29, 6年前 , 2F
同意樓上 但如果硬要挑一種寫法出來 我會直接丟except
10/04 16:29, 2F

10/04 16:29, 6年前 , 3F
ion 外面接的人要去負責處理 文件寫清楚就好
10/04 16:29, 3F
我自己來自問自答好了 開檔寫入只是想舉例而已 只是想知道class 裡面到底哪一步有問題, 可以傳到最外層讓UI顯示 與同事討論過後 應該比較像下列 丟出個 Error,再讓外面去顯示 不知道是否有更好建議 public static class Error { public static int PASS = 0; public static int OPEN_FILE = 1; public static int WRITE_FILE = 2; } class File { string path = @"C:\\"; public static int openAndWriteFile(string path) { if(!File.openFile(path)) return Error.OPEN_FILE; if (!File.writeString("hello")) return Error.WRITE_FILE; return Error.PASS; } public static bool openFile(string File) { return true; } public static bool writeString(string str) { return true; } } ※ 編輯: abc95007 (220.133.187.22), 10/04/2018 23:03:07

10/04 23:35, 6年前 , 4F
我經驗沒有很多 不過我有點好奇 你願意自己寫一個clas
10/04 23:35, 4F

10/04 23:35, 6年前 , 5F
s而不願意使用exception去接的原因是什麼 try catch
10/04 23:35, 5F

10/04 23:35, 6年前 , 6F
本身也可以接各種不同的exception 單純好奇理由 想
10/04 23:35, 6F

10/04 23:35, 6年前 , 7F
學習各種不同的思維模式
10/04 23:35, 7F
也是從別人那邊 code 學來的 try 似乎比較像是在無法預期會發生什麼錯誤 比較難掌控情況下使用 function 丟出個 bool 出來, 再去判斷 檔案開啟失敗了, 我就知道 Error 是甚麼 檔案寫入失敗了,我就知道 Error 是甚麼 但我還是不太確定對於防呆哪一種比較好, 同時又讓外面 UI 知道到底錯在哪裡 ※ 編輯: abc95007 (220.133.187.22), 10/05/2018 00:05:46

10/05 02:36, 6年前 , 8F
一般來說取決於層級,較底層的是例外,較外層是bool o
10/05 02:36, 8F

10/05 02:36, 6年前 , 9F
r message
10/05 02:36, 9F

10/05 02:41, 6年前 , 10F
舉例來說操作介面來的資料是允許對方可能會輸入錯誤,
10/05 02:41, 10F

10/05 02:41, 6年前 , 11F
就不該用例外處理,而是判斷完值後回傳訊息,但較底層
10/05 02:41, 11F

10/05 02:41, 6年前 , 12F
的api則是直接預期對方使用這個api應該要知道適當參數
10/05 02:41, 12F

10/05 02:41, 6年前 , 13F
為何,當不符合則是拋出例外。
10/05 02:41, 13F

10/05 02:45, 6年前 , 14F
簡單來說還是取決於你對函式的定位,假設你的案例程式
10/05 02:45, 14F

10/05 02:45, 6年前 , 15F
是在Main呼叫函式,我傾向於不用例外
10/05 02:45, 15F

10/05 02:50, 6年前 , 16F
然後訊息方式enum or bool+out message or 寫一個資料
10/05 02:50, 16F

10/05 02:50, 6年前 , 17F
結構(structure和class都行)封裝是否成功和訊息都可以
10/05 02:50, 17F

10/05 02:50, 6年前 , 18F
,用哪種也是看需求
10/05 02:50, 18F

10/05 02:55, 6年前 , 19F
如果會需要判斷回傳訊息是哪種而執行不同行為用enum;
10/05 02:55, 19F

10/05 02:55, 6年前 , 20F
想要知道有沒有成功並且show訊息用第二種;第三種就比
10/05 02:55, 20F

10/05 02:55, 6年前 , 21F
較彈性,你可以同時封裝bool messsge enum,然後看情
10/05 02:55, 21F

10/05 02:55, 6年前 , 22F
況決定
10/05 02:55, 22F

10/05 02:57, 6年前 , 23F
話說你的message應該用out不是ref,用ref會讓人預期是
10/05 02:57, 23F

10/05 02:57, 6年前 , 24F
訊息的累加
10/05 02:57, 24F

10/05 19:57, 6年前 , 25F
try catch不是用來處理無法預期的錯誤的,MSDN有說明
10/05 19:57, 25F

10/05 19:58, 6年前 , 26F
http://goo.gl/oYodhJ 奇怪不知為何很多人都有原po這種
10/05 19:58, 26F

10/05 20:00, 6年前 , 27F
觀念,我還看過有人把每一個function的內容都用try包起
10/05 20:00, 27F

10/05 20:00, 6年前 , 28F
來,每一個喔,更扯的是他的catch裡面什麼都沒做,等於
10/05 20:00, 28F

10/05 20:01, 6年前 , 29F
出現exception時完全沒有訊息,使用者連反映都沒機會
10/05 20:01, 29F

10/05 20:03, 6年前 , 30F
如果懷疑自己寫的程式可能會有自己無法預期的錯誤,你
10/05 20:03, 30F

10/05 20:04, 6年前 , 31F
要做的事應該是debug或把錯誤變成可以預期的,而不是放
10/05 20:04, 31F

10/05 20:05, 6年前 , 32F
著不管,用try包起來就了事
10/05 20:05, 32F

10/05 20:06, 6年前 , 33F
把一支「我不知道他有沒有bug,也不知道哪裡會有bug」
10/05 20:06, 33F

10/05 20:06, 6年前 , 34F
的程式交出去不覺得怪怪的嗎?
10/05 20:06, 34F

10/05 21:36, 6年前 , 35F
例外不是都有名稱嗎...你看官方的各種函式,如果會跳例
10/05 21:36, 35F

10/05 21:37, 6年前 , 36F
外,每種不同的例外在什麼情況會跳出來不是都有說明嗎?
10/05 21:37, 36F

10/05 21:37, 6年前 , 37F
怎麼會不知道Error是什麼呢?
10/05 21:37, 37F

10/06 00:27, 6年前 , 38F
log(e.message) 印出來你就知道是哪個exception
10/06 00:27, 38F

10/06 00:45, 6年前 , 39F
很多工程師都把catch地毯式使用,每次看到都覺得很吐血
10/06 00:45, 39F

10/06 00:48, 6年前 , 40F
曾經有同事說: 預防萬一,所以每個方法都要try-catch
10/06 00:48, 40F

10/06 00:51, 6年前 , 41F
全包try catch和throw ex真的是try catch兩大誤用
10/06 00:51, 41F

10/06 00:58, 6年前 , 42F
throw ex 也是經典,看過一個專案到處throw ex,然後同事
10/06 00:58, 42F

10/06 00:58, 6年前 , 43F
看到stack trace之後認為是try-catch不夠,於是下一層的
10/06 00:58, 43F

10/06 00:58, 6年前 , 44F
方法也都加了try-catch,印完log再重拋出去外面再印一次,
10/06 00:58, 44F

10/06 00:58, 6年前 , 45F
很恐怖XD
10/06 00:58, 45F

10/06 06:16, 6年前 , 46F
建議try catch原則,能處理或需處理才去 catch, 另
10/06 06:16, 46F

10/06 06:16, 6年前 , 47F
外 catch 可以寫多段,針對不同型別的exception,這
10/06 06:16, 47F

10/06 06:16, 6年前 , 48F
也可以達到你依不同的 error,丟出不同的exception,
10/06 06:16, 48F

10/06 06:16, 6年前 , 49F
裡面可以附加更多不同資訊,而不是一個整數或列舉
10/06 06:16, 49F

10/06 06:16, 6年前 , 50F
的限制,它有效能的消耗
10/06 06:16, 50F

10/06 11:05, 6年前 , 51F
try catch 跟 bool 應付的是不同層級的錯誤處理
10/06 11:05, 51F

10/09 17:04, 6年前 , 52F
try catch 才是好方法,只是要將清楚資訊 丟給呼叫者
10/09 17:04, 52F

11/02 21:54, 6年前 , 53F
丟出有意義的例外,catch有意義的例外再針對每個case處
11/02 21:54, 53F

11/02 21:54, 6年前 , 54F
11/02 21:54, 54F
文章代碼(AID): #1RjRpIyC (C_Sharp)
文章代碼(AID): #1RjRpIyC (C_Sharp)