10年程序员的抉择:Windows还是Linux?
作为一名拥有10年开发经验的程序员,如果一直使用Windows进行开发,而没有在Linux或Unix环境中开发过,与在Linux或Unix环境中开发10年的程序员相比,水平通常会有很大差距。文章作者分享了个人从Windows转向Linux开发的经历,强调在Linux环境下可以通过丰富的开源资源更快地学习和进步。文章还详细对比了Windows和Linux在API数量和学习难度上的差异,指出在Linux上开发可以更专注于系统架构和数据结构的学习,从而提升编程水平。
来源:菜鸟教程
ID:runoob
如果一个程序员一直使用Windows进行开发,而没有在Linux或Unix环境中开发过,工作10年后的水平与在Linux或Unix环境中开发10年的程序员相比,通常会有很大差距。这篇文章并不是为了贬低在Windows下开发的程序员,可能会让从事Windows开发的读者感到不快,我无意冒犯,只是分享我的个人感受。
我最初学习编程是在Windows平台上,从VB开始,后来转向VC++,当时使用的是VC6.0。在Windows上开发了5年后,我转向Linux进行开发。尽管我在Linux上开发时也曾参与过一些Windows项目,但在Linux上开发让我学到了更多东西,从开源代码中汲取了丰富的养分。我并不是说自己是高手,只是说在Linux上学习,你的进步会更快。
但我需要强调的是,我这里所说的情况是基于“在同样勤奋,同样努力程度,同样基础知识,同样工作年限,同样是做应用程序开发”的前提下。如果有不同的看法,希望大家在评论区发表意见。
可能大家会感到奇怪,为什么会出现这种情况呢?让我慢慢解释。
首先:闭源与开源
在Windows上开发的程序通常是封闭源代码的,特别是10年前,几乎找不到可用的开源软件。现在情况有所改善,许多Linux上的开源程序被移植到Windows上,但Linux上的开源程序增长得更多。
在Windows上编写应用程序时,需要使用MFC、WINSOCK、ODBC、FILE IO等,可以查找资料的地方主要是微软的官方文档MSDN,只有MSDN是最全面的,接下来是第三方网站如vckbase、CSDN、codeproject。这些网站上的代码通常是针对特定小功能的演示代码,代码质量和风格各不相同,都是一些小demo,简单研究后可以集成到自己的应用程序中。
如何构建一个完整且架构良好的应用程序,大学里不会教你,一切都得靠自己摸索。在公司项目中不断提升,直到项目上线,后期维护和修改代码时,你会发现自己当初的代码架构多么不合理,维护和修改是多么困难。
如果在互联网上找不到所需的资料,就只能靠自己想出实现方法,虽然功能实现时可能会很有成就感,但当你发现别人用了一个巧妙的方法实现同样功能时,你会突然意识到自己为何当时没想到这种方法呢?
在Windows上开发,不容易找到可参考的开源项目,一切都得靠自己。但在Linux上就不一样了,当你要开发一个新项目时,可以考虑是否有开源项目实现了类似的功能,可以下载源代码进行参考,详细了解其中的算法、架构设计等,这样在开发时就会得心应手,可以避免别人犯过的错误,少走很多弯路。
其次:要学习的知识量不同
学习Windows开发,你需要掌握大量的Windows API。截至2009年9月,Windows总API数量为2258个,且Windows API的参数多,参数类型复杂,记住这些内容并不容易,至少和学习一门外语一样难,大学英语四级要求掌握4500个单词。可以想象,学会这么多API的用法是多么困难。
而学习Linux开发,需要掌握的API数量相对较少。Linux内核API总共只有335个,但这些API主要用于编写驱动,开发应用程序基本用不到。开发应用程序主要使用C语言API,而Linux所有的C语言API只有279个,也就是说,只需要掌握不到300个API,就可以在Linux上顺利开发应用程序。与学习Windows上那一大堆API相比,你可以节省很多时间来学习其他知识。
下面举个简单的例子:
CreateFile ReadFile OpenFile WriteFile DeleteFile ReadFileEx WriteFileEx CloseHandle
这些是Windows上对文件操作的API,总共8个。看看CreateFile的参数:
代码语言:javascript代码运行次数:0运行复制```javascript 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 );
<code> 这些参数的意义和类型,你需要花多少时间来掌握呢? <p>再看看Linux上对文件操作的C语言API:</p><p>fopen fwrite fread fclose</p><p>总共四个,参数如下:</p><p>代码语言:javascript代码运行次数:0<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXpusdyfa5hlmtrIrn7Zmpaup4TgeaevdnGqyGySnnqNgrGv0Kysl3ar08h4pNGRupWwh5ioYLFlcpzJgJ-aebKGoq6VuKSCdp7csnuGmYaqtbKFupSZu6x5abR9o2SKjYZrvt2zso6Gjc-yoX6Z' rel='nofollow'>http://www.w3.org/2000/svg"><path</a> d="M6.66666 10.9999L10.6667 7.99992L6.66666 4.99992V10.9999ZM7.99999 1.33325C4.31999 1.33325 1.33333 4.31992 1.33333 7.99992C1.33333 11.6799 4.31999 14.6666 7.99999 14.6666C11.68 14.6666 14.6667 11.6799 14.6667 7.99992C14.6667 4.31992 11.68 1.33325 7.99999 1.33325ZM7.99999 13.3333C5.05999 13.3333 2.66666 10.9399 2.66666 7.99992C2.66666 5.05992 5.05999 2.66659 7.99999 2.66659C10.94 2.66659 13.3333 5.05992 13.3333 7.99992C13.3333 10.9399 10.94 13.3333 7.99999 13.3333Z" fill="currentcolor"></path></svg>运行<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXpusdyfa5hlmtrIrn7Zmpaup4TgeaevdnGqyGySnnqNgrGv0Kysl3ar08h4pNGRupWwh5ioYLFlcpzJgJ-aebKGoq6VuKSCdp7csnuGmYaqtbKFupSZu6x5abR9o2SKjYZrvt2zso6Gjc-yoX6Z' rel='nofollow'>http://www.w3.org/2000/svg"><path</a> clip-rule="evenodd" d="M4.5 15.5V3.5H14.5V15.5H4.5ZM12.5 5.5H6.5V13.5H12.5V5.5ZM9.5 2.5H3.5V12.5H1.5V0.5H11.5V2.5H9.5Z" fill="currentcolor" fill-rule="evenodd"></path></svg>复制<code>javascript FILE *fopen( const char *filename, const char *mode );</code>
两个参数,你需要花多少时间来掌握呢?可能有人会提出意见,说这些C语言API也能在Windows上运行。
没错,是能在Windows上运行,但仅掌握这些跨平台的C语言API就够了吗?难道所有在Windows上开发的人都喜欢用C语言API,不会用Windows本身的API吗?你不需要学习Windows的API吗?你的同事使用了CreateFile这个函数,你不需要搞懂它吗?你不需要看同事的代码吗?你不需要去维护别人写过的代码吗?
如果你还是这么想,我还可以举其他例子。下面是两个在Windows上创建线程的例子,第一个是创建安全工作线程,第二个是创建界面线程,还有一个函数我没有列出,是创建不安全的工作线程的,具体原理可以参考《win32多线程程序设计》,作者:(美)Jim Beveridge & Robert Wiener 著,侯捷 译。
代码语言:javascript代码运行次数:0运行复制javascript //线程安全的工作线程函数 uintptr_t _beginthreadex( void security, unsigned stack_size, unsigned ( start_address )( void ), void arglist, unsigned initflag, unsigned *thrdaddr ); //界面线程函数 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 );
<code> 在Windows上开发,我们必须掌握这两个创建线程的函数。当然,你也可以只知道 _beginthreadex 来在Windows上通用,但当看到别人的代码使用CreateThread时,你可不要不习惯,MFC中很多人用CreateThread。掌握这么多API是不是很累?就像你上学时背单词一样累。<p>下面列出Linux上创建线程的函数:</p><p>代码语言:javascript代码运行次数:0<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXpusdyfa5hlmtrIrn7Zmpaup4TgeaevdnGqyGySnnqNgrGv0Kysl3ar08h4pNGRupWwh5ioYLFlcpzJgJ-aebKGoq6VuKSCdp7csnuGmYaqtbKFupSZu6x5abR9o2SKjYZrvt2zso6Gjc-yoX6Z' rel='nofollow'>http://www.w3.org/2000/svg"><path</a> d="M6.66666 10.9999L10.6667 7.99992L6.66666 4.99992V10.9999ZM7.99999 1.33325C4.31999 1.33325 1.33333 4.31992 1.33333 7.99992C1.33333 11.6799 4.31999 14.6666 7.99999 14.6666C11.68 14.6666 14.6667 11.6799 14.6667 7.99992C14.6667 4.31992 11.68 1.33325 7.99999 1.33325ZM7.99999 13.3333C5.05999 13.3333 2.66666 10.9399 2.66666 7.99992C2.66666 5.05992 5.05999 2.66659 7.99999 2.66659C10.94 2.66659 13.3333 5.05992 13.3333 7.99992C13.3333 10.9399 10.94 13.3333 7.99999 13.3333Z" fill="currentcolor"></path></svg>运行<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXpusdyfa5hlmtrIrn7Zmpaup4TgeaevdnGqyGySnnqNgrGv0Kysl3ar08h4pNGRupWwh5ioYLFlcpzJgJ-aebKGoq6VuKSCdp7csnuGmYaqtbKFupSZu6x5abR9o2SKjYZrvt2zso6Gjc-yoX6Z' rel='nofollow'>http://www.w3.org/2000/svg"><path</a> clip-rule="evenodd" d="M4.5 15.5V3.5H14.5V15.5H4.5ZM12.5 5.5H6.5V13.5H12.5V5.5ZM9.5 2.5H3.5V12.5H1.5V0.5H11.5V2.5H9.5Z" fill="currentcolor" fill-rule="evenodd"></path></svg>复制```javascript int pthread_create( pthread_t <em>restrict thread, const pthread_attr_t </em>restrict attr, void <em>(</em>start_routine)(void<em>), void </em>restrict arg);</p></code>
你只需要知道这个函数就行了。
C语言API的大部分可以在Windows上运行,但在Windows上学习开发,你不仅要懂得C语言API,还需要花更多时间学习Windows系统本身的API。你可能会说,这样应该是Windows上学得更多,但我想要说的是,你掌握的API很多,但对于一个软件来说,最重要的是系统架构和数据结构,好的架构设计对后期的代码维护和功能修改至关重要,这也是新手写的代码到最后连自己都很难维护的原因,更不用说让别人来维护了。
API相当于基本功,系统架构和数据结构是内功,基本功练得越快,我们就有更多时间来练习内功。练习内功,我们需要多向高手学习。
在学习Windows应用开发的道路上,我们需要掌握更多的API,学习后,让我们的路越走越窄,没有特别丰富的开源代码可以参考,水平提高的速度很慢。
可喜的是,现在很多开源项目被移植到Windows上,也有很多跨平台的开源项目,常用的有wxWidget界面库,用法类似MFC,还有qt这个强大的界面库,以及开源的3D引擎OGRE,其架构非常值得学习。但Linux上的开源库要比Windows上的丰富得多,我们可以方便地从高手的代码中学习数据结构、设计模式和编程技巧,这也就是Linux上的程序员水平可能会比Windows上的程序员更高的原因,毕竟见多识广嘛,熟读唐诗三百首,不会作诗也会吟啊!
*声明:推送内容及图片来源于网络,部分内容会有所改动,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜。
- END -
好了,本文到此结束,带大家了解了《10年程序员的抉择:Windows还是Linux?》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

- 上一篇
- 即梦ai漫画效果生成攻略,二次元滤镜操作技巧

- 下一篇
- Linux存储优化,Syslog使用秘籍
-
- 文章 · 软件教程 | 14分钟前 |
- Win7截图快捷键有哪些
- 324浏览 收藏
-
- 文章 · 软件教程 | 17分钟前 |
- 电脑无法启动怎么修系统修复全攻略
- 119浏览 收藏
-
- 文章 · 软件教程 | 25分钟前 |
- 电脑无声音怎么办?原因及解决方法
- 187浏览 收藏
-
- 文章 · 软件教程 | 31分钟前 |
- 电脑开机黑屏原因及解决方法
- 446浏览 收藏
-
- 文章 · 软件教程 | 36分钟前 |
- Win11PIN无法使用怎么解决?教程详解
- 253浏览 收藏
-
- 文章 · 软件教程 | 43分钟前 | 自动重启 Win10系统
- Win10无故重启原因及解决方法
- 247浏览 收藏
-
- 文章 · 软件教程 | 46分钟前 |
- Win10修改hosts失败怎么解决
- 150浏览 收藏
-
- 文章 · 软件教程 | 1小时前 |
- Windows搜索失效?快速修复方法大全
- 223浏览 收藏
-
- 文章 · 软件教程 | 2小时前 |
- Win11触控屏失灵怎么修复?
- 266浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 142次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 168次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 159次使用
-
- 稿定PPT
- 告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
- 142次使用
-
- Suno苏诺中文版
- 探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
- 170次使用
-
- pe系统下载好如何重装的具体教程
- 2023-05-01 501浏览
-
- qq游戏大厅怎么开启蓝钻提醒功能-qq游戏大厅开启蓝钻提醒功能教程
- 2023-04-29 501浏览
-
- 吉吉影音怎样播放网络视频 吉吉影音播放网络视频的操作步骤
- 2023-04-09 501浏览
-
- 腾讯会议怎么使用电脑音频 腾讯会议播放电脑音频的方法
- 2023-04-04 501浏览
-
- PPT制作图片滚动效果的简单方法
- 2023-04-26 501浏览