Code

Code สวย

เมื่ออาทิตย์ก่อนหน้าโน๊นพี่ roof ตั้งคำถามใน fb ว่า ตั้งแต่ทำงานมามีที่ทำงานที่ไหนให้ความสำคัญกับคำว่า “โค้ดสวย” บ้างครับ แม้ผมจะตอบกวนตีนไปว่าคนเขียน code สวยสำคัญกว่า แต่ตัวคำถามก็น่าสนใจจนต้องมาย้อนนึกคำตอบอยู่เหมือนกัน

สมัยผมยังทำงานเป็นโปรแแกรมเมอร์บริษัทแรกที่ผมทำ (อย่างน้อยก็ทีมที่ผมอยู่) ไม่มีแนวคิดเรื่อง code สวยครับ คือมีสอน coding convention บ้างว่าตัวแปรควรจะตั้งชื่ออย่างไร ชื่อ database แต่ละ table ควรจะตั้งอย่างไรก่อนเข้าทำ project แค่นั้น

แต่ตอนได้ทำงานจริงๆ ผมและเพื่อนร่วม project ก็ได้เรียนรู้ว่า code แบบไหนที่คนเขียนแล้วด่า (ด่าแรงๆ ก็ด่ายันพ่อคนเขียน code อีกที) แล้วพวกเราก็เรียนรู้ที่จะไม่เขียน code แบบนั้น ซึ่งส่วนใหญ่ไอ้ที่เราด่าจะเป็นอะไรที่ง่าวสุดๆ แบบเห็นได้ชัด ส่วนไอ้ที่ไม่ควรเขียนแต่เราไม่รู้เนี่ยเราก็นั่งอ่านผ่านๆ ตาทุกวันจนกระทั่งเกิดความเคยชิน ติดนิสัยเขียนแบบนั้นตามไปด้วย ซึ่งเหตุการณ์นี้ก็ยังเกิดตอนผมมาทำบริษัทที่ 2 อยู่ดี

ในบริษัทปัจจุบันที่ผมทำอยู่ ผมไม่ได้เป็นโปรแกรมเมอร์แล้ว (ที่นี่เรียกว่า dev) ผมไม่รู้ว่ามีการเน้นการเขียน code ที่ถูกต้องหรือไม่ แต่ผมก็รู้ว่าพวกเขามีการทำ code review กันทุกอาทิตย์ ส่วนงานของผมจะเน้นไปที่อ่านและ debug code ที่ตัวเองไม่ได้เขียนเป็นหลัก code ที่ผมมีความสุขที่ได้ทำงานด้วยคือ code ที่ผมเห็นแล้วรู้ทันทีว่ามันทำอะไรโดยไม่ต้องอ่าน comment หรือ debug ดู และถ้า code นั้นผมเห็นแล้วถึงกับร้องว่าเหยด คิดได้ยังไงจะยิ่งฟินสุดๆ ซึ่งก็พอจะมี dev ที่เป็นเพื่อนผมอยู่ 2-3 คนที่เขียนได้ประมาณนี้แล้วก็มีหลายๆ ครั้งที่ส่วนนั้นมันเจ๋งจนผมจำได้ว่าเวลาจะไล่อะไรก็ไปเริ่มไล่ในจุดนั้นแหละ แต่ไอ้ code พวกนั้นก็ไม่ได้รับรองว่าตัวมันทำงานจริงๆ มันจะช้าจะเร็วอย่างไร หรือนานๆ ไปมันจะมี bug ไหม ควร refactor อีกรึเปล่า (เพราะไม่ใช่หน้าที่ผม – แต่ก็เห็น dev refactor กันอยู่บ้างนานๆ ทีอ่ะนะ)

ทั้งหมดทั้งปวงที่กล่าวมาก็คือผมเองก็ไม่รู้ว่า code ที่สวยนั้นเป็นอย่างไร ส่วนตัวชอบ code ที่อ่านง่าย เข้าใจได้เลยโดยไม่ต้องอ่าน comment หรือ debug และ code นั้นจะไม่ควรจะง่าวระดับสุดๆ จนดูแล้วอยากด่านั่นเอง

ป.ล. พี่ roof เขียนถึงการพัฒนา software ที่เน้นเรื่อง performance จนละเลย maintainability ไว้แล้วครับ

Advertisements
Categories: Code, Tech | Tags: , | Leave a comment

วิธี set PATH Solaris เพื่อ configure กับ make file

ช่วงนี้มีเรื่องให้ต้อง compile โปรแกรมบน Solaris 10 x86 แล้วก็ติดปัญหาเรื่อง set compiler path หลายครั้งจนขอจดไว้ต้อง set อะไรบ้าง

พอโหลด source มา untar file เสร็จสั่ง configure ก็ขึ้นแบบนี้มาเลย

# ./configure
checking build system type... i386-pc-solaris2.10
checking host system type... i386-pc-solaris2.10
checking target system type... i386-pc-solaris2.10
checking for gcc... no
checking for cc... no
checking for cl.exe... no
configure: error: in `/disk2/opt/ruby':
configure: error: no acceptable C compiler found in $PATH
See `config.log' for more details
#

ไปค้นๆ ดู ต้องไปหา gcc ครับ ซึ่ง default ของ Solaris ในกรณีที่ไม่ได้ลง Sun Studio มันอยู่ที่ /usr/sfw/bin เราก็ export PATH ไป

# export PATH=/usr/sfw/bin:$PATH

พอสั่ง ./configure ก็จะเจอ error ว่าไม่มี make -*-

checking for prefix of external symbols... ./configure: line 18702: conftest.o: command not found
NONE
checking pthread.h usability... yes
checking pthread.h presence... yes
checking for pthread.h... yes
checking if make is GNU make... ./configure: line 18909: make: command not found
no
checking for safe null command for make... configure: error: no candidate for safe null command

ไปค้นๆ ดู make ไม่ได้อยู่ใน /usr/sfw/bin แต่อยู่ใน /usr/ccs/bin ต่างหาก -*-

ดังนั้นวิธีการ export ที่ถูกต้องเพื่อที่จะ configure และ make ได้คือ

# export PATH=/usr/ccs/bin:/usr/sfw/bin:$PATH

ที่นี่ก็จะ build ได้ พอ make install โปรแกรมก็จะไปอยู่ใน /usr/local แล้วเราก็ค่อยไปสร้าง softlink อีกทีครับ

Categories: Code, Diary, Tech | Tags: , , , , , | 1 Comment

วิธีสร้าง JSON Message ด้วย Java

ผมเขียนถึงวิธีการสร้าง JSON message บน Java ผ่าน entry นี้มาแล้วรอบนึง หลังจากนั้นผมก็ไปค้นเจอทีหลังว่าจริงๆ แล้ว Java มันสนับสนุน JSON โดยไม่ต้องพึ่ง 3rd Party lib แล้ว เลยมาแนะนำกันครับ

สิ่งที่ผมจะสร้างคือ JSON หน้าตาแบบนี้

{
   "service":"quote",
   "user":"plynoi",
   "symbols":["Nokia"],
   "fields":["BID","ASK","HIGH"]
}

ขอเปรียบเทียบกับวิธีใช้ 3rd Party ก่อน ตัวที่ผมเลือกเพราะ google เจออันดับแรกๆ คือ json-simple ซึ่งมันก็ใช้ง่ายๆ ตรงไปตรงมา doc อ่านง่ายดีมาก จะขอยกตัวอย่างตัดมาจาก entry Java อันนั้นอีกทีนะครับ

import org.json.simple.*;

private void createJSON(){

	JSONObject request_msg = new JSONObject();
	request_msg.put("service","quote");
        	request_msg.put("user","plynoi");

        	JSONArray itemArray = new JSONArray();
        	itemArray.add("Nokia");

        	JSONArray filterArray = new JSONArray();
        	filterArray.add("BID");
        	filterArray.add("ASK");
       	filterArray.add("HIGH");

        	request_msg.put("symbols",itemArray);
        	request_msg.put("fields",filterArray);
	
	//JSON message "request_msg" is ready to process
}

เทียบกับตัว Native ของ Java เองอย่าง JSR 353 แล้วส่วนตัวผมมองว่าที่ Java ให้มาอยู่แล้วยุ่งยากกว่าเยอะ แต่โชคดีที่ doc เขียนละเอียดดีโฮกๆ (แต่ก็อ่านยากกว่าเช่นกัน :p)

import javax.json.Json;
import javax.json.JsonObject;

private void createJSON(){

	JsonObject request_msg = Json.createObjectBuilder()
		.add("service","quote")
		.add("user","plynoi")
		.add("symbols",Json.createArrayBuilder()
                    		.add("Nokia")
               	 )
                	.add("fields",Json.createArrayBuilder()
                    		.add("BID")
                    		.add("ASK")
                    		.add("HIGH")
                	)
                .build();
	
	//JSON message "request_msg" is ready to process
}

จะไปใช้ตัวไหนก็แล้วแต่นะครับ ส่วนตัวผมชอบ simple-json มากกว่าตรงที่มันดูตรงไปตรงมากว่านี่แหละ

Categories: Code, Tech | Tags: , , , | 1 Comment

Create a free website or blog at WordPress.com.

Bomreview

โบ้มรีวิว โตแล้วจะรีวิวอะไรก็ได้

rerng.rak

Just another WordPress.com weblog

neizod

Smile! You’re at the best WordPress.com site ever

Admod's blog

just logs

freeclub

พยายามเขียนให้ยาวกว่าเฮดเดอร์ข้างบนจะได้ดูสวยๆ

Anontawong's Musings

a daily dose of a new perspective

TravelKanuman

Travel around the world

kemisara

Belle Kemisara Paladesh's Fan Site - เว็บไซต์แฟนคลับเบลล์ เขมิศรา พลเดช

eatandysummers

eat. travel. live.

Jonathan Fleming's Blog

A Photography Blog

Viewfinder - Street Photography Blog

Jimmy Yang Street Photography Blog

PinkiiGirl

Be one of those who change things and push the human race forward

บล็อกอะไรไม่รู้ของแบม

Ordinary guy blogging about comic books, video games, movies and stuffs.

Pawoot Personal Blog & Think Tank

E-Business Man Daily Life and What I'm Thinking