TURI BLOG

[Nomad Coders Challenge] Clean Code - Assignment #10 ๋ณธ๋ฌธ

Nomad Coders

[Nomad Coders Challenge] Clean Code - Assignment #10

TURI BLOG 2024. 12. 10. 11:02

 

๐Ÿ“ It is part of a book club challenge on a programming learning website called Nomad Coders. The challenge is to demonstrate what I have learned after reading Clean Code by Robert C. Martin.

 

๐Ÿ“ It will consist of the following sections over three weeks: the range of reading, the top quotes from the book, my review, and remaining questions. 

  ๐Ÿ”—Challenge Schedule


๐Ÿ’ป I plan to read Clean Code in JavaScript and Python, referring to the GitHub repositories shared by Nomad Coders with the challengers.

 

Assignment #10

  • ๐Ÿ“š Chapter 7. Error Handling (Michael Feathers)
  • โœ”๏ธ TIL 
    • Top quotes from the book
    • Case study in JavaScript
    • Remaining questions

 

๐Ÿ“ Top quotes from the book

  • ์˜ค๋ฅ˜ ์ฒ˜๋ฆฌ๋Š” ํ”„๋กœ๊ทธ๋žจ์— ๋ฐ˜๋“œ์‹œ ํ•„์š”ํ•œ ์š”์†Œ ์ค‘ ํ•˜๋‚˜. ๊นจ๋—ํ•˜๊ณ  ํŠผํŠผํ•œ ์ฝ”๋“œ๋ฅผ ์œ„ํ•œ ์˜ค๋ฅ˜ ์ฒ˜๋ฆฌ ๊ธฐ๋ฒ•๊ณผ ๊ณ ๋ ค ์‚ฌํ•ญ.
    • ์˜ˆ์™ธ ์‚ฌ์šฉ: ์—๋Ÿฌ ๋ฐœ์ƒ ์‹œ -> ์˜ˆ์™ธ
    • Try-Catch-Finally ๋ฌธ๋ถ€ํ„ฐ ์ž‘์„ฑ:
      • try ๋ธ”๋ก์—์„œ ๋ฌด์Šจ์ผ์ด ์ƒ๊ธฐ๋“  catch๋ธ”๋ก์€ ํ”„๋กœ๊ทธ๋žจ ์ƒํƒœ๋ฅผ ์ผ๊ด€์„ฑ ์žˆ๊ฒŒ ์œ ์ง€ํ•  ๊ฒƒ์ด๊ธฐ ๋•Œ๋ฌธ์—. try-catch ๊ตฌ์กฐ๋กœ ๋ฒ”์œ„๋ฅผ ์ •์˜ํ–ˆ์œผ๋ฏ€๋กœ TDD(Test-driven deveploment)๋ฅผ ์‚ฌ์šฉํ•ด ํ•„์š”ํ•œ ๋‚˜๋จธ์ง€ ๋…ผ๋ฆฌ๋ฅผ ์ถ”๊ฐ€ํ•œ๋‹ค. ๋จผ์ € ๊ฐ•์ œ๋กœ ์˜ˆ์™ธ๋ฅผ ์ผ์œผํ‚ค๋Š” ํ…Œ์ŠคํŠธ ์ผ€์ด์Šค๋ฅผ ์ž‘์„ฑํ•œ ํ›„ ํ…Œ์ŠคํŠธ๋ฅผ ํ†ต๊ณผํ•˜๊ฒŒ ์ฝ”๋“œ๋ฅผ ์ž‘์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ๊ถŒ์žฅํ•œ๋‹ค. 
    • ์˜ˆ์™ธ์— ์˜๋ฏธ ์ œ๊ณต: ์—๋Ÿฌ ๋ฐœ์ƒ ์›์ธ ๋ฐ ์œ„์น˜ ํ™•์ธ ์‰ฝ๋„๋ก -> ์˜ˆ์™ธ์˜ ์ „ํ›„ ์ƒํ™ฉ ๋”ํ•  ๊ฒƒ - ์—๋Ÿฌ ์—ฐ์‚ฐ ์ด๋ฆ„, ์—๋Ÿฌ ์œ ํ˜• ๋“ฑ์˜ ์ •๋ณด
    • ํ˜ธ์ถœ์ž๋ฅผ ๊ณ ๋ คํ•œ ์˜ˆ์™ธ ํด๋ž˜์Šค ์ •์˜
      • ์—๋Ÿฌ ๋ถ„๋ฅ˜ ๋ฐฉ๋ฒ• 
        • ์—๋Ÿฌ ๋ฐœ์ƒ ์œ„์น˜๋กœ ๋ถ„๋ฅ˜ - ์—๋Ÿฌ๊ฐ€ ๋ฐœ์ƒํ•œ ์ปดํฌ๋„ŒํŠธ๋กœ ๋ถ„๋ฅ˜ 
        • ์—๋Ÿฌ ์œ ํ˜•์œผ๋กœ ๋ถ„๋ฅ˜ - ๋””๋ฐ”์ด์Šค ์‹คํŒจ, ๋„คํŠธ์›Œํฌ ์‹คํŒจ, ํ”„๋กœ๊ทธ๋ž˜๋ฐ ์˜ค๋ฅ˜ ๋“ฑ์œผ๋กœ ๋ถ„๋ฅ˜
      • ์—๋Ÿฌ ์ •์˜ ์‹œ, ์—๋Ÿฌ๋ฅผ ์žก์•„๋‚ด๋Š” ๋ฐฉ๋ฒ•์ด ์ค‘์š” 
      • LocalPort ํด๋ž˜์Šค์ฒ˜๋Ÿผ ACMEPort๋ฅผ ๊ฐ์‹ธ๋Š” ํด๋ž˜์Šค๋Š” ๋งค์šฐ ์œ ์šฉํ•˜๋‹ค. ์‹ค์ œ๋กœ ์™ธ๋ถ€ API๋ฅผ ์‚ฌ์šฉํ•  ๋•Œ๋Š” ๊ฐ์‹ธ๊ธฐ(wrapper) ๊ธฐ๋ฒ•์ด ์ตœ์„ ์ด๋‹ค. ์™ธ๋ถ€ API๋ฅผ ๊ฐ์‹ธ๋ฉด ์™ธ๋ถ€ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€ ํ”„๋กœ๊ทธ๋žจ ์‚ฌ์ด์— ์˜์กด์„ฑ์ด ํฌ๊ฒŒ ์ค„์–ด๋“ ๋‹ค. ๋‚˜์ค‘์— ๋‹ค๋ฅธ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋กœ ๊ฐˆ์•„ํƒ€๋„ ๋น„์šฉ์ด ์ ๋‹ค. ๋˜ํ•œ ๊ฐ์‹ธ๊ธฐ ํด๋ž˜์Šค์—์„œ ์™ธ๋ถ€ API๋ฅผ ํ˜ธ์ถœํ•˜๋Š” ๋Œ€์‹  ํ…Œ์ŠคํŠธ ์ฝ”๋“œ๋ฅผ ๋„ฃ์–ด์ฃผ๋Š” ๋ฐฉ๋ฒ•์œผ๋กœ -> ํ”„๋กœ๊ทธ๋žจ ํ…Œ์ŠคํŠธ์—๋„ ์šฉ์ด
    • ์ •์ƒํ๋ฆ„ ์ •์˜
        • Special Case Pattern(ํŠน์ˆ˜ ์‚ฌ๋ก€ ํŒจํ„ด) : ํด๋ž˜๋ฅผ ๋งŒ๋“ค๊ฑฐ๋‚˜ ๊ฐ์ฒด๋ฅผ ์กฐ์ž‘ํ•ด ํŠน์ˆ˜ ์‚ฌ๋ก€๋ฅผ ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ์‹ -> ํด๋ผ์ด์–ธํŠธ ์ฝ”๋“œ๊ฐ€ ์˜ˆ์™ธ์  ์ƒํ™ฉ ์ฒ˜๋ฆฌ ํ•„์š”X, ํด๋ž˜์Šค๋‚˜ ๊ฐ์ฒด๊ฐ€ ์˜ˆ์™ธ์ ์ธ ์ƒํ™ฉ์„ ์บก์Šํ™”ํ•ด์„œ ์ฒ˜๋ฆฌํ•˜๋ฏ€๋กœ. 
        // BAD
        try {
            MealExpenses expenses = expenseReportDAO.getMeals(employee.getID());
            m_total += expense.getTotal();
        } catch (MealExpensesNotFound e) {
            m_total += getMealPerDiem();
        }
        
        // GOOD
        MealExpenses expenses = expenseReportDAO.getMeals(employee.getID());
        m_total += expenses.getTotal();
        
        public class PerDiemMealExpenses implements MealExpenses {
            public int getTotal() {
                // Returns a default daily meal expense
            }
        }

 

 

๐Ÿ•ต  Case study in JavaScript based on @ryanmcdermott 's Clean Code JavaScript GitHub repository

 

๐Ÿ” Remaining questions

  • Try-Catch-Finally
  • TDD - 'try-catch ๊ตฌ์กฐ๋กœ ๋ฒ”์œ„๋ฅผ ์ •์˜ํ–ˆ์œผ๋ฏ€๋กœ TDD๋ฅผ ์‚ฌ์šฉํ•ด ํ•„์š”ํ•œ ๋‚˜๋จธ์ง€ ๋…ผ๋ฆฌ๋ฅผ ์ถ”๊ฐ€ํ•œ๋‹ค.'
  • OCP(Open Closed Principle)
  • Special Case Pattern(ํŠน์ˆ˜ ์‚ฌ๋ก€ ํŒจํ„ด) : ํด๋ž˜๋ฅผ ๋งŒ๋“ค๊ฑฐ๋‚˜ ๊ฐ์ฒด๋ฅผ ์กฐ์ž‘ํ•ด ํŠน์ˆ˜ ์‚ฌ๋ก€๋ฅผ ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ์‹

 

 

 

Comments