Tag Archives: kinh nghiệm

Tạm biệt Việt Nam – Chia sẻ kinh nghiệm nộp đơn du học – Phần 1

Bạn nào hay theo dõi blog của mình chắc cũng biết mình đã xách valy đi ngoài ra nước, nhầm, đi ra nước ngoài vào hôm 25/09. Sau gần hai năm đi làm, mình quyết định học lên Thạc Sĩ ở UK. Trong ngành IT, tấm bằng Thạc Sĩ không cải thiện được mức lương nhiều, nhưng mình thích đi để trải nghiệm. Bạn nào mong học Thạc Sĩ để lương cao hơn thì nên suy nghĩ lại nhe.

Sẵn có vài bạn hỏi nên mình viết bài để chia sẻ cách tìm trường và đi du học luôn. Quá trình tìm trường, nộp hồ sơ du học cũng khá nhiều khê và phức tạp. Nhờ sự giúp đỡ, tư vấn của trung tâm tư vấn nên mình được nhận vào Đại học Lancaster (Top 10 ở UK), với học bổng 1600o bảng (gần 550tr), ngành MSc Internation Innovation (Computer Science). Mình viết bài này chia sẻ kinh nghiệm chuẩn bị, nộp hồ sơ cho các bạn có dự định đi du học (Về kinh nghiệm học tập, ôn luyện tiếng Anh thì các bạn xem bài khác nhé).

StudyAbroadbanner

Continue reading Tạm biệt Việt Nam – Chia sẻ kinh nghiệm nộp đơn du học – Phần 1

Ngồi xuống và viết blog đi nào

Đây không phải là điều mình tự nói với mình đâu, mà là điều mình muốn nói với bạn đấy. Mình nhắc lại một lần nữa nhé: Hãy ngồi xuống và viết blog đi nào.

Trước khi lắc đầu nguầy nguậy, đưa ra vô vàn lý do để chống chế: mình không có thời gian, biết gì mà viết, viết có được gì đâu … Hãy chịu khó bỏ chút thời gian quý giá của bạn, đọc hết bài viết này rồi bắt tay vào viết nhé.

Time-to-Share

Continue reading Ngồi xuống và viết blog đi nào

Tạm biệt ASWIG – Đôi dòng tâm sự của chàng junior developer – Phần 2

Đầu tháng 6/2015 – Một tháng đầy biến động

Tiếp theo phần 1. Thiếu người, mình bị “ép” phải dựng toàn bộ wireframe, giao diện cho dự án Claimbook. Đúng là làm super junior nó khổ thế. Một lần nữa, anh H. lại tỏa sáng với khả năng ngoại giao của mình. Anh đã “lôi kéo” được một bác Technical Lead và 2 developer mới vào team. Anh còn dụ dỗ được team designer tham gia vào quá trình thiết kế cho dự án. Leader Team Designer là anh Sơn Đoàn – người yêu của Adrian Anh Tuấn. Trông anh Sơn đẹp trai và manly hơn ông Team Leader của mình cả chục lần.

Suốt 2 tháng trời, cả nhóm dồn tâm sức làm prototype cho dự án Claimbook. Team cũng tổn thất khá nhiều. Anh technical lead do thái độ làm việc không ok, không phù hợp với văn hóa công ty, vào team mình được 1 tháng đã phải chuyển qua team khác, rồi nghỉ việc ngay sau đó vài tuần. Design của dự án cũng bị thay đổi xoành xoạch theo yêu cầu của khách hàng, team mình cũng ngại không dám liên hệ lại với team designer vì sợ bị chửi do tự ý sửa lung tung design của họ.

Thay mặt anh H., xin gửi lời cảm ơn đến anh Sơn Đoàn đẹp trai, cùng toàn thể các bạn trong team designer đã góp phần vào thành công của dự án. Thấy team em được khen nhiều mà không nhắc đến các đóng góp của team anh nên cũng hơi cắn rứt.

Anh Sơn Đoàn - Giám đốc sáng tạo của ASWIG. Đẹp trai nam tính hơn ông team leader của mình nhiều T_T
Anh Sơn Đoàn – Giám đốc sáng tạo của ASWIG. Đẹp trai nam tính hơn ông team leader của mình nhiều T_T

Continue reading Tạm biệt ASWIG – Đôi dòng tâm sự của chàng junior developer – Phần 2

Tạm biệt ASWIG – Đôi dòng tâm sự của chàng junior developer – Phần 1

Ngày 4 tháng 9 năm 2015, mình chính thức nghỉ việc tại Aswig Solutions để bước trên một con đường mới – du học 2 năm ở UK tại Đại Học Lancaster. Bài viết này là đôi dòng tâm sự kể về một năm làm việc của mình ở đây: Buồn ít, Vui nhiều, học được vô số điều bổ ích về technical và cách hành xử trong công việc.

Nghỉ việc rồi, không còn được vào phòng họp ngắm cảnh thế này nữa ~.~

Continue reading Tạm biệt ASWIG – Đôi dòng tâm sự của chàng junior developer – Phần 1

Tạo động lực học tập và làm việc – Sức mạnh của thói quen

Thời sinh viên, đã bao giờ bạn muốn làm bài tập, ôn thi ngay nhưng lại bị games, đi chơi, gái gú cảm dỗ chưa?

Thời sinh viên, đã bao giờ bạn muốn lấy một tấm bằng ngoại ngữ, một chứng chỉ, nhưng tìm học được nửa tiếng rồi lại thôi chưa?

Lúc đi làm, đã bao giờ bạn muốn học một công nghệ mới, một ngôn ngữ mới, nhưng được một vài hôm lại thấy chán nản và muốn bỏ chưa?

Nếu câu trả lời của bạn là “Có”, đừng lo, chẳng có gì xấu hổ cả, ngày xưa mình cũng từng như bạn (giờ vẫn vậy). Tuy nhiên, nhờ một vài bí quyết đơn giản, mình đã cảm thấy tự tin, dễ dàng khi học và tiếp thu kiến thức mới, có được một công việc kha khá, cũng như một số tấm bằng kha khá.

Continue reading Tạo động lực học tập và làm việc – Sức mạnh của thói quen

Trải lòng với bài viết thứ 50 – Cảm ơn sự ủng hộ của mọi người

Mình bắt đầu viết blog này vào ngày 31/12 năm trước, thấm thoắt mà cũng đã được gần 8 tháng rồi nhỉ. Bài viết này ra đời nhân kỉ niệm lượng bài viết của blog đã đạt đến con số 50.

Bạn nào từng theo dõi blog chắc cũng thấy mình từng viết 1 bài viết ăn mừng blog đạt được 1000 view đầu tiên vào khoảng cách đây 2 tháng. Một chuyện dở khóc dở cười là, ngay sau khi mình chia sẻ và giới thiệu blog của mình với bạn bè trên facebook, lượng view trong ngày 09-05 đạt gần 1000 – bằng với lượng view của blog trong 4 tháng. Thế mới thấy, sức mạnh của quảng cáo bá đạo như thế nào.

01

 

Continue reading Trải lòng với bài viết thứ 50 – Cảm ơn sự ủng hộ của mọi người

70 điều các developer giỏi thuộc nằm lòng – Phần 2

Nối tiếp phần 1, bài viết này bao gồm 35 bài học tiếp theo trong số 70 bài học rút ra từ cuốn The Pragmatic Programmer mà mình đã nhắc tới ở bài trước.

35 bài học còn lại:

Continue reading 70 điều các developer giỏi thuộc nằm lòng – Phần 2

70 điều các developer giỏi thuộc nằm lòng – Phần 1

bài trước, trong số sách đã giới thiệu, mình giới thiệu 1 cuốn sách gọi The Pragmatic Programmer. Như mình đã quảng cáo, cuốn sách này tập hợp rất nhiều kinh nghiệm được các tiền bối đúc kết lại qua bao nhiêu năm phát triển phần mềm. Vì sách khá dài, để tiện cho mọi người đọc, bác Jeff, chủ blog codinghorror đã rút gọn cuốn sách thành 70 điều dưới đây. 90% những điều này sẽ giúp ích cho sự nghiệp lập trình của bạn, do đó mình mạn phép dịch ra để chia sẻ lại. Bạn nào muốn có thể xem link gốc của cuối blog.

Continue reading 70 điều các developer giỏi thuộc nằm lòng – Phần 1

Éo ai quan tâm đến code bạn viết đâu

Có một sự thật đớn đau ít người biết về nghề lập trình. Lập trình viên thường bỏ công sức để trau chuốt code của mình trở nên hoàn hảo mà quên 1 sự thật: Thứ quan trọng thật sự không phải là code, mà là sản phẩm. Biết được điều này, lập trình viên sẽ gia tăng hiệu suất làm việc, sản phẩm do anh ta làm ra cũng sẽ được coi trọng hơn

(Điều này chỉ đúng với các start-up, các project làm ra sản phẩm. Với các project outsource, code chính là sản phẩm, bọn Nhật nhiều khi review code rất kĩ, bắt lỗi tới từng câu lệnh, cách đặt tên biến. Tác giả là người nước ngoài chắc cũng không làm outsource nhiều nên không biết).

abcd

Code chỉ là công cụ

Công việc của developer chúng ta không phải là viết code, mà là sử dụng code để tạo ra phần mềm, với những chức năng mà người dùng mong muốn. Code là thứ giúp chúng ta thực hiện điều đó, nhưng xét cho cùng, nó chỉ là công cụ. Giống như công việc của thợ cắt tóc không phải là sử dụng kéo (kéo = code), công việc của họ là tạo ra thứ gì đó (một mái đầu đẹp) với cây kéo.

Tuy vậy, một số quy trình trong ngành phần mềm có thể làm ta lầm tưởng rằng code chính là sản phẩm. Vd, việc refactor code, có thể xem đó là 1 qui trình làm cho code tốt hơn, hoặc làm cho sản phẩm tốt hơn. Nhìn từ góc độ của khách hàng hoặc người quản lý, refactor code là một hành động vô bổ, còn có thể làm nảy sinh bug mới, tốn thời gian và công sức.

Sản phẩm chúng ta tạo ra (phần mềm) được đánh giá qua những gì người dùng nhìn thấy, chúng ta cần tự nhắc nhở mình điều này mỗi khi viết một dòng code. Nếu phần mềm nhàm chán, không đáp ứng đủ chức năng, người dùng sẽ éo thèm quan tâm đến những thứ đằng sau, toàn bộ những thứ đẹp đẽ tuyệt vời chúng ta làm trong code đều trở nên vô nghĩa.

Điều đó không có nghĩa là code hoàn toàn vô giá trị, có thể thoải mái thả nổi chất lượng. Những vấn đề như bảo mật, validation, khả năng chịu lỗi cần phải được giải quyết bằng cách code đúng cách, sử dụng đúng thư viện, đó cũng chính là công việc của lập trình viên chúng ta. Code chất lượng, dễ hiểu thì người khác sẽ review dễ dàng hơn (Theo mình, ý của tác giả ở đoạn này là: tuy khách hàng không quan tâm đến code của bạn, nhưng còn 1 số người khác như developer, technical lead  sẽ khá quan tâm đến nó).

Tập trung vào chức năng

Hãy tưởng tượng bạn đang ở trong một cuộc họp trực tiếp với khách hàng, hoặc product owner. Chúng ta báo cáo gì với họ? Chúng ta có nói rằng đã tạo được bao nhiêu class, viết được bao nhiêu dòng code ko? Hay chúng ta nói cho họ nghe về cách chúng ta sửa lỗi ứng dụng, script để deploy, hoặc ta thiết kế database như thế nào. Tiếc thay, câu trả lời thường là . Hãy nhìn mặt khách hàng lúc này, trông họ chan chán, ngu ngơ như con cá bơ, hoặc giả bộ gật gù chờ hết chuyện. Chúng ta đi vào quá nhiều chi tiết vô giá trị đối với khách hàng. Không phải học không biết, không hiểu, mà đơn giản là họ éo quan tâm (Ví dụ dễ thấy, nếu bạn nhận làm web quảng cáo cho 1 công ty, họ chỉ cần sản phẩm là 1 trang web kèm tên miền, họ không quan tâm bạn dùng PHP hay Java hay C#, bạn viết HTML4 hay HTML5, họ không biết, và có biết cũng không thèm quan tâm).

Hãy tượng tượng bạn có 1 đội designer trong công ty. Trong buổi họp, bạn phải nghe bọn designer lảm nhảm về photoshop, về việc tụi nó đã tạo layer thế nào, thiết kế gradient tương phản ra sao, tụi nó viết script xử lý ảnh như thế nào. Chúng ta éo quan tâm, chúng ta chỉ cần biết : Khi nào bọn mài design xong để tụi tao còn code.

Chúng ta nên tập trung vào chức năng khi báo cáo với khách hàng: chức năng tạo báo cáo đã xong, nhưng còn thiếu phần ABC; trang web đã hiển thị rõ đẹp trên di động, nhưng cần chỉnh sửa chút đỉnh trên tablet. Đây là những thông tin mà quản lý và khách hàng quan tâm, nó giúp họ hiểu rõ tiến độ của dự án, cho họ thêm thông tin trong việc lên kế hoạch

JavaScript-Code-Libraries

Mấy cái library vô dụng

Một câu hỏi đặt ra dành cho các bạn lập trình viên: Đã bao giờ các bạn chọn 1 library để sử dụng dựa trên source code của nó chưa? Mình thì chưa. Vd như mình cần tìm 1 library  hỗ trợ việc resize ảnh trong C#, mình sẽ google, sau đó xem library nào được nhiều người sử dụng nhất, chức năng có nhiều hay không, cách sử dụng có dễ hay không. Thứ mình quan tâm là gì, chính là sản phẩm, không phải code của thư viện đó. Nếu 1 thư viện được code rất có bài bản, áp dụng design pattern, interface, DI, nhưng mà chức năng chỉ có 1 chút, liệu bạn có chọn không? Câu trả lời đương nhiên là không.

Bạn thấy đấy, đến cả lập trình viên chúng ta còn không thèm quan tâm đến code của lập trình viên khác, làm sao bạn có thể đòi hỏi “lũ khách hàng” quan tâm đến code của mình.

1

Đúng, nhưng mà…

Vì không ai quan tâm đến code, chúng ta có quyền viết code ẩu cho xong chuyện. Không, hoàn toàn không phải. Code chất lượng thì sẽ cho ra sản phẩm chất lượng. Dù không ai quan tâm đến code, để giải quyết vấn đề ta vẫn phải dùng đến code. Quay lại chuyện cái kéo ở ban đầu, kéo bén hay kéo cùn thì đều cắt ra tóc được, nhưng xài kéo rỉ sét (code quá tệ) thì sẽ hại cả thợ lẫn người cắt. Công việc của lập trình viên chúng ta là chăm chút cho sản phẩm, không phải cho code. Hãy thử đặt mình vào vị trí của quản lý, hoặc khách hàng, tập trung vào chức năng, chứ không phải công cụ. Chức năng, chứ không phải code, mới là thứ mang lại giá trị thực sự cho sản phẩm ta làm ra.

Cột mốc 1000 view – Lời cảm ơn chân thành đến bạn đọc và mọi người

Mình bắt đầu viết blog này vào ngày 31/12 năm trước, bắt đầu bằng bài viết về bản thân và giới thiệu blog. Đây là bài viết thứ 28 của blog này, đánh dấu lượt view thứ 1000.

https://toidicodedao.com/2014/12/31/gioi-thieu/

Đẹp trai nhất, ngoài cùng bên phải

Từ đó tới nay tính ra đã được 5 tháng, lúc blog đạt được mốc 1000 view vẫn còn là tháng 4, tính ra mình đạt mốc 1000 view sau 4 tháng, không phải quá xuất sắc nhưng cũng không đến nỗi tồi. Kỉ lục của blog là hơn 100 views/ngày, khi mình post link bài viết về Lambda Expression trên group ASP.NET MVC facebook.

Continue reading Cột mốc 1000 view – Lời cảm ơn chân thành đến bạn đọc và mọi người