Tags:

ได้ไปอ่านมา web หนึ่งเห็นเขาเขียนได้ดี เเละแฝงไว้ข้อคิดดีอะคะ (บางทีหมั่นไส้พวกโปรแกรมเมอร์เห็นแก่ตัวอะ เหอๆๆ...อิอิอิ) . . . . .

1.โปรแกรมแบบพอเพียง(ทำอะไรให้เล็กที่สุดเท่าที่เป็น ไปได้)

2.ทำสิ่งธรรมดาให้ง่าย ทำสิ่งยากให้เป็นไปได้

3.จงโปรแกรมโดยนึกว่าจะมีคนมาทำต่ออย่างแน่นอน

4.ระเบียบ กฏข้อบังคับ เชื่อมั่นไม่ได้แล้ว ถ้ามีเพียงหนึ่งโมดูลไม่ปฏิบัติตาม

5.ตัดสินใจให้ดีระหว่างความชัดเจน(clearance) กับ การขยายได้(extensibility)

6.อย่าเชื่อมั่น output จากโมดูลอื่น ถึงแม้เราจะเป็นคนเขียนเอง

7.ถ้าคนเขียนยังเข้าใจได้ยาก แล้วคนอ่านจะเข้าใจได้ยากกว่าแค่ไหน

8.ค้นหาข้อมูลสามวันแล้วทำหนึ่งวัน หรือจะทำสามวันแล้วแก้บั๊กตลอดไป

9.จงสร้างเครื่องมือ ก่อนทำงาน

10.อย่าโทษโมดูลอื่นก่อน โดยเฉพาะถ้าโมดูลอื่นเป็น OS และ Compiler

11.พยายามทำตามกฏ แต่ถ้ามีข้อยกเว้น ต้องมีอย่างหลีกเลี่ยงไม่ได้ แล้วประกาศและตะโกนให้ดังที่สุด

12.High cohesion Loose coupling. (ยึดเกาะให้สูงสุดในโมดูล และ เกาะเกี่ยวกับโมดูลอื่นให้น้อยที่สุด)

13.ให้สิ่งที่เกี่ยวข้องกันยิ่งมากอยู่ไกล้กันมากที่ สุด

14.อย่าเชื่อโดยไม่พิสูจน์

15.อย่าลองทำแล้วคอมไพล์ดู ถ้าเราไม่ได้คาดหวังผลลัพธ์อะไรไว้ (อย่างเช่นปัญหา index off by one)

16.จงกระจายความรู้เพราะนั่นคือการทำ Unit Test ระดับล่างสุด(ระดับความคิด)

17.อย่าเอาทุกอย่างใส่ใน UI เพราะ UI คือส่วนที่ Unit Test ได้ยาก

18.ทั้งโปรเจ็คต์ควรไปในทางเดียวกันมากที่สุด( Consistency )

19.ถ้ามีสิ่งที่ดีอยู่แล้วจงใช้มัน อย่าเขียนเอง ถ้าจำเป็นต้องเขียนเอง ให้ศึกษาจากข้อผิดพลาดในอดีตก่อน

20.อย่ามั่นใจเอาโค้ดไปใช้จนกว่าจะ test อย่างเพียงพอ

21.เอาโค้ดที่ test ไว้ที่เดียวกันกับโค้ดที่ถูก test เสมอ

22.ทุกครั้งที่แก้ไขโค้ดให้ run unit test ทุกครั้ง

23.จงใช้ Unit Test แต่อย่าเชื่อมั่นทุกอย่างใน Unit Test เพราะ Unit Test ก็ผิดได้

24.ถ้าต้องทำอะไรที่ซ้ำกันมากกว่าหนึ่งครั้ง ก็เพียงพอแล้วที่จะแยกโค้ดส่วนนั้นออก

25.ทำให้ใช้งานได้ก่อน แล้วค่อย optimize และถ้าไม่จำเป็น อย่าoptimize

26.ยิ่งประสิทธิภาพเพิ่ม ความเข้าใจง่ายจะลดลง

27.ใช้ Design Pattern ที่เป็นที่รู้จักจะได้คุยกับใครได้รู้เรื่อง

28.อย่าเก็บไว้ทำทีหลัง ถ้ายังไงก็ต้องทำ

29.MutiThreading ไม่ใช่แค่การเพิ่มประสิทธิภาพ แต่มันมาพร้อมกับ Concerency, Deadlock, IsolationLevel, Hard to debug, Undeterministic Errors.

30.จงทำอย่างโจ่งแจ้ง

31.อย่าเพิ่ม technology โดยไม่จำเป็น เพราะนั่นทำให้โปรแกรมเมอร์ต้องวุ่นวายมากขึ้น

32.จงทำโปรเจ็คต์ โดยคิดว่าความเปลี่ยนแปลงเกิดขึ้นได้เสมอ

33.อย่าย่อชื่อตัวแปรถ้าไม่จำเป็น เดี๋ยวนี้ IDE มันช่วยขึ้นเยอะแล้วไม่ต้องพิมพ์เองแค่ dot มันก็ขึ้นมาให้เลือก

34.อย่าใช้ i, j , k , result, index , name, param เป็นชื่อตัวแปร

35.ทำโค้ดที่ต้องสื่อสารผ่านเครือข่ายให้คุยกันน้อยท ี่สุด

36.แบ่งแยกดีดี ระหว่าง Exception message ในแต่ละเลเยอร์ ว่าต้องการบอกผู้ใช้ หรือ บอกโปรแกรมเมอร์

37.ที่ระดับ UI ต้องมี catch all exception เสมอเพื่อกรอง Exception ที่ลืมดักจับ

38.ระวัง คอลัมภ์ allow null ใน database ดีดี ค่า มัน convert ไม่ได้

39. อย่าลืมว่า Database เป็น global variable ประเภทหนึ่ง แต่ละโปรแกรมที่ติดต่อเปรียบเหมือน MultiThreading ดังนั้นกฏของ Multithreading ต้องกระทำเมื่อทำงานกับ Database

40.ระวังอย่าให้ logic if then else ซ้อนกันมากมาก เพราะสมองคนไม่ใช่ CPU จินตนาการไม่ออกหรอกว่ามันอยู่ตรงไหนเวลา Debug (ถ้ามากกว่าสามชั้นก็ลองคิดใหม่ดูว่าเขียนแบบอื่นได้ มั้ย)

41.ระวังอย่าให้ลูปซ้อนกันมากมาก ไม่ใช่แค่เรื่องความเร็วอย่างเดียว เวลา Debug เราคิดตามมันไม่ได้ (ถ้าเกินสามชั้นก็ไม่ไหวแล้ว)

42. อย่าใช้ Magic Number ใน Code เช่น if( controlingValue == 4 ) เปลี่ยนไปใช้ Enum ดีกว่า เป็น if( controlingValue == ControllingState.NORMAL ) เข้าใจง่ายกว่ามั้ย

43.ถ้าจะเปรียบเทียบ string Trim ซ้ายขวาก่อนเสมอ

44.คิดหลายๆ ครั้งก่อนใช้ Trigger

45.โปรแกรมเมอร์คือห่วงโซ่สุดท้ายของมลพิษทางความซับ ซ้อน ดังนั้นหา project leader ดีดีแล้วกัน

46. มนุษย์ฉลาดกว่าคอมพิวเตอร์ การเขียนโปรแกรมก็คือการสอนให้คอมพิวเตอร์ฉลาดได้เหม ือนเรา (มนุษย์ฉลาดกว่าคอมพิวเตอร์จริงๆนะ) Reply With Quote

47. จงควบคุมคอม มิใช่ให้คอมควบคุมเรา เราต้องสั่งให้คอมทำงาน ไม่ใช่ให้เราทำงานตามคอมสั่ง

48. อย่าปล่อยให้ข้อจำกัดของคอม มาจำกัดความคิดของเรา [คอมไม่ดีเปลี่ยนเครื่องเลย 55+]

49. ยอมรับความคิดของผู้อื่น แต่อย่าออกจากกรอบของตนเอง

50. หมั่น Save โปรแกรมไว้อย่าสม่ำเสมอ ก่อนที่จะไม่มีโอกาส Save [จะให้ดี Save เป็นแต่ละ Version เลย]

Get latest news from Blognone
By: panuta
iPhone
on 7 May 2006 - 23:18 #6597

"3.จงโปรแกรมโดยนึกว่าจะมีคนมาทำต่ออย่างแน่นอน"

อืม .. ตรงนี้ยังไม่ทำดีกว่า เดี๋ยวก็มีคนทำต่อ อืม .. ตรงนี้ทำไปเท่านี้พอ เดี๋ยวมีเพิ่ม คนที่ทำต่อเค้าก็ทำเอง อืม .. ตรงนี้ยังมี bug เดี๋ยว comment ไว้หน่อยนึง ... หน่อยนึง อืม .. ว่าแล้วก็ไปปิดเบอร์โทร แล้วเปลี่ยน email ดีกว่า


http://www.seasandsong.com/

By: TiD
AndroidWindows
on 8 May 2006 - 19:35 #6614

อยากให้คนทำโปรเจคท์ที่ผมต้องทำต่อ มาอ่านซะบ้าง

By: adkdev on 8 May 2006 - 22:40 #6621

34.อย่าใช้ i, j , k , result, index , name, param เป็นชื่อตัวแปร

อยากทราบว่าทำไม่ถึง ห้ามใช้ i,j,k เป็นตัวแปรครับ เพราะเห็นโค๊ดทั่วไปก็ใช้นิครับ

สงสัยจัง ??? ช่วยบอกเหตุผลทีครับ

By: keng
WriteriPhoneAndroidIn Love
on 8 May 2006 - 22:46 #6623
keng's picture

34.อย่าใช้ i, j , k , result, index , name, param เป็นชื่อตัวแปร

อุ๊ยตาย...T_T อายจัง

By: plynoi
WriterAndroidUbuntu
on 8 May 2006 - 23:43 #6625

index ก็โดน T_T

By: plynoi
WriterAndroidUbuntu
on 8 May 2006 - 23:45 #6626

adkdev ถ้าโปรแกรมใหญ่ๆ มันจะไม่สื่อครับ ว่าหมายถึงอะไร ยิ่งถ้าซ้อนๆกันยิ่งงง ผมเคยเจอ VB.NET ประกาศใน Module Public i as Integer...... TiD ู^ ^ อิๆ พอมีคนเีขียนต่อจากเรา เค้าก็บ่นอย่างเดียวกัน :P

By: deans4j on 9 May 2006 - 02:18 #6634

ผมว่าไม่เสมอไปหรอกครับ i,j,k,index,result เนี้ยะ

i,j,k,index มันเอาไว้นำเสนอ index ใน collection จริงๆ ซึ่งมันก็สมเหตุสมผลที่จะใช้ ตามหลักการเขียนคณิตศาสตร์ อย่างการใช้ ซิกม่า เราจะแทน element แต่ละตัวด้วย i,j,k หรือ x,y,z กันประจำ อยู่แล้ว

By: DrRider
WriterAndroid
on 9 May 2006 - 08:45 #6644
DrRider's picture

อีกอย่าง i กับ j ใช้เป็น complex number ด้วยรึเปล่า


We need to learn to forgive but not forget...

By: Gmz
Windows PhoneAndroid
on 23 May 2006 - 01:16 #6983

ผมชอบทำแบบฝรั่งมากกว่า คือ ใส่ comment บอกไปเลยว่า กำลังทำอะไร และตัวแปรในนี้แต่ตัวหมายถึงอะไร เคยเห็น /* * * * * */

ยาว ๆ ของพวกฝรั่งไหมอ่ะครับ ผมว่ามันดีมาก ๆ เลยล่ะ ทำให้รู้ว่าจะใช้อย่างไร

By: mr_tawan
ContributoriPhoneAndroidWindows
on 20 April 2013 - 02:34 #564059 Reply to:6983
mr_tawan's picture

(เห็นมีคนเม้นต่อข้างล่างเลยเม้นบ้าง 55)

การใส่ comment เยอะ ๆ เป็นการทำให้โค๊ดสกปรก (pollute) ครับ ควรใส่เฉพาะกรณีที่ไม่สามารถเขียนโค๊ดให้ชัดเจนพอได้เท่านั้น (อ้างอิงจาก Clean Code)

เหตุผลคือเรามักจะแก้โค๊ด แต่ไม่แก้คอมเม้นท์ โดยเฉพาะถ้ารีบ ๆ แต่เรามักจะอ่านคอมเม้น ไม่อ่านโค๊ด เวลาจะเอาโค๊ดไปใช้งาน ถ้าเกิดว่าเอาโค๊ดไปใช้ไม่ระวัง โค๊ดกับคอมเม้นท์ไม่ตรงกัน กว่าจะหาเจอว่าเกิดจากอะไรมันจะมึนมาก แล้วสุดท้ายก็จะไปด่าคนคอมเม้นว่า "จะคอมเม้นทำไมเนี่ย ..."


  • 9tawan.net บล็อกส่วนตัวฮับ
By: plynoi
WriterAndroidUbuntu
on 23 May 2006 - 18:44 #6986

Gmz อ่านเจอ "ยาวๆ ของพวกฝรั่ง" ตกใจเลย เหอๆๆ ผมก็ใช้แบบนั้นนะ เขียนลงไปเลย

By: panitw
Windows Phone
on 19 April 2013 - 23:07 #564007
panitw's picture

ข้อ 50. นี่ใช้ Source Control ดีกว่ามั้ย SVN, Git, Mercurial, ...