推 stallings: 關於縮排,我比較接受 4 個空格 03/17 15:09
→ stallings: 8 個空格我覺得過多了。至於用 tab?嗯... 03/17 15:09
→ stallings: 關於區塊,現在好像有人提倡 03/17 15:09
→ stallings: 即使只有一行也加括號以使程式碼清楚 03/17 15:09
→ tomsawyer: vscode的linter會把if弄成大括號跟函數一樣 03/17 16:10
推 closer76: Google open-source style 是 2 空格.... 我一開始不習 03/17 16:43
→ closer76: 慣,但用了一段時間覺得也還不錯。 XD 03/17 16:43
推 Lipraxde: 比起縮幾格,不要搞成五、六層巢狀比較舒服 03/17 17:59
推 chuegou: 最後一個就防呆來說不好 misra規範就強制要加大括號 蘋 03/17 21:12
→ chuegou: 果的goto fail某種程度上也是因為沒加大括號 03/17 21:12
推 stallings: 沒在寫 Linux kernel code 就不用理那些了 03/17 22:14
推 mmmmei: 大括號我們組要求要新的一行。理由是這樣比較容易看出一 03/18 07:27
→ mmmmei: 個clause從哪裡開始的 03/18 07:27
推 johnjohnlin: 用一個tab縮排就能同時滿足2 4 8空白三種需求 03/18 10:37
→ fatalfeel2: 有些ide tab 可以設定 字元數 03/18 19:23
※ 編輯: fatalfeel2 (218.187.80.32 臺灣), 03/18/2023 19:24:46
推 stallings: 不定寬度正是 tab 的短處啊 03/18 21:25
→ stallings: 唯一支持 sp~叭叭叭~ 03/18 21:25
※ 編輯: fatalfeel2 (218.187.80.32 臺灣), 03/19/2023 06:27:11
推 CoNsTaR: 我都去找算命的算變數名稱,這樣以後程式有 bug 他比較好 03/19 14:00
→ CoNsTaR: 通靈 03/19 14:00
→ Caesar08: 不定寬度"是"tab的長處吧。tab可以解釋成各種space長度 03/22 19:00
→ Caesar08: 喜歡2 space的把tab設成2 space,喜歡4 space的就設成4 03/22 19:01
→ Caesar08: tab應該被大力推廣才對,不懂tab有什麼"缺點" 03/22 19:04
推 CoNsTaR: tab 的缺點是除了在你自己的 IDE A裡以外你永遠無法保證 03/22 22:32
→ CoNsTaR: tab 和 space 混用的檔案會被 display aligned 03/22 22:32
推 CoNsTaR: 就算你真的只用 tab 還是會有 misalignment,但只用 spac 03/22 22:35
→ CoNsTaR: e 永遠不會出錯 03/22 22:35
推 CoNsTaR: *IDE 03/23 00:20
→ madturtle: 按照樓上的理論,只用tab也永遠不會出錯。 03/24 05:40
→ Caesar08: 為什麼只用tab會misalignment?你tab不都是等寬嗎? 03/24 12:35
→ lycantrope: 用tab一定要跟space混用,除非你所有間隔都用tab 03/24 12:41
→ Caesar08: 為什麼要跟space混用?只有indent用tab,其他才用space 03/24 19:53
推 CoNsTaR: 除非你的其他字元也都跟 tab 一樣可以自由伸縮,whitespa 03/25 09:13
→ CoNsTaR: ce 全部都用 tab,否則就是會有 misalignment 啊 03/25 09:13
→ CoNsTaR: 你要怎麼保證你用 tabs indent 的 comments 開頭一定會 03/25 09:13
→ CoNsTaR: 對齊下一行的某個字元? 03/25 09:13
→ CoNsTaR: 除了一個參數一行以外,你要怎麼對齊多行的函數參數? 03/25 09:13
→ CoNsTaR: 你要怎麼保證你的 comments 不會超過 80 或 120 字元寬? 03/25 09:13
推 CoNsTaR: 更正,要怎麼把你開頭用 tabs indent 的 comments 對齊在 03/25 09:17
→ CoNsTaR: 80 或 120 字元寬? 03/25 09:17
推 CoNsTaR: 每行一個 statement,每個 statement 後面都有註解,你要 03/25 09:19
→ CoNsTaR: 怎麼對齊那些註解? 03/25 09:19
→ MOONRAKER: 想太多。space最大的好處是增加原始碼長度,看起來很多 03/27 09:24
推 johnjohnlin: 拿tab縮排 空白對齊就不會亂掉了 03/28 07:54
推 CoNsTaR: 樓上... tab 和 space 同時存在就是亂掉的主因啊 03/28 15:25
→ CoNsTaR: 用 tab 縮排之後到底要怎麼做到用 space 對齊? 03/28 15:25
→ Caesar08: 你舉的例子裡只有保證寬度(80或120)是tab做不到的 03/28 20:41
→ Caesar08: statement後面要把註解對齊,跟tab多寬沒有關係 03/28 20:42
→ Caesar08: 既然縮排是tab,那要對齊的時候也要補tab,而不是space 03/28 20:46
→ Lipraxde: 對齊 argument、三元運算子,tab 行嗎XD? 03/28 22:28
推 Richun: statement後對齊註解跟tab對應寬度很有關係,statement間 03/28 23:02
→ Richun: 的字元數落差只要大於一個hard tab寬度就會開始對不齊了。 03/28 23:02
→ Richun: 長度落差10個字元,hard tab在這台電腦佔8個,另一台佔4個 03/28 23:03
→ Richun: 這時對齊所需的tab數在兩台之間一定會差至少1格。 03/28 23:09
→ johnjohnlin: space align很多,vscode都有外掛了 03/29 00:20
→ johnjohnlin: 的確我常常看到亂混tab space的會很不爽,但是把握 03/29 00:21
→ johnjohnlin: 好的話我還沒遇過問題,同時可以滿足不同寬度喜好 03/29 00:22
推 johnjohnlin: @Lipraxde 當然不行 tab是"縮排" space才是"對齊" 03/29 00:38
推 CoNsTaR: 真要混用也是 space indent, tab align 吧 03/29 01:26
→ CoNsTaR: @johnjohnlin 貼的那篇只適用於每行縮排都相同的情況而已 03/29 01:26
→ CoNsTaR: ,要是有一個 block 或 statement 需要多縮一排,不又直 03/29 01:26
→ CoNsTaR: 接爆炸了? 03/29 01:26
→ CoNsTaR: * 誤, space indent tab align 照樣行不通 03/29 01:27
推 CoNsTaR: 反正回到一開始,space 和 tab 混用就是可能會有問題,通 03/29 01:29
→ CoNsTaR: 通用 tab 還是可能有問題,不要用就對了 03/29 01:29
→ Caesar08: 甚麼叫做“多縮一排”?那就補一個tab阿,只要indent就 03/29 01:37
→ Caesar08: 用tab,其他才用space,有那麼困難嗎? 03/29 01:37
→ Caesar08: @johnjohnlin 貼的文章就說明怎麼用tab了。tab又不是拿 03/29 01:38
→ Caesar08: 來取代space,他只是提供indent而已 03/29 01:38
→ Caesar08: 你覺得space很方便,因為不會有亂用的問題。但是tab也有 03/29 01:44
→ Caesar08: 方便的地方,因為每個人喜歡的indent都不同,tab提供了 03/29 01:44
→ Caesar08: 一個抽象層,讓大家可以在不改source code的狀況下得到 03/29 01:44
→ Caesar08: 自己喜歡的style 03/29 01:44
噓 CoNsTaR: 多補一個 tab,然後你用 space 做的 alignment 就壞掉了 03/29 03:03
→ CoNsTaR: 這樣有很難理解? 03/29 03:03
噓 CoNsTaR: 從來沒有在討論喜歡哪個 style 或哪個方便,從頭到尾討 03/29 03:05
→ CoNsTaR: 論的都是 tab 會在很多專案被禁止使用的原因 03/29 03:05
噓 CoNsTaR: 我就已經說明 @johnjohnlin 貼的文章會遇到什麼問題了, 03/29 03:08
→ CoNsTaR: 也從來沒有說過你要用 tab 來取代 space,從頭到尾說的 03/29 03:08
→ CoNsTaR: 都是 tab 不要和 space 混用 03/29 03:08
→ CoNsTaR: 我有說過的話你通通不看不理解,我沒說過的話你通通指著 03/29 03:09
→ CoNsTaR: 我鼻子罵,到底哪一點讓你這麼難接受? 03/29 03:09
→ LPH66: 你的"多縮一排"是指連結文章裡 int var1 var2 這種內縮? 03/29 07:11
→ LPH66: 那篇文章裡已經明確跟你說了那種叫 alignment 限用 space 03/29 07:11
→ LPH66: 連結文章開頭那種長條件切行內縮那也是 alignment 03/29 07:13
→ LPH66: indent 只限指在大階層內縮, 多一個 {} 內縮那種是 indent 03/29 07:13
→ LPH66: 啊我知道啦, 你的"space 做的 alignment 就壞掉了"該不會是 03/29 07:14
→ LPH66: 某些編輯器會多事的幫你把所有開頭的空白全部換成 tab 那種 03/29 07:15
→ LPH66: 如果編輯器會多事這樣轉的那當然按個 tab 內縮就全幫你轉了 03/29 07:15
→ LPH66: 自然就壞光光... 03/29 07:15
→ LPH66: 當編輯器只懂得「開頭要嘛全 Tab 要嘛全 space」的時候 03/29 07:19
→ LPH66: 自然是全 space 才不壞事, 但如果編輯器不會多事那當然是 03/29 07:20
→ LPH66: 用的人有分好 indent 跟 alignment 哪個用哪個 03/29 07:20
→ LPH66: 就都不會有問題 03/29 07:20
→ Caesar08: 因為你說混用是不行的。@johnjohnlin貼的文章也說可以混 03/29 09:27
→ Caesar08: 用,也有code補充論點。既然你不同意這些觀點,那我想知 03/29 09:27
→ Caesar08: 道實際code是甚麼,你的“內縮一排”是甚麼code 03/29 09:27
噓 CoNsTaR: 根本不存在同不同意的問題,可以就是可以,不行就是不行 03/29 11:41
→ CoNsTaR: ,不要滑坡 03/29 11:41
→ CoNsTaR: 我原先的推文就已經告訴你在怎樣的情況下那樣的做法一樣 03/29 11:41
→ CoNsTaR: 不行,是你不聽不討論不理解根本不是我不講(只要 indent 03/29 11:41
→ CoNsTaR: ation 不是每行完全相同) 03/29 11:41
→ CoNsTaR: 相同的 use case 在我更之前的推文也早就已經提到過了 03/29 11:41
→ CoNsTaR: 只要某一行和其他行有不同 indentation, comments 就是 03/29 11:41
→ CoNsTaR: 不可能對齊 03/29 11:41
→ CoNsTaR: 而無法對齊的根本原因就是 space 和 tab 混用 03/29 11:51
推 yvb: 樓上,問題就是<tab>定位點用8k會對齊時,改為4k未必會對齊. 03/29 18:27
→ yvb: 但是要這樣子的方式寫註解, 又要對齊的意義是什麼? 03/29 18:30
→ yvb: 有疑慮時就規定<tab>的縮排量吧. 03/29 18:38
推 LPH66: > 只要 indentation 不是每行完全相同 03/29 18:55
→ LPH66: 所以看起來你是把所有開頭的 whitespace 全部稱為 indent 03/29 18:55
→ LPH66: 那這就是定義不同的問題不是誰不聽誰的問題了 03/29 18:56
→ LPH66: 該連結文章裡的 indent 只稱大排版 03/29 18:56
→ LPH66: 像長行切斷下面內縮這種開頭 whitespace 該文稱 alignment 03/29 18:57
→ LPH66: 那一行的內縮會有稱為 indent 跟隨大部隊的內縮 03/29 18:57
→ LPH66: 以及只有自己有為了對齊文字或顯示斷行歸屬的 alignment 03/29 18:58
→ LPH66: (這些都是該文的叫法) 你要全叫它 indent 行啊, 但就說清楚 03/29 18:59
→ LPH66: 至於 comment, comment 對齊用 whitespace 對該文來說 03/29 19:00
→ LPH66: 當然是屬於 alignment, 所以自然全得用空白 03/29 19:00
→ LPH66: 你所點出的跨 indent level 的對齊 comment 03/29 19:02
→ LPH66: 是啦, 這些對不齊沒錯, 但我不覺得在會時常改動的程式碼中 03/29 19:03
→ LPH66: 會需要時常因為改程式碼而去調整對齊 03/29 19:04
→ LPH66: 是一件舒服的事 03/29 19:04
→ LPH66: 我自己就只會在不常改的地方 (像表格) 這樣做 03/29 19:05
→ LPH66: 那種地方很少會有跨 indent level 的程式碼需要這樣 03/29 19:05
→ Caesar08: @yvb嗯,我現在才注意到就算都是tab,寬度也會有不同的 03/29 20:03
→ Caesar08: 狀況,但這應該是屬於編輯器怎麼處理tab的問題。不過既 03/29 20:03
→ Caesar08: 然每個人使用的編輯器都不同,那在這code用tab做對齊就 03/29 20:03
→ Caesar08: 是不可能的了 03/29 20:03
推 yvb: 不過我個人覺得, 在每行末端註解要對齊這種事太枝微末節了, 03/29 21:52
→ yvb: 還不如程式寫整齊,命名適當,以及函式及區段註解寫清楚就夠了. 03/29 21:54
→ yvb: 至於程式內容寫得清不清楚漂不漂亮,那則是另一件事. 03/29 21:59
推 johnjohnlin: LPH大大那種不對齊我今天才注意到有這個可能 03/30 23:20
→ johnjohnlin: 應該是這類型註解真的很少出現 03/30 23:20
→ johnjohnlin: 還要我開哪個奇怪的編輯器嗎?Microsoft word 如何 03/30 23:28
→ johnjohnlin: 我錯了,你如果這樣用的話會跑掉 03/30 23:30
推 wulouise: 我覺得程式有很多可以討論 coding style是最沒有產出的. 04/01 22:22
→ wulouise: 訂好一起用就好,至於space tab就是不要混用就沒差 04/01 22:23
→ wulouise: 大多用space的原因就是ide不會亂動space但tab不好說 04/01 22:24
推 CoNsTaR: @LPH66 那篇文章對 alignment 和 indentation 的定義和 04/01 23:45
→ CoNsTaR: 我沒有不一樣啊 @@ 04/01 23:45
推 CoNsTaR: 我也沒有要 promote 把 comments 寫在行尾,我只是試圖 04/01 23:48
→ CoNsTaR: 用例子解釋當你用 space 去 makeup 另一行的 tab,或是 04/01 23:48
→ CoNsTaR: 用 tab 去 makeup 另一行的 space 的時候 alignment 就無 04/01 23:48
→ CoNsTaR: 法被保證 04/01 23:48
→ LPH66: 老實說我也是邊想邊回打字到一半才發現你在強調這個 04/02 04:50
→ LPH66: 所以後來才補了為什麼我不會去用這種會造成問題的寫法 04/02 04:51
推 wulouise: 我大概懂意思 如果有一行註解是\t\t//^^^^ magic 04/02 22:47
→ wulouise: 你要怎麼樣確保magic指到的位置是對的...應該是無解XD 04/02 22:48
推 timofEE: 對齊的問題好一點的IDE會幫你處理好 04/03 04:05
→ timofEE: space跟tab也是 但就是會被寵壞 04/03 04:05
→ timofEE: 已經好幾次程式跑不起來結果是有幾行是tab或空格 04/03 04:05
→ timofEE: 反正我現在一律養成用space了 04/03 04:05
推 johnjohnlin: 樓上可是這裡不是python版(? 04/03 12:34
推 lc85301: 我都用 clang-format 沒在管排版 (owo) 04/05 13:22
推 Lhmstu: 把tab換成幾個空白不就好了,想設幾個就設幾個 04/24 02:21