[CR] บะหมี่เกี้ยว อาคารชินพงษ์ ถนนลาดหญ้า

วันนี้หลังจากไม่ได้กินบะหมี่เกี้ยวร้านลุงมานานมากก วันนี้ได้กลับมากินแล้ว ผมเลยอยากจะมาแนะนำกับครับ ร้านบะหมี่เกี้ยวร้านนี้ อยู่ตรง ถนนลาดหญ้า ซอยลาดหญ้า 9  อาคารชินพงษ์ครับ สำหรับราคาถูกมากครับ ในยุคสมัยที่ข้าวแกงใน กทม เฉลี่ยจานะ 45 บาท โดยราคาของบะหมี่เกี้ยวเจ้านี้ ธรรมดา 25 บาท พิเศษ 30 บาท  

Best Practices คำแนะนำที่เรียบง่าย แต่มีที่มาที่ล้ำลึก

Best Practices คำแนะนำที่เรียบง่าย แต่มีที่มาที่ล้ำลึก โดยเวลาที่เราเขียนโปรแกรม เราอาจจะโดนจำกัดการใช้ตัวแปร ให้เขียน Code ตามรูปแบบที่ SA กำหนดไว้ ต้องเขียน Code เป็นชั้นๆ อาทิ เช่น Presenter, Business Logic, Data Access และแต่ละชั้นต้องเชื่อมกันผ่าน Interface แต่ถ้าลองมาศึกษาลึกๆแล้ว ทุกอย่างมีที่มาที่ไป แต่ถ้าจะลงลึกไป อธิบายผลดี/ผลเสียมันอาจจะต้องใช้เวลา มันก็เลยกลายเป็น Best Practices เรียบง่ายที่ ห่อหุ้ม(Encapsulate) ความซับซ้อนต่างๆเอาไว้ข้างในครับ ตัว Developer เองจะได้เวลาไปสนใจเรื่องอื่นมากขึ้น เช่น Business หรือ การ Test ครับ 😀

Design Principle กับ Design Pattern

ก่อนจะมาเข้าเรื่องที่ลึกลงไป ผมอยากแนะนำ 2 คำนี้ก่อนครับ Principle แปลเป็นไทย คือ “หลักการ” แปลไทยเป็นไทย คือ สาระสำคัญที่ยึดถือเป็นแนวปฏิบัติ (ข้อมูลจากราชบัณฑิตยสถาน) Pattern แปลเป็นไทย คือ “รูปแบบ” แปลไทยเป็นไทย คือ แบบ, แผน, ตัวอย่าง, ทำแบบ, แบบอย่างอันดี, เอาแบบอย่าง กลับมาที่ Design Principle คือ หลักการออกแบบ Software โดยมีชุดแนวคิด หรือคำแนะนำ เพื่อป้องกันการออกแบบ Software ที่แย่ ที่ส่งผลทำให้มีการปรับแก้ไข (Customize) หรือ การดูแลรักษา (Maintenance) ยาก เช่น SOLID (หลักการพื้นฐาน 5 ข้อ ถูกคิดและเผยแพร่โดย Uncle Bob ครับ ) จากนั้นอีกคำ Design Pattern คือ รูปแบบการออกแบบที่ดี อ่านแล้วดูแปลก เปลี่ยนใหม่ดีกว่าเป็นแบบแผนที่ดี ที่สามารถใช้กับปัญหาทั่วไปได้ (Reusable Solution) เช่น Singleton (Pattern ช่วยจัดการจำนวน Object เพื่อให้ระบบงานมีระสิทธิภาพสูงสุด) แถมให้อีกคำ เนื่องจากมี Design Pattern แล้ว ก็ต้องมี Anti-Pattern คู่กันครับ เจ้า Anti-Pattern ตรงข้าม Design Pattern คือ แบบแผนที่ไม่ดี แก้ปัญหาเฉพาะหน้าครับ มันเป็นการ Workaround ครับ ตัวอย่างที่คุ้นๆกัน น่าจะเป็น GodClass, GodMethod, Circular Dependency ครับ ปูมาซะนาน ตอนแรกจะเขียน Blog เกี่ยวกับ IoC(Inversion of Control) แต่ศึกษาไป ศึกมาก็มาลงเอยที่ Blog นี้ครับ…

[Digital Thailand] Big Data in Business

บทความนี้ก็แตกออกมาจาก Blog “สรุปจากงาน Digital Thailand 2016 ครับ”  ขอสรุปสิ่งที่ได้จากการฟังสัมมนาในงาน Digital Thailand วันที่ 28-May-2016 ครับ Turning Big Data Into Personalized User Journeys ใน Section แรกมาจาก “Turning Big Data Into Personalized User Journeys” โดย Mr. Kevin Jackson, Global Sales Director of Gravity R&D Digital Car Insurance – delivering safer drivers, lower CO2 and increased customer engagement through smartphone Apps และส่วนที่สอง “Digital Car Insurance – delivering safer drivers, lower CO2 and increased customer engagement through smartphone Apps” เป็นการนำเจ้า Big Data มาปรับประยุกต์ใช้กับธุรกิจในด้านประกันภัยครับ เกริ่นแนะนำการประกันภัยสักหน่อย ปัจจุบัน Digital Insurance Insurance Telematics ในไทยมีเอา Insurance Telematics ผมเข้าใจว่าเป็น ไทยวิวัฒน์ประกันภัยนะครับ  Digital Insurance นอกจากด้าน Motor Insurance แล้วยังสามารถเอาไปใช้กับการประกันในด้านอื่นๆได้ เช่น อสังหาริมทรัพย์, สุขภาพ และการท่องเที่ยว เป็นต้น Future

[Digital Thailand] How Google Thinks About Developing a Culture of Innovation

วันเสาร์ที่ผ่านมา ผมได้ไปงาน Digital Thailand โดยผมขอแตก Blog นี้ ออกมาจาก Blog หลักนะครับ โดยเรื่องที่ผมกำลังเขียนต่อไปนี้ เป็นเรื่อง How Google Thinks About Developing a Culture of Innovation” โดยคุณ Ben King, Country Head of Google Thailand ครับ ช่วงแรกเป็นการแนะนำบริษัทก่อนครับ ตอนนี้ Google หรือ Alphabet ในปัจจุบันครับ เข้าสู่วัยรุ่นและ อายุ 18 ปี นับจากที่ผู้ก่อตั้งทั้ง 2 คน Larry Page และ Sergey Brin ครับ ในโรงรถครับ (บริษัทยักษ์ด้าน IT ในปัจจุบัน มักเกิดจากโรงรถครับ อย่าง Micorsoft กับ Apple ครับ) แรกเริ่มที่มีพนักงาน 4 ครับ จนถึงปัจจุบัน ที่มีอยู่ 60,000 กว่าคนทั่วโลกครับ โดยมี 6 Platform มี่ต้องดูแลครับ Culture and innovation High-performance ways of working Talent acquisition & retention  ปิดท้ายด้วยคำพูดของคุณ Larry Page ครับ “If you’re not doing some things that are crazy , then you’re  doing the wrong things.”

[Digital Thailand] สรุปจากงาน Digital Thailand 2016 ครับ

คืนวันศุกร์ หลังจากปั่นงานเสร็จ ผมลองหาๆดูว่าวันเสาร์จะไปทำอะไรดี พอดีเจองาน Digital Thailand ที่ศูนย์ประชุมแห่งชาติสิริกติ์ครับ พอไปดูงานสัมมนาในวันเสาร์มีเรื่องที่น่าสนใจหลายเรื่องครับ อาทิ เช่น Google คิดอย่างไรกับการสร้างนวัตกรรม และการนำ Big Data เช้ามาประยุกต์ใข้กับงาน เป็นต้นครับ และก็วันนี้มีจัดการหลายงานด้วยนะครับ ถ้าเบื่อแล้วก็สามารถเปลี่ยนไปชมงานอื่นๆได้ครับ เริ่มกันเลยดีกว่า หลังจากลองเดินทางแบบประหยัด โดยนั่งรถเมล์ 149 จากบ้านมาแทนครับ แล้วเดินอีกนิดนึง แทนที่จะนั่งรถเมล์สาย 40 แล้วไปต่อ MRT ครับ เวลาไม่ต่อกัน แต่ค่าใช้จ่ายลดไปเยอะเลย เมื่อมาถึงงานมีให้ลงทะเบียนครับ ในส่วนนี้ผมคิดว่าระบบ OK นะครับ ของตัว ZipEvent ครับ ถ้าลงทะเบียนมาจากเว็บแล้ว สามารถใช้มา Print QR Code เพื่อใช้ลงชื่อเข้างานใน Session ต่างๆครับ คล้ายกับ Project ที่เคยส่งประกวดตอนปี 2 เลย แต่ของผมจะใช้ RFID ในช่วงแรกผมได้เข้า Session ต่างๆ ดังนี้ครับ ที่จัดในห้องสัมมนา Lotus ถ้าเราอยู่กับที่ หรือก้าวถอยไป ศักยภาพของการแข่งขันของประเทศเราจะลดลง เมื่อเทียบประเทศอื่นที่มีการพัฒนาอย่างต่อเนื่องครับ ดร.ทวีศักดิ์ กออนันตกูล หลังจากทานของว่างเสร็จ ตอนแรกนึกว่าจัดให้เฉพาะวิทยากรเท่านั้น ฮ่าๆ ต่อมาผมเข้าไป Plenary Hall ครับ ในนี้มีหน่วยงานต่างๆ ทั้งภาครัฐ และเอกชนมาเปิดบธครับ โดย แบ่งเป็นกลุ่มได้ ดังนี้ ท้ายที่สุดเป็นของที่ระลึกจากงานครับ ตอนแรกนึกว่าเป็นพวกกุญแจ แต่ที่จริงแล้วเป็น Handy Drive ครับ 8GB และเสริมอีกนิดนึงสำหรับการฟัง Session ที่บรรยายเป็นภาษาอังกฤษ เราสามารถขอเครื่องช่วยแปลได้ครับ โดยแลกบัตรประชาชนเก็บไว้ครับ แต่แนะนำให้ฟังภาษาอังกฤษดีกว่าครับ ฝึกภาษาครับ

แนะนำหนังสือ Your Code as a Crime Scene

ก่อนอื่นขอเล่าประวัติหนังสือเล่มนี้ก่อน ช่วงกลางเดือนมีนาคม ผมมี Idea ที่จะลองศึกษาอะไรใหม่ๆในวันอาทิตย์ ไม่ว่าจะเป็นอ่านหนังสือ ดู Video หรือ อื่นๆ ดีกว่าเอาเวลาไปปั่นงานที่เกิดจากความผิดพลาดของการบริหารโครงการ ฮ่าๆ วันนั้นผมได้ไปร้านหนังสือ Kinokuniya และก็สะดุดกับหนังสือเล่มนี้ครับ Your Code as a Crime Scene  ของคุณ Adam Tornhill หนังสือเล่มนี้พอซื้อมาเสร็จเป็น Crime Scene ทันที่ครับ หนังสือหายไปกับโครงการ 5 ส ที่ Site งานลูกค้า ย่านสะพานควาย ผมเพิ่งซื้อใหม่ทดแทนเป็นของขวัญวันเกิดวันที่ 23 เมษายน ครับ สำหรับ Your Code as a Crime Scene พอได้เห็นชื่อหนังสือนี้เสร็จ ภาพของ CSI นี่โผล่มาเลยครับ ลองมาดูที่ Code ของเราบ้าง คุณเคยเจอปัญหานี้ไหม มีคนไปแก้ Code ที่เป็น Core ของระบบ แล้วบึ้มไปโดน Module อื่นๆ ใครเป็นคนที่ทำ Code ให้มีพฤติกรรมที่ต่างไปจากเดิม ทำไม Code ถึงกลายพันธุ์ แล้วมันเริ่มที่ไหนหละ ? Code Module นี้ โครตเยอะ แต่มีการเรียกใช้งานมันไหม หรือเป็นมรดก จากยุคดึดำบรรพ์ (Legacy Code) เราจะสังเกตุได้อย่างไร ว่า Code ที่มีทีมงานเข้ามายุ่งหลายๆส่วน ส่วนไหน มันจะเป็นความเสี่ยงที่เราต้องสนใจ และ Test เป็นพิเศษ มาดู Keyword ของหนังสือ เล่มนี้ดีกว่า โดยหนังสือเล่มนี้จะเสนอ Idea โดยเอา Forensic Psychology มาใช้กับ Code ครับ แนว CSI สืบจากศพ มาเป็นสืบจาก…

Workaround Solution กับ Technical Debt

ก่อนอื่นของกล่าวถึงคำว่า Workaround มัน คือ การแก้ปัญหาเฉพาะหน้า เฉพาะกิจครับ เช่น ระบบจำเป็นต้องต่อกับระบบ Network ผ่านสายแลน เนื่องจากต้องการความเสถียร และความเร็ว แต่ที่โต๊ะ User ยังไม่มีการติดตั้งระบบ Networkทางทีมเสนอให้ใช้ Wireless ไปก่อน เป็นต้นครับ ถ้านึกภาพไม่ลองออกไปดูพวก Trust me I am Engineer ก็ได้ครับ ฮ่าๆ ในแง่ของการพัฒนา Software ก็มีเหมือนกัน เจ้า Workaround มัน คือ การแก้ปัญหาเฉพาะหน้า เพื่อลดเวลา หรือความยุ่งยากในการพัฒนาครับ ซึ่งส่งผลกระทบโดยตรงกับ Code และตัวระบบครับ ที่มาของการ Workaround ที่ผมเข้าใจนะ มี 2 แบบ ดังนี้ เกิดจากทีมพัฒนา เมื่องานมันเร่ง โดยมีตัวเลขค่านึง ที่ระบบต้องคำนวณ โดยมีสูตร A และสูตร B ตัว สูตร A มีคนทำไว้แล้ว พองานมันเร่ง และ BA ก็บอกว่า ลูกค้าไม่มีทางที่ต้องใช้สูตร B คิด SA และ Dev เลยตัดสินใจให้งานมันเร็ว เขียน Code ให้ใช้สูตร A แก้ปัญหาไปก่อน เพื่อให้ UAT ผ่าน แต่มัน คือ ระเบิดเวลาดีๆนั่นเองครับ ถ้ามีเคสที่ต้องใช้สูตร B ขึ้นมาหละ รื้อ Code กันยาวเลยทีนี้ ถ้าระบบรอดไปได้นานพอ ตัว Business ที่ Developer รุ่นหลังรับรู้ มีสูตร A ส่วนสูตร B หายไปตามกาลเวลาครับ เกิดจาก User บ้าง การใช้ระบบผิดวัตถุประสงค์ อันนี้เจอมากับตัวเลย…

[Spring 4.x] Overview กันสักหน่อย

จาก Blog ในตอนที่แล้ว เราได้ใช้ Spring ไปแล้ว หลายคนอาจจะใช้แบบไม่รู้ตัวก็ได้ครับ ที่นี้เรามาดูภาพรวมของ Spring ดีกว่า ว่ามันมีอะไรบ้างครับ Spring ไม่ได้เกิดมาเพื่อทำเว็บอย่างเดียวนะครับ โดยที่เรารู้จักกันเยอะเป็น Spring MVC กลับมาที่ Spring ดีกว่าครับ Spring มันเป็น Framework  ที่เกิดจากความโหดร้ายของ EJB ใน J2EE ครับ อาทิ เช่น ไม่ต้องการ App Server ตัวใหญ่ๆ การ Implement ที่ต้องเขียน Code เยอะแยะ Code ผูกกับตัว EJB มาเกินไป และอื่นๆ โดยคุณ Rod Johnson ได้สร้าง Framework ที่ Lightweight  ซึงนำเสนอพร้อมกับหนังสือ Expert One-on-One J2EE Design and Development ครับ โดยมีแนวคิดคร่าวๆ ดังนี้ Container Invasion of Control(IoC) โดยใช้แนวคิด Dependency Injection(Di) POJO (Plain Old Java Object) แก่นหลักที่คุณ คุณ Rod Johnson  คือ ตัว Spring Core (Blog ตอนก่อนหน้าเราก็ใช่เท่านี้ครับ) ที่พัฒนาออกมาในช่วงแรกครับ โดยมีชุมชนพัฒนา-เติมส่วนเสริม (Extension) ตามที่ระบบเราต้องการได้ครับ ไม่จำเป็นต้องใช้ทั้งหมด นี่แหละ Lightweight Spring Core มันมีสิ่งที่เราต้องรู้จัก ดังนี้ POJO (Plain Old Java Object) Container Dependency Injection(Di)…

[CR] Sushi Express Terminal 21

ผมเจอร้านนี้จากใน Twitter ครับ เห็นโปรช่วงแรกจานละ 20 มวลมหาประชาชนล้นหลามมากครับ ผมเลยไม่ไปครับ รออีกโปรดีกว่าครับ 5 จาน แถม 1 จาน ครับ แต่ราคาจานละ 30 บาทนะครับ วันนี้จริงก็กะจะไปกิน Food Court Pier21 มากกว่าครับ หลังจากเดินมาราธอนในงาน Mobile Expo มาครับ และวันนี้ก็หิวด้วย เพราะ ยังไม่ได้กินอะไรเป็นมื้อจริงๆจังๆเลย มีแต่นมกับผลไม้ครับ พอเห็นร้านโล่งๆนี่ เข้าทางผมเลยครับ กินชิวๆ ไม่ต้องมีแรงกดดันครับ โปรก็อันนี้เลยครับ  5 จาน แถม 1 จาน ครับ แต่ราคาจานละ 30 บาท ผมเข้าใจว่าคนน้อย เพราะ ยังเข้าใจว่า 20 บาท แล้วอารมณ์เสียครับ อันนี้ความเห็นส่วนตัวนะครับ เพื่อนผมก็บ่นครับ หลังจากเข้าร้านมาแล้วมาดูบรรยากาศในร้านดีกว่าครับ บรรยากาศในร้านครับ สวนใหญ่เป็นที่นั่งเดี่ยวครับ มีราง Sushi วนไปครับ แต่มีที่นั่งสำหรับ 4 คนด้วยครับ จากข้อแรกอันนี้ ภาพในหัวจากโคนัน ตอนปริศนาซูชิจานเวียน หายไปเลย ตอนแรกผมเข้าใจว่ามีหน้าจอให้สั่ง Sushi แบบพิเศษ และที่จานมี Tag RFID ไว้ช่วยนับครับ ที่เข้ากินร้านนี้ เพราะเข้าใจว่าเหมือนโคนัน 555 พอมาถึงที่โต๊ะครับ มาดูสิ่งที่ทางร้านเตรียมไว้ให้ดีกว่า กล่องอุปกรณ์ อันนี้ผมเรียกเองนะครับ โดยมี แก้วน้ำชา : หมายเลข 1 น้ำจิ้ม Sushi : หมายเลข 2 ถ้วยน้ำจิ้ม ไม้จิ้มฟัน : หมายเลข 3 ตะเกียบ : หมายเลข 4 ชาถุง รสชาติใช้ได้เลยครับ : หมายเลข 5 ก๊อกน้ำร้อนครับ เอาไว้ชงชากินเองครับ…