作者Killercat (殺人貓™)
看板C_and_CPP
標題[討論] 有無匿名ostream物件做string format?
時間Mon Nov 27 11:21:09 2017
目前在改一個非常legacy的專案,Log function signature基本上寫死了沒辦法改 :
Log(const char* type, const char* client, const char* log);
以前看他們都是寫成這樣
char log[48];
sprintf(log, "This is a PEN : %s PINEAPPLE!");
Log(TYPE, CLIENT, log);
這寫法顯然是有問題的,但是這個VC6等級的編譯器又不支援sprintf_n
更不用說這其實挺麻煩的
所以後期我就把它改寫成這樣
stringstream log;
log << "This is a PEN : " << pen << " PINEAPPLE!";
Log(TYPE, CLIENT, log.str().c_str());
但是顯然這還是有點麻煩
自己是寫了一個ostream拼貼物件讓他看起來像是這樣
包含了一個operator const char*()
Log(TYPE, CLIENT, log << "This is a PEN : " << pen << " PINEAPPLE!");
來讓他能夠串起來,讓他能夠吃大多數的變數型別
問題來了,有沒有std函數能滿足這個需求?
Log希望能讓他們寫的方便一點,不然他們一個個都不想Log了 -o-||
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 60.250.140.192
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1511752872.A.682.html
1F:→ galic: 看不太懂你的需求耶... 為何不function overloading一個 11/27 11:38
2F:→ galic: Log(TYPE, CLIENT, FMT, ...) 的版本就好 11/27 11:40
3F:→ galic: 而且就算沒有snprintf或是sprintf_s 你也可以用strlen自幹 11/27 11:42
4F:→ Killercat: 盡量避免用...吧,型別不明滿難debug的 11/27 12:23
5F:→ Killercat: 是能自幹 不過就是用起來麻煩 11/27 12:23
6F:→ Killercat: 我是弄了一個stream物件做這件事 只是看有沒有std能用 11/27 12:23
7F:→ Killercat: 我是直接把stringstream加一個const char* operator XD 11/27 12:24
8F:→ galic: 我不懂的點就是 你既然要方便 就包成一個函式在裡面處理複 11/27 13:16
9F:→ galic: 雜的事情 呼叫的人不用管這麼多 這不就是方便? 11/27 13:16
10F:→ galic: 結果你一直找std有沒有支援這個 11/27 13:17
11F:→ galic: 你要作到type-safe就用variadic templates.. 但是版本又很 11/27 13:19
12F:→ galic: 舊不支援 那就只能去重載 () 或是 << 達到類似效果 你不就 11/27 13:20
13F:→ galic: 已經用類似方法達到? 11/27 13:20
14F:→ Killercat: 我的點是,我是土炮弄了個出來,但看看有沒有std已經 11/27 14:08
15F:→ Killercat: 有類似的solution,土炮總是比不上標準好 11/27 14:08
16F:→ Killercat: 就是土炮完以後覺得這case應該滿常見的 所以想看看std 11/27 14:08
17F:→ Killercat: 是不是已經有類似解,有的話我會傾向用std取代土炮 11/27 14:08
18F:→ Killercat: 以一個coder來講,尋求一個漂亮的輪子,總比自己打得好 11/27 14:09
19F:推 jasonwu23: 你sprintf範例有點怪 11/27 18:48
20F:→ Killercat: 對,少打一個參數 拍寫 XD 11/28 06:41
21F:推 galic: 說真的啦 你提著一個VC6的專案說在找漂亮的輪子… 不要侮辱 11/28 09:39
22F:→ galic: 人的智商啊 11/28 09:39
23F:→ Killercat: 條件也列了 該試的也寫出來了 你被侮辱到怪我哩 11/28 13:21
24F:→ Killercat: 講的好像是我不想把專案升級一樣(聳肩 11/28 13:22
25F:→ Killercat: 不過vc6本來就非長久之計 我上來也在想辦法幹掉他 11/28 13:24
26F:→ galic: 我是在酸你邏輯不通 是不是沒在動腦... 算了 11/29 19:30
27F:→ galic: 我是以為你的目的是讓其他使用Logging的人 覺得方便... 11/29 19:30
28F:→ galic: 原來你是在求自己方便 11/29 19:31
29F:→ galic: format一直都沒進過std,訂std比你想的複雜多了 11/29 19:32
30F:→ galic: 而且你的土炮叫做concatenate 不是formatting 11/29 19:39