Bài viết được dịch từ blog Coding Horror
Một trong những đề tài trung tâm của stackoverflow.com đó là nhiều nhà phát triển phần mềm không còn học lập trình từ những cuốn sách nữa, như Joel đã đề cập:
Các lập trình viên ngày nay dường như không còn đọc sách nữa. Thị trường sách về các chủ đề lập trình thì quá nhỏ khi đem so sánh với số lượng các lập trình viên đang làm việc.
Joel cũng đã nói rõ ý kiến tương tự vào năm 2004 trong một bài viết có tên là The Shlemiel Way of Software:
Phần lớn mọi người vẫn không chịu đọc. Hoặc viết. Phần lớn các lập trình viên không chịu đọc các cuốn sách về phát triển phần mềm, họ cũng không chịu đọc các trang web về phát triển phần mềm, họ thậm chí còn không đọc cả các trang như Slashdot.
Là một lập trình viên thì tôi có nên thường xuyên đọc sách?Nếu ngày nay các lập trình viên không học từ các cuốn sách, thì làm thế nào để họ học lập trình được? Họ làm việc này theo cách đã lỗi thời: là cứ việc xắn tay áo của họ lên và hùng hục viết code – trong khi tìm kiếm giải pháp cho vấn đề họ đang gặp phải trên internet trong một cửa sổ thứ hai. Internet đã làm cho những cuốn sách lập trình trở nên lỗi thời. Nó thì nhanh hơn, hiệu quả hơn, hay chỉ đơn giản là thông minh hơn để tìm được thông tin về lập trình bạn muốn trên môi trường trực tuyến. Tôi tin vào kinh nghiệm của Doug McCune, khi anh ta nêu ra một số lý do khá điển hình trong bài viết Lý Do Tại Sao Tôi Không Đọc Sách.
Tôi liệt kê ra đây một phần của những chỉ trích gay gắt đối với những vấn đề trong ngành xuất bản sách kỹ thuật của chúng ta:
- Hầu hết các cuốn sách về lập trình đều rất cùi bắp. Điều kiện để trở thành một tác giả viết sách, thì tôi có thể nói là gần như không tồn tại. Với sự hỗn loạn của ngành xuất bản sách thì người ta có thể xem rằng nó cũng chả tốt đẹp gì hơn cái mà bạn tìm thấy trên môi trường hoang dã của internet. Có hàng trăm cuốn sách về lập trình được xuất bản mỗi năm, và có lẽ chỉ có từ 2 đến 3 cuốn trong số đó là có giá trị thực sự để bạn đầu tư thời gian vào đọc.
- Các cuốn sách lập trình giờ đây được bán theo cân nặng (kiểu bán ve chai), chứ không bởi giá trị của nó. Dường như có một mối quan hệ nghịch lý giữa độ dày của một cuốn sách và chất lượng của nó. Cuốn sách càng dày, thì càng có ít thông tin hữu ích được chứa trong đó. Liệu đó có phải là đặc điểm của những cuốn sách khổng lồ dạng tham khảo toàn tập? Bạn có tìm được bất cứ thứ gì ở trong đó không, hay là toàn những thứ vớ vẩn?
- Những cuốn sách lập trình đa số là kiểu “mì ăn liền” nhắm đến đối tượng lập trình viên mới vào nghề. Tôi không có ý chống lại những người mới tham gia vào lĩnh vực lập trình. Nhưng tôi tiếp tục tin rằng vô số cuốn sách dạng “Học [bổ sung ngôn ngữ lập trình vào đây] trong 24 giờ!” đang làm hại nghề nghiệp của chúng ta. Việc cứ chăm chăm vào các giải phápăn liền và nhanh nhất, dễ dàng nhất có thể thì sẽ dẫn những người mới bắt đầu vào một con đường sai lầm – hoặc tôi thích gọi nó là, “PHP”. Tôi đùa đấy! Tôi nói giỡn chút thôi!
- Sách lập trình mà cứ như là sách báo khiêu dâm vậy. Nhiều người cứ sưu tập một đống sách dày cộp, gồm rất nhiều các cuốn sách về lập trình trông có vẻ quan trọng trên giá sách, phần lớn là chưa đọc, và hy vọng bằng cách nào đó nó sẽ khiến bạn trở thành một lập trình viên giỏi hơn. Như David Poole một lần trước đây đã viết cho tôi trong email rằng, “Tôi sẽ chẳng bao giờ làm điều đó trong thế giới thực”, nó giống như là một đống sách lập trình với chủ đề khiêu dâm vậy. Đấy là lý do tại sao tôi đã cân nhắc, và từ chối mua cuốn sách “Art of Computer Programming” của tác giả Knuth. Hãy mua những cuốn sách về thực hành để bạn sẽ thực sự đọc, và điều quan trọng hơn là chuyển nó vào hành động.
Là một tác giả viết sách, tôi cũng cảm thấy tội lỗi. Tôi là đồng tác giả của một cuốn sách lập trình, và tôi vẫn không nghĩ rằng bạn nên mua nó. Tôi không nói điều này với mục đích nói ngược để dụ bạn mua sách của tôi. Ý tôi là cuốn sách đó thì tương đối bình thường. Nó không phải là một cuốn sách tồi theo bất kỳ hình thức nào. Tôi luôn có sự tôn trọng rất lớn dành cho những người đồng tác giả kính mến của mình. Nhưng những thông tin tương tự trong cuốn sách thì bạn có thể truy cập ở nhiều nơi trên web. Việc gom tất cả vào trong một cuốn sách như vậy thì cuối cùng chỉ là một việc tốn công mất sức.
Internet chắc chắn đã đẩy nhanh sự thoái trào của những cuốn sách lập trình, nhưng có một vài bằng chứng rằng, thậm chí trước thời có internet thì các lập trình viên cũng không đọc nhiều sách về lập trình. Tôi đã khá ngạc nhiên khi đọc được đoạn sau đây trong cuốn sách nổi tiếng Code Complete:
Nếu bạn đang đọc cuốn sách này thì bạn đang học nhiều hơn hầu hết mọi người trong ngành công nghiệp phần mềm, bởi vì hầu hết các lập trình viên đọc ít hơn một cuốn sách mỗi năm(tác giả DeMarco và Lister 1999). Việc đọc một chút sẽ giúp bạn tiến một bước dài về phía trước trong sự nghiệp của mình. Nếu bạn đọc thậm chí chỉ một cuốn sách lập trình chất lượng mỗi hai tháng, hay xấp xỉ 35 trang sách một tuần, thì bạn sẽ sớm có một chỗ đứng vững chắc trong ngành công nghiệp này và khiến bạn nổi trội hơn so với đám đồng nghiệp xung quanh.
Tôi tin rằng đoạn trích đó cũng có trong phiên bản đầu tiên của cuốn sách Code Complete vào năm 1993, nhưng tôi không còn giữ một bản copy của nó để xác nhận lại điều đó. Qua một chút tìm kiếm thì tôi đã khám phá ra một đoạn của Steve McConnell được trích trong cuốn sách Peoplewarecủa hai tác giả DeMarco và Lister như sau:
Thống kê về việc đọc sách làm cho chúng ta vô cùng nản lòng: Các nhà phát triển phần mềm trung bình, thường không sở hữu một cuốn sách nào về chủ đề mà anh ta hoặc cô ta đang làm việc, và chưa bao giờ đọc một cuốn nào cả. Thực tế đó làm kinh hãi bất kỳ ai quan tâm đến chất lượng công việc trong lĩnh vực này; và cho những ai đang viết sách như chúng tôi, đó thực sự là một tấn bi kịch.
Tôi đã khổ tâm lẫn dằn vặt rất nhiều khi đọc được những lời bình luận trên mạng xã hội Reddit và biết được rằng mọi người đang hiểu tuyên bố sứ mệnh về “đứa con” của tôi là stackoverflow.comnhư là một sự phủ nhận những cuốn sách lập trình. Có nhiều cảm xúc trái ngược trong tôi về thị trường sách lập trình hiện nay, tôi yêu các cuốn sách lập trình! Mỗi blog mà tôi tạo ra đều dựa trên khái niệm từ danh sách những cuốn sách nên đọc mà tôi đã giới thiệu đến các lập trình viên. Nhiều bài viết trên blog này là tôi đang cố gắng giải thích theo cách của mình về các khái niệm quan trọng được đề cập từ lâu ở trong các cuốn sách lập trình kinh điển đó.
Làm thế nào để tôi có thể dung hòa những điều tưởng chừng như mâu thuẫn đó, tôi nên yêu hay nên ghét sự biến động này? Bạn biết đấy, có những cuốn sách lập trình, và cũng có những cuốn sách lập trình. Những cuốn sách lập trình tốt nhất là những cuốn sách bất tử. Chúng vượt quá việc lựa chọn ngôn ngữ, IDE, hoặc nền tảng nào đó. Chúng không giải thích cho câu hỏi như thế nào, mà giải đáp cho câu hỏi tại sao. Nếu bạn cảm thấy bị thôi thúc để dọn bớt giá sách của mình cứ mỗi 5 năm, thì tin tôi đi, bạn đang mua nhầm phải những cuốn sách lập trình tồi rồi đó.
Tôi sẽ không bán kệ sách lập trình của mình với bất cứ giá nào. Tôi tham khảo chúng hầu như mọi lúc mọi nơi. Thực ra, tôi đã tham khảo nó hai lần trong khi viết mỗi bài trên blog này.
Tôi sẽ không giải thích thêm về sự quan trọng của danh sách những cuốn sách mà tôi đã đề nghị bạn nên đọc, cũng như tôi luôn giữ gìn nó như một niềm kiêu hãnh trong nhiều năm qua.
(Cập nhật: Một người bạn tên là Tim Spalding tốt bụng đã tạo một tài khoản thay mặt cho tôi trên trang LibraryThing – và các thành viên ở đó đã liệt kê tất cả các cuốn sách có trong bức hình về kệ sách của tôi. Thật là ấn tượng, và khá tuyệt!)
Nhưng tôi cũng xin nói rõ là: top 5 cuốn sách lập trình của mình mà tôi nghĩ mọi lập trình viên đang làm việc nên sở hữu – và đọc. Những cuốn sách này là hạt giống để làm phong phú thêm cả lý thuyết lẫn thực tiễn, từ năm này sang năm khác, bất kể là tôi đang làm về dạng lập trình nào. Mỗi lần đọc thì chúng càng mang lại nhiều giá trị sâu sắc hơn và nhiều sự tinh tế của kỹ nghệ phần mềm đến với tôi, mặc dù đã lăn lộn nhiều năm kinh nghiệm trong nghề này. Nếu bạn vẫn chưa đọc những cuốn sách này, thì bạn đang đang còn chờ đợi điều chi?
Code Complete 2![]() | Don’t Make Me Think![]() |
Peopleware ![]() | Pragmatic Programmer![]() |
Facts and Fallacies![]() |
Mục đích lớn nhất của tôi là biến stackoverflow.com như là một phần bổ sung cho những cuốn sách lập trình kinh điển và bất tử nói trên. Không có cách thức, hình dạng hay khuôn mẫu nào có thể thay thế cho chúng được cả.
Một mặt khác, nếu bạn không may lại là tác giả của cuốn sách “Perl for Dummies”, thì hãy ngoảnh lại nhìn phía sau lưng mình, bởi vì chúng tôi rõ ràng đang chĩa súng về phía bạn đấy anh bạn ạ!
Các bài viết liên quan:
- Tầm quan trọng của việc đọc sách đối với lập trình viên
- 10 Lợi ích của việc đọc: Tại sao bạn nên đọc sách mỗi ngày
- Làm IT nên đọc ebook của nhà xuất bản nào?
- Điểm yếu của các bạn trẻ khởi nghiệp tại Việt Nam là tiếng Anh
- Thiết kế website đúng cách với 5 cuốn sách
Về tác giả bài viết:Jeff Atwood là một chuyên gia công nghệ tại Mỹ, hiện đang sinh sống và làm việc tại Berkeley, CA. Anh là một kỹ sư phần mềm chuyên về công nghệ Microsoft .NET, và là một blogger nổi tiếng trong cộng đồng công nghệ với blog Coding Horror, anh là người sáng lập và kiêm Giám đốc điều hành (CEO) của trang web hỏi đáp uy tín Stack Overflow và cũng là đồng sáng lập của Stack Exchange và Discourse.





Jeff Atwood
Những cuốn sách lập trình tốt nhất là những cuốn sách bất tử. Chúng vượt quá việc lựa chọn ngôn ngữ, IDE, hoặc nền tảng nào đó. Chúng không giải thích cho câu hỏi như thế nào, mà giải đáp cho câu hỏi tại sao. Nếu bạn cảm thấy bị thôi thúc để dọn bớt giá sách của mình cứ mỗi 5 năm, thì tin tôi đi, bạn đang mua nhầm phải những cuốn sách lập trình tồi rồi đó.
ReplyDelete