`
bigpanda
  • 浏览: 109215 次
  • 性别: Icon_minigender_1
  • 来自: 斯德哥尔摩
文章分类
社区版块
存档分类
最新评论

关于学习操作系统编程

阅读更多
写这篇是因为simohayha在C++圈子里的留言:

simohayha 写道

希望圈子能专门开个报道贴,置顶的。
然后就是不知道老大们对linux源码了解多少?希望能就此发些文章,哈哈。


本来是想在留言里面回simohayha的,结果越写越多,改成博客算了,也许对别人也有帮助。没什么中心思想,大家胡乱看看。

我在读大学的时候是努力试图学习过linux源码的,在机房里打印出厚厚一叠纸,闷在计算机旁边猛看了好几天,饭也没好好吃,那些纸的质量不太好,有股怪味,空着肚子钻研,到后来闻那股味道,差点呕吐,于是放弃,出去大吃了一顿。

这是上世纪末的事情了,那时其实水平还没到,心里好奇,完全是赖蛤蟆想吃天鹅肉。学习这个事情,还是得循序渐进的。

要想学深入学习操作系统,推荐从这本书开始: Operatiing Systmes, Design and Implementation (by Tanenbaum, Woodhull),里面有个用于教学的操作系统Minix。Linux的某些方面,现在还可以找到Minix的影子。

我手里的这本书,是第二版,现在书最新版是第三版。Minix 3.0,也已经有点难度了, X Window System都有了。http://www.minix3.org/

要是觉得还是太复杂,还有个更简单的GeekOS,http://geekos.sourceforge.net/

OS的设计是受限于硬件的,尤其是CPU。当代OS的不同进程之间的内存保护,虚拟地址,都要通过硬件。所以对一个CPU的深刻了解,必不可少。对于Intel的CPU,应该读下面三本:

1. Intel Architecture Software Developer's Manual, Volume 1: Basic Architecture http://www.intel.com/design/PentiumII/manuals/243190.htm

2. Intel Architecture Software Developer's Manual, Volume 2: Instruction Set Reference Manual http://www.intel.com/design/PentiumII/manuals/243191.htm

3. Intel Architecture Software Developer’s Manual Volume 3: System Programming http://www.intel.com/design/PentiumII/manuals/243192.htm

尤其是第三本,编OS必看,虚拟内存,内存保护的东西全在里面。

操作系统里面代码最多的,实际是IO部分,理论不多,可事关重要。Mindshare出了一系列书,写的非常深入详细。http://www.mindshare.com/

学汇编开始直接学CISC的指令集太费劲了,推荐先从RISC汇编开始,西方大学计算机专业走的也是这条路。可以看的一本书是Introduction to RISC Assembly Language Programming,by John Waldron。里面用的处理器MIPS,可以下载个SPIM Simulator,在PC上跑。http://www.cs.wisc.edu/~larus/spim.html

Knuth老先生在The Art of Computer Programming一书里的例子,都是汇编,现在用的虚拟机是访RISC设计的,叫做MMIX,Knuth写了本书,叫做MMIXware, A RISC Computer for the Third Millennium, 呵呵,口气好大啊。

讲计算机架构的两本计算机学科经典书,是Patterson和Hennessy合写的两本:Computer Organization and Design: The Hardware/Software Interface 3rd edition,以及Computer Architecture, Fourth Edition: A Quantitative Approach

学汇编要注意一点,每个汇编器,其语法都不一样。在Windows下面写汇编,微软的Macro Assembler不是很合适,里面的Macro太多,都赶上高级语言了。有个开源的Netwide Assembler, http://sourceforge.net/projects/nasm, 倒是挺不错,推荐使用。

关于学习操作系统内核,如果不是非抱着Linux的话,BSD是个挺好的选择。代码的结构可能还清晰些。我有一台FreeBSD服务器,基本非常满意,有两点不足,MySQL是针对Linux优化的,在FreeBSD下性能不够好,但是根据Yahoo的人说(Yahoo用FreeBSD),FreeBSD最新版下用MySQL threading library重新编译性能可以接受了。Java也不尽如意,Sun 现在提供Java 5的binary给FreeBSD。但我在FreeBSD如果启动Tomcat开的内存太大,启动会失败。

想看看FreeBSD的源码,可以看看这里:http://www.leidinger.net/FreeBSD/src_docs/,里面列的都是内核各个部分的Code Reference Manual。里面那个讲kernel的文件有23M,共2205页,可见钻研这些是件极为费时费力的事情。

http://www.chinaunix.net/也有很多BSD的资料。

现在主流操作系统,就两大家了,一边是微软的以NT为内核的Win2k/XP/2003/Vista,另一边是以UNIX为根基的Linux/BSD/Solaris等等.

Tanenbaum说过这么一句话,操作系统是什么呢,就是操作系统定义的API。

学习Windows下的API,容易许多,资料全,另外Jeffrey Richter的Programming Application for MS Windows那本书写的太好了,Process, Job, Thread, Fiber, Critical Section, Event, Waitable Timer, Semaphore, Mutex,Virtual Memory, IO,写的非常详尽清楚。要是Linux/BSD下面也有这么一本书,该有多好啊。Linux, BSD里面的线程,家家各有不同,把人搞得糊里糊涂。

如果从研究操作系统是怎么实现的,那么正好反过来,Linxu/BSD/Solaris简单明了多了.除了代码公开,他们内部结构没有Windows那么复杂。Windows的源码,要是成为微软的MVP,也是可以看到的。Windows 2000的大部分源码,还泄露出来了,在网上流传了一阵子。

我个人觉得搞应用的去学习编译器回报可能更大,首先就是对语言了解很深入,写码,读码容易。如果会了编译器前台技术,可以自己写个分析代码的程序啊,那么读别人的码不久容易很多。现在虽然有现成的源码分析器,但是想想你有个数据库,一种是只能使用别人写好的界面,一种是可以用SQL自由查找,哪个好?如果学会了编译器后台技术,恭喜你,写任何一行代码都知道在计算机里怎么执行的,这是一种多么自由自在的境界啊。  
分享到:
评论
25 楼 小帽子 2007-05-23  
引用
为什么一说操作系统编程就是“写一个操作系统”啊?

9494  大部分是DRIVE  还是写LX上的实用程序比较好 既满足了自己对OS的好奇 有带来了一定的效益
24 楼 simohayha 2007-05-11  
hurricane1026 写道
黑眼豆豆 写道
提供一下这本书的下载地址
Operating Systems Design and Implementation, Third Edition

http://cpp.ga-la.com/downloads/ebooks/os/os_d&i_stdcpp.cn.rar

买吧。。。才20+,还能找到更便宜的么?
呵呵,那书俺看了,当年10块买的,不过觉得写的不怎么样,那本LINUX KERNEL DEVELOPMENT 学习操作系统更好一些.
23 楼 黑眼豆豆 2007-05-11  
提供一下这本书的下载地址
Operating Systems Design and Implementation, Third Edition

http://cpp.ga-la.com/downloads/ebooks/os/os_d&i_stdcpp.cn.rar
22 楼 jebtang 2007-03-08  
sp42 写道
lighter 写道
写任何一行代码都知道在计算机里怎么执行的,这是一种多么自由自在的境界啊。 .
人机合一啊!!


记得中科院计算所的博士生的一个作业就是从最底层的寄存器操作到word application去解释一个word文档的open的全过程。
21 楼 刑天战士 2007-02-25  
发觉很多操作系统黑客喜欢用trick解决问题,而不是倾向于使代码好懂。而且对于很多函数,变量的命名过于随便,使得像我这样的初学者望而生畏……
20 楼 七猫 2007-02-23  
Elminster 写道
为什么一说操作系统编程就是“写一个操作系统”啊?

写一个完整的操作系统,在今天早就远远超出了一个人所能负担的界限,特别是今天的操作系统里面有很大一块其实是各种驱动程序(这个倒真的是体力活),个人根本做不了。但有些事情还是很有趣、很值得一做的,比方说给 linux/free bsd 的 kernel 贡献一点东西。我印象里面 Redhat 搞 NPTL 的小组就没几个人,现在这个东西已经是 linux 下面线程的标准实现了。当然那个组有大牛压阵,可能听起来夸张一点,那么换一个我身边的例子好了:我一个朋友当初的毕业论文,就是把 linux 的 kernel 架到一个 RTOS 上面,这样凡是没有硬实时要求的东东都可以扔到 linux 里面去跑,省的重新在 RTOS 下面实现。挺有意思的一个东西,工程量也不大,一个人几个月就搞定了。


这个比较现实一些。而且中国不像外国是福利国家。先填饱肚子吧。
19 楼 sp42 2007-02-15  
lighter 写道
写任何一行代码都知道在计算机里怎么执行的,这是一种多么自由自在的境界啊。 .
人机合一啊!!
18 楼 avi2 2006-12-20  
介绍的真的很不错
geekos到真的不错,是一个值得学习的操作系统
17 楼 lix23 2006-12-17  
我要是对操作系统的架构,各模块作用有个较深入了解,也就满足了。
16 楼 刑天战士 2006-12-15  
最好的办法是找个小的不能再小的操作系统,然后给他添加功能……
15 楼 Elminster 2006-12-12  
为什么一说操作系统编程就是“写一个操作系统”啊?

写一个完整的操作系统,在今天早就远远超出了一个人所能负担的界限,特别是今天的操作系统里面有很大一块其实是各种驱动程序(这个倒真的是体力活),个人根本做不了。但有些事情还是很有趣、很值得一做的,比方说给 linux/free bsd 的 kernel 贡献一点东西。我印象里面 Redhat 搞 NPTL 的小组就没几个人,现在这个东西已经是 linux 下面线程的标准实现了。当然那个组有大牛压阵,可能听起来夸张一点,那么换一个我身边的例子好了:我一个朋友当初的毕业论文,就是把 linux 的 kernel 架到一个 RTOS 上面,这样凡是没有硬实时要求的东东都可以扔到 linux 里面去跑,省的重新在 RTOS 下面实现。挺有意思的一个东西,工程量也不大,一个人几个月就搞定了。
14 楼 lixigua 2006-12-11  
不一定要去做一个实用的操作系统阿,满足点好奇心而已阿-----不是学什么都能带来经济效益的,求知快乐而已。

一直有想法,有时间的时候还是要学学操作系统实现,心里老想着要见识操作系统的一点皮毛,现在一点皮毛都不懂,郁闷得很。
13 楼 Arath 2006-12-11  
基本如此,而且操作系统的推广不是一朝一夕可以完成的,即使你做出了比windows安全10000倍,好用100倍的操作系统,如果推广不力也只能是实验室里的花朵
12 楼 runes 2006-12-11  
Arath 写道
介绍的不错,加个精~
操作系统需要百倍的耐心和仔细,相关的核心技术实际上现在都已成熟,自我突破的空间比较小了。
而且正如楼主所说,写操作系统必须得到硬件厂家的全力支持,否则基本上是很难过的。
至于编译器...回报不会很高的。



我感觉,有机会试着做做这两个东东 demo级的,就够了,切身的知道到底是咋回事就行了,破除一下心中的“好奇”。

以国内目前的状况,如果是以专业的心态去搞它,闹不好最后弄个 “曲高和寡”。
11 楼 Arath 2006-12-11  
qiezi 写道
Arath 写道
介绍的不错,加个精~
操作系统需要百倍的耐心和仔细,相关的核心技术实际上现在都已成熟,自我突破的空间比较小了。
而且正如楼主所说,写操作系统必须得到硬件厂家的全力支持,否则基本上是很难过的。
至于编译器...回报不会很高的。

编译器回报挺高啊,看看IronPython, JRuby, 这些家伙们都被大公司收了,有技术的话做个编译器不需要很多人。操作系统就不一样了,那么多人参与,拿到钱的有多少?


不要这么看,那么Windows的回报不高吗?全球首富就是这么诞生的。
而且你去google一下,有多少人在做编译器,有很多听都没有听说过。
最后东西还没做成,分什么钱啊
10 楼 qiezi 2006-12-11  
Arath 写道
介绍的不错,加个精~
操作系统需要百倍的耐心和仔细,相关的核心技术实际上现在都已成熟,自我突破的空间比较小了。
而且正如楼主所说,写操作系统必须得到硬件厂家的全力支持,否则基本上是很难过的。
至于编译器...回报不会很高的。

编译器回报挺高啊,看看IronPython, JRuby, 这些家伙们都被大公司收了,有技术的话做个编译器不需要很多人。操作系统就不一样了,那么多人参与,拿到钱的有多少?
9 楼 Arath 2006-12-11  
介绍的不错,加个精~
操作系统需要百倍的耐心和仔细,相关的核心技术实际上现在都已成熟,自我突破的空间比较小了。
而且正如楼主所说,写操作系统必须得到硬件厂家的全力支持,否则基本上是很难过的。
至于编译器...回报不会很高的。
8 楼 taowen 2006-12-11  
Elminster 写道
taowen 写道
俺觉得操作系统就是体力活。编译器虽然也是体力活但是更有意思一些。


呵呵,你写过?来分享一下经验吧,我倒是好奇你为啥这么说。


No, I have no experience at all. Sorry.
7 楼 taowen 2006-12-11  
runes 写道
taowen 写道
俺觉得操作系统就是体力活。编译器虽然也是体力活但是更有意思一些。


偶,见过的JAVAEYE有史以来最NB的发言(也就是最牛的牛人现身了),或 吹的最凶的 吹牛贴,到底是哪个,有待 进一步证实,

希望 是前者,出一个真的牛人不容易啊,hoho.......


thanks. I am recalling my words now.
6 楼 runes 2006-12-11  
taowen 写道
俺觉得操作系统就是体力活。编译器虽然也是体力活但是更有意思一些。


偶,见过的JAVAEYE有史以来最NB的发言(也就是最牛的牛人现身了),或 吹的最凶的 吹牛贴,到底是哪个,有待 进一步证实,

希望 是前者,出一个真的牛人不容易啊,hoho.......

相关推荐

    从单片机编程到操作系统产生

    通过学习单片机编程结构和操作系统的原理,可以更好地理解计算机系统的工作原理,提高自己的编程能力和技术水平。同时,本文还将提供一些有用的资源和参考书籍,供读者进一步学习和研究。 在学习单片机编程和操作...

    一步一步写嵌入式操作系统--ARM编程的方法与实践.pdf

    根据提供的信息,我将展开关于“一步一步写嵌入式操作系统--ARM编程的方法与实践”这一主题下的知识点。 首先,我们从标题中可以提炼出两个核心内容,即“嵌入式操作系统”的编写以及“ARM编程”的方法和实践。这两...

    学习操作系统的看法,转自别人

    因此,学习操作系统首先要了解早期的编程环境和CPU工作原理,例如Intel的CPU文档中提到的系统级编程,它包括内存寻址、虚拟存储管理、中断处理和资源保护等关键内容。 操作系统主要分为应用级编程和系统级编程两...

    RT-Thread实时操作系统编程指南

    ### RT-Thread实时操作系统编程指南知识点总结 #### 一、实时系统概念 **实时系统**是一种特殊的计算机系统,其能够对外部事件或内部任务在指定的时间内作出响应。这类系统的特性在于时间敏感性,即系统必须能够在...

    学习资料,关于操作系统的学习文档

    这两个标签表明这份学习资料可能涉及到如何在这些编程语言中与操作系统进行交互。 C++和C#都是强大的编程语言,但它们与操作系统的联系各有不同。C++,作为一种静态类型的、编译式的、通用的、大小写敏感的、不仅...

    Linux-UNIX系统编程手册.pdf

    Linux/UNIX系统编程是计算机...总结来说,这本手册是Linux和UNIX系统编程学习者和专业人员必备的参考书籍之一,它不仅覆盖了广泛的系统编程知识,还提供了大量的实例和图表,帮助读者快速掌握复杂的编程概念和技巧。

    操作系统学习推荐书籍,操作系统Linux应该怎么学,怎么搭建,怎么编程

    推荐操作系统学习书籍,操作系统Linux应该怎么学,怎么搭建,怎么编程,按照第一二三组的顺序来学习

    01.什么是Linux系统编程 02. Linux系统编程的基本框架

    学习Linux系统编程C语言是基础,能够在Linux系统下通过指令完成文件的创建、复制、剪切、删除;文件夹的创建和删除;软件的下载和安装就可以。 Linux系统编程主要是学习Linux系统调用的接口,学习这些接口的功能、...

    VB游戏编程学习系统

    【VB游戏编程学习系统】是一款专为初学者设计的编程教育软件,主要针对Windows XP操作系统。该系统基于Visual Basic(VB)环境,旨在帮助用户掌握基础的VB编程技能,特别是对于游戏开发感兴趣的用户。然而,需要注意...

    新代 编程操作手册

    新代编程操作手册是针对新代品牌的编程系统提供的一份...通过深入学习新代编程操作手册,用户不仅可以掌握基本的编程技能,还能深入了解系统性能,提高加工效率和质量。无论是新手还是经验丰富的程序员,都能从中受益。

    linux系统编程(课件源码)

    Linux系统编程是IT领域中一个重要的学习主题,它涉及到操作系统层面的编程技术,包括与内核交互、进程管理、文件操作、网络通信等多个方面。在这个"最新C、C++全栈培训第24期高清无密-Linux系统编程(课件源码)"中,...

    Linux操作系统下C语言编程入门

    在IT领域,Linux操作系统是开发者和系统管理员的重要平台,尤其对于学习编程的初学者来说,理解Linux环境下的编程原理和实践具有很高的价值。本资源"Linux操作系统下C语言编程入门"是一个针对C语言初学者的PDF教程,...

    实现一个简单的操作系统

    学习操作系统需要从基础开始,掌握基本的编程知识,然后逐步深入了解操作系统的原理和实现。通过学习操作系统,我们可以更好地理解计算机的工作原理,提高自己的编程能力和问题解决能力。 在这个专栏中,我们将学习...

    《从单片机编程到操作系统产生》的附件

    总结来说,这个附件为读者提供了一个从基础的单片机编程到进阶的操作系统设计的学习路径。通过实际操作书中的例程,不仅可以提升编程技能,还能深入了解计算机系统的运行原理,为从事相关领域的开发工作打下坚实基础...

    网络学习空间应用研究——以《Unix_Linux系统编程》课程为例.pdf

    网络学习空间应用研究——以《Unix_Linux系统编程》课程为例.pdf

    QNX实时操作系统开发手册(中文)包含实例

    本手册主要介绍了QNX操作系统的基本概念、系统结构、进程间通信、文件操作命令、应用程序开发等方面的知识,旨在帮助开发人员快速熟悉QNX操作系统和编程技术。 QNX操作系统的开发环境包括开发工具、编译器、库函数...

Global site tag (gtag.js) - Google Analytics