做10年Windows程式員與做10年Linux程式員的區別

来源:http://www.cnblogs.com/roucheng/archive/2016/06/11/linuxwindows.html
-Advertisement-
Play Games

如果一個程式員從來沒有在linux,unix下開發過程式,一直在windows下麵開發程式, 同樣是工作10年, 大部分情況下與在linux,unix下麵開發10年的程式員水平會差別很大。我寫這篇文章並不是想貶低windows下麵開發的人,做windows開發的人看了可能會感覺不舒服,我並不是這個意 ...


如果一個程式員從來沒有在linux,unix下開發過程式,一直在windows下麵開發程式, 同樣是工作10年, 大部分情況下與在linux,unix下麵開發10年的程式員水平會差別很大。我寫這篇文章並不是想貶低windows下麵開發的人,做windows開發的人看了可能會感覺不舒服,我並不是這個意思,我只是說說我自己的感受,我最早開始學習編程也是在windows下麵的, 學的是VB,後來轉到VC++,當時用的是VC6.0, 做windows下麵的開發5年後轉入linux下麵做開發的,開始在linux下麵做開發的時候, 也做過很多windows下麵的項目,在linux下麵做開發確實比我在windows下麵做開發多學到了很多的東西,從開源代碼裡面吸取了豐富的營養,我不是說我是個高手, 只是說在linux下麵學習,你會進步的更快。

 

不過我需要強調一下,我這裡說的是 “大部分情況下”,意思就是說“在同樣勤奮,同樣努力程度,同樣基礎知識,同樣工作年限,同樣是做應用程式的開發” 的情況下,如果說的不對,希望大家在下麵發表看法。

 

可能大家會奇怪, 為何會出現這種情況呢 ?

聽我慢慢道來!

第一:閉源與開源

windows下麵的程式基本都是封閉源代碼的,特別是10年前,在windows下可以說找不到可用的開源的軟體,現在的情況比以前好多了, 很多linux下麵開源的程式被移植到windows下麵來,但是linux下麵開源的程式增加的更多了。

以前在windows下麵寫應用程式, 需要用到MFC,WINSOCK,ODBC,FILE  IO等, 可以找資料的地方主要是微軟官方的文檔MSDN,也只有MSDN才是最全的地方,下來是第三方網站 vckbase, CSDN, codeproject 這幾個網站。 但是從這些網站找到的代碼,都是針對一個特定的小功能,為了演示如何實現這個小功能而寫的代碼,寫代碼的水平參差不齊,風格各異,都是一些demo性質的小東西,簡單研究看看代碼就可以集成到自己的應用程式裡面。如何構建一個完整的應用程式, 架構良好的應用程式, 大學裡面不會教你, 一切都得靠自己摸索,在公司裡面做項目獲得提升,直到項目商用,後期維護修改代碼時, 回頭看自己寫的代碼, 才深刻體會到,自己當時寫的代碼架構是多麼的不合理,維護修改是如此的困難。如果在互聯網上找不到自己需要的資料,就只能靠自己想一些實現的方法,雖然功能完成了, 可能完成的時候還很有成就感,但是等那天你突然發現有人實現這個功能,並且用了一個巧妙的方法, 這是你才突然恍悟, 我當時為何就想不到這麼實現呢? 在windows下麵開發, 不太容易找到可以參考的類似你要完成功能的開源項目。一切都得靠自己。但是在linux下麵就不一樣了, 當你要開發一個新項目時, 可以想想有沒有什麼開源項目也完成了類似的功能, 可以下載到源代碼來做一個參考, 對其中的演算法, 架構設計等做一個詳細的瞭解,然後自己開發的時候就會比較得心應手了,可以避免別人犯過的錯誤,少走很多彎路。http://hovertree.com/menu/windows/

 

第二:要學習的知識量不一樣

學習window下的開發, 你需要學習很多的Windows API,截止到2009年9月,Windows總API數量為2258個, 並且Windows API 的參數多, 參數類型複雜,要記住這麼多東西不是一件容易的事情,至少也和學習一門外語一樣,大學英語四級要求掌握的總辭彙量達到4500個單詞。可想而知, 學會這麼多的API用法,有多難了吧。那麼學習linux下, 要掌握多少API呢 ? linux下的內核API, 全部算下來也才335,但是這些內核的API只有編寫驅動的時候才能用到, 開發應用程式基本用不到內核的API,開發應用程式的API基本都是C的API,而 Linux所有的C的API個數是279個, 也就是說你只需要掌握不到300個的API, 就可以順利的在linux下麵開發應用程式了,相比學習windows下麵的那一堆API來說, 你是不是可以省下很多時間來學習其他知識呢?

 

下麵我就舉個簡單的例子:

CreateFile
ReadFile
OpenFile
WriteFile
DeleteFile
ReadFileEx
WriteFileEx
CloseHandle

上面這些API是windows下麵對文件操作的API, 總共是8個,看看CreateFile的參數吧,

HANDLE WINAPI CreateFile(
__in LPCTSTR lpFileName,
__in DWORD dwDesiredAccess,
__in DWORD dwShareMode,
__in LPSECURITY_ATTRIBUTES lpSecurityAttributes,
__in DWORD dwCreationDisposition,
__in DWORD dwFlagsAndAttributes,

__in HANDLE hTemplateFile);

這些參數的意義和類型, 請問你需要花多少時間來掌握呢 ?

 

我們在看看linux下麵對文件操作的C的API有幾個,

fopen, fwrite, fread, fclose 共四個,我們在看看參數吧

FILE *fopen( const char *filename, const char *mode );   兩個參數, 請問你需要花多少時間掌握呢。

 

可能有的人會提出意見,說上面C的API也能在windows下麵運行啊? 沒錯, 是能在windows下麵運行,但是你就掌握這跨平臺的C的API夠嗎? 難道所有在windows下麵開發的人都喜歡用C的API, 不會用windows本身的API嗎?你不需要學習windows下麵的API嗎? 你的同事使用了CreateFile這個函數, 你不需要搞懂他嗎? 你不需要看同事的代碼嗎? 你不需要去維護別人寫過的代碼嗎? 

如果你還是這麼想,那我還可以再舉其他例子!就拿創建線程的例子吧,下麵是2個在windows下麵創建線程的例子, 第一個是創建安全工作線程, 第二個是創建界麵線程,還有一個函數我沒有放下麵, 是創建不安全的工作線程的,具體的原理大家可以參考《win32多線程程式設計》,

作者:(美)Jim Beveridge & Robert Wiener 著,侯捷 譯 這本書。

 

//線程安全的工作線程函數

uintptr_t   _beginthreadex( 
   void *security,
   unsigned stack_size,
   unsigned ( *start_address )( void * ),
   void *arglist,
   unsigned initflag,
   unsigned *thrdaddr 
);

 /* 何問起 hovertree.com */

//界麵線程函數

HANDLE WINAPI CreateThread(
  __in          LPSECURITY_ATTRIBUTES lpThreadAttributes,
  __in          SIZE_T dwStackSize,
  __in          LPTHREAD_START_ROUTINE lpStartAddress,
  __in          LPVOID lpParameter,
  __in          DWORD dwCreationFlags,
  __out        LPDWORD lpThreadId
);

做windows下麵的開發, 上面兩個創建線程的函數我們都必須掌握。當然了, 你也可以只需要知道 _beginthreadex 來在windows下麵通吃,但是當看到別人的代碼使用CreateThread的時候, 你可不要不習慣,MFC裡面很多人都用CreateThread。 掌握這麼多的API累吧 ?  就和你上學的時候背單詞一樣累。

 

下麵我在列一下linux下麵創建線程的函數

int pthread_create(
pthread_t *restrict thread,
const pthread_attr_t *restrict attr,
void *(*start_routine)(void*), 
void *restrict arg);

看到了吧, 你只需要知道這個就可以了。

 

C的API 絕大部分都可以再windows下麵運行,在windows下麵學習開發, 你不但要懂得C的API, 你還需要多花時間來學習windows系統本身的API, 你可能要說, 這麼說應該是windows下麵學得多啊, 我要說的是你掌握的API是很多, 但是對於一個軟體來說, 最最重要的是系統架構,數據結構,架構設計的好, 對後期的代碼維護,功能修改都很關鍵, 這也就是新手寫的代碼, 到最後連他自己本人都很難維護的原因, 更別說讓別人來維護了。

 

API相當於基本功, 系統架構, 數據結構是內功,基本功練的越快,我們就越有更多的時間來練習內功。練習內功,我們要多向高手學習。

 

在學習windows 下麵開發應用的道路上, 我們需要掌握更多的API, 學習後, 讓我們的路越走越窄, 沒有特別豐富的開源代碼可以參考, 水平提高的速度很慢。

可喜的是, 現在很多開源的項目被很多人移植到了linux下麵, 也有很多的開源項目是跨平臺的, 常用的是 wxWidget界面庫, 用法類似MFC, 還有qt這個界面庫, 也很強大,還有開源的3D引擎OGRE, 架構非常好,很值得學習其架構模式。但是linux下麵的開源庫要遠遠比windows下麵的開源庫豐富得多, 我們可以方便的從高手的代碼裡面學習數據結構,學習設計模式,學習編程技巧,這也就是linux下麵的程式員, 可能會比windows下麵的程式員水平更高的原因, 畢竟見多識廣嘛, 熟讀唐詩三百首,不會作詩也會吟啊!

推薦:http://www.cnblogs.com/roucheng/p/daimashi.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MySQL中定義數據欄位的類型對你資料庫的優化是非常重要的。 MySQL支持多種類型,大致可以分為三類:數值、日期/時間和字元串(字元)類型。 數值類型 MySQL支持所有標準SQL數值數據類型。 這些類型包括嚴格數值數據類型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及 ...
  • 最開始學Oracle的時候,有個概念叫SGA和PGA,是非常重要的概念,其實就是記憶體中的緩衝池。InnoDB的設計類似於Oracle,也會在記憶體中開闢一片緩衝池。眾所周知,CPU的速度和磁碟的IO速度相差可以用鴻溝來形容,因此聰明的前輩們使用了記憶體這個ROM來彌補這道鴻溝,那麼資料庫的設計者們也繼承 ...
  • 作為玩windows的碼農,在centos上面裝點東西,真的會崩潰的要死,,,我想大家也知道,在centos上面,你下載的是各種源代碼,需要自己編譯。。。而 使用yum的話,這個弔軟體包有點想nuget,不過yum上面都是老的掉牙的軟體。。。有時候還要升級,比如我在安裝redis的另一種監控redm ...
  • 執行計劃的組成部分 正確的看執行計劃 DBMS_XPLAN 這個包是一個很好查看執行計劃,顯示很多格式,來分析執行計劃中存在的問題 format:控制詳細執行計劃輸出的格式,包含以下內容: BASIC:顯示最少的信息-ID,operation name TYPICAL :預設,在計劃中顯示最多相關信 ...
  • Sometimes there is a need to change the name of your database whether this is because the original name was based on some other project that is no lon ...
  • 一.安裝環境: 系統:Centos6.5x64 Apache: httpd-2.4.10.tar.gz Mysql: mysql-5.6.20-linux-glibc2.5-x86_64.tar.gz Php: php-5.6.0.tar.gz Apr: apr-1.5.1.tar.gz Apr-u ...
  • 快捷鍵總結: 打開cmd: windows+R 在”運行“命令框裡面輸入”mstsc.exe"按回車鍵後顯示輸入IP界面 鎖住觸屏區:fn+f6 鎖定當前用戶:window+L 任務管理器:ctrl+alt+delete 打開遠程連接:Window+r 打開我的電腦:Window+e 打開記事本:w ...
  • SWAT—Samba WEB管理工具 本文試驗環境是RHEL5.2+samba-swat-3.0.28。Server的IP是192.168.120.241。 1. swat介紹 SWAT:The Samba WEB Administration Tool SWAT是Samba的圖形化管理工具。我們可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...