推 lightyen: 日防夜放家賊難防 用OpenFileDialog 10/04 16:07
推 jass970991: 同意樓上 但如果硬要挑一種寫法出來 我會直接丟except 10/04 16:29
→ jass970991: ion 外面接的人要去負責處理 文件寫清楚就好 10/04 16:29
我自己來自問自答好了
開檔寫入只是想舉例而已
只是想知道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
推 jass970991: 我經驗沒有很多 不過我有點好奇 你願意自己寫一個clas 10/04 23:35
→ jass970991: s而不願意使用exception去接的原因是什麼 try catch 10/04 23:35
→ jass970991: 本身也可以接各種不同的exception 單純好奇理由 想 10/04 23:35
→ jass970991: 學習各種不同的思維模式 10/04 23:35
也是從別人那邊 code 學來的
try 似乎比較像是在無法預期會發生什麼錯誤
比較難掌控情況下使用
function 丟出個 bool 出來, 再去判斷
檔案開啟失敗了, 我就知道 Error 是甚麼
檔案寫入失敗了,我就知道 Error 是甚麼
但我還是不太確定對於防呆哪一種比較好, 同時又讓外面 UI 知道到底錯在哪裡
※ 編輯: abc95007 (220.133.187.22), 10/05/2018 00:05:46
推 CloudyWing: 一般來說取決於層級,較底層的是例外,較外層是bool o 10/05 02:36
→ CloudyWing: r message 10/05 02:36
→ CloudyWing: 舉例來說操作介面來的資料是允許對方可能會輸入錯誤, 10/05 02:41
→ CloudyWing: 就不該用例外處理,而是判斷完值後回傳訊息,但較底層 10/05 02:41
→ CloudyWing: 的api則是直接預期對方使用這個api應該要知道適當參數 10/05 02:41
→ CloudyWing: 為何,當不符合則是拋出例外。 10/05 02:41
→ CloudyWing: 簡單來說還是取決於你對函式的定位,假設你的案例程式 10/05 02:45
→ CloudyWing: 是在Main呼叫函式,我傾向於不用例外 10/05 02:45
推 CloudyWing: 然後訊息方式enum or bool+out message or 寫一個資料 10/05 02:50
→ CloudyWing: 結構(structure和class都行)封裝是否成功和訊息都可以 10/05 02:50
→ CloudyWing: ,用哪種也是看需求 10/05 02:50
→ CloudyWing: 如果會需要判斷回傳訊息是哪種而執行不同行為用enum; 10/05 02:55
→ CloudyWing: 想要知道有沒有成功並且show訊息用第二種;第三種就比 10/05 02:55
→ CloudyWing: 較彈性,你可以同時封裝bool messsge enum,然後看情 10/05 02:55
→ CloudyWing: 況決定 10/05 02:55
→ CloudyWing: 話說你的message應該用out不是ref,用ref會讓人預期是 10/05 02:57
→ CloudyWing: 訊息的累加 10/05 02:57
推 DeathTemp: try catch不是用來處理無法預期的錯誤的,MSDN有說明 10/05 19:57
→ DeathTemp: 觀念,我還看過有人把每一個function的內容都用try包起 10/05 20:00
→ DeathTemp: 來,每一個喔,更扯的是他的catch裡面什麼都沒做,等於 10/05 20:00
→ DeathTemp: 出現exception時完全沒有訊息,使用者連反映都沒機會 10/05 20:01
→ DeathTemp: 如果懷疑自己寫的程式可能會有自己無法預期的錯誤,你 10/05 20:03
→ DeathTemp: 要做的事應該是debug或把錯誤變成可以預期的,而不是放 10/05 20:04
→ DeathTemp: 著不管,用try包起來就了事 10/05 20:05
→ DeathTemp: 把一支「我不知道他有沒有bug,也不知道哪裡會有bug」 10/05 20:06
→ DeathTemp: 的程式交出去不覺得怪怪的嗎? 10/05 20:06
→ kobe8112: 例外不是都有名稱嗎...你看官方的各種函式,如果會跳例 10/05 21:36
→ kobe8112: 外,每種不同的例外在什麼情況會跳出來不是都有說明嗎? 10/05 21:37
→ kobe8112: 怎麼會不知道Error是什麼呢? 10/05 21:37
→ feeya: log(e.message) 印出來你就知道是哪個exception 10/06 00:27
推 t64141: 很多工程師都把catch地毯式使用,每次看到都覺得很吐血 10/06 00:45
→ t64141: 曾經有同事說: 預防萬一,所以每個方法都要try-catch 10/06 00:48
推 CloudyWing: 全包try catch和throw ex真的是try catch兩大誤用 10/06 00:51
→ t64141: throw ex 也是經典,看過一個專案到處throw ex,然後同事 10/06 00:58
→ t64141: 看到stack trace之後認為是try-catch不夠,於是下一層的 10/06 00:58
→ t64141: 方法也都加了try-catch,印完log再重拋出去外面再印一次, 10/06 00:58
→ t64141: 很恐怖XD 10/06 00:58
推 chentsungmin: 建議try catch原則,能處理或需處理才去 catch, 另 10/06 06:16
→ chentsungmin: 外 catch 可以寫多段,針對不同型別的exception,這 10/06 06:16
→ chentsungmin: 也可以達到你依不同的 error,丟出不同的exception, 10/06 06:16
→ chentsungmin: 裡面可以附加更多不同資訊,而不是一個整數或列舉 10/06 06:16
→ chentsungmin: 的限制,它有效能的消耗 10/06 06:16
→ jim7434: try catch 跟 bool 應付的是不同層級的錯誤處理 10/06 11:05
推 dontblame: try catch 才是好方法,只是要將清楚資訊 丟給呼叫者 10/09 17:04
→ s9041200: 丟出有意義的例外,catch有意義的例外再針對每個case處 11/02 21:54
→ s9041200: 理 11/02 21:54