星期五, 一月 18, 2008

哈哈一笑

1 小白长得很像他的哥哥,打一句成语

答案:真相大白

2 问:为什么梨子是温度最高的水果?

答 :梨子(离子 )烫

3 问 : 世界上最富有同情心的动漫人物是谁

答: 机器猫

为什么: 因为他总是向人伸出 圆手 !

4 问 : 世界上最最黑暗的动漫人物是谁?

答: 还是机器猫

为什么: 因为他伸手不见五指

5 有一只狼来到了北极,不小心掉到ㄌ冰海中,被捞ㄌ起来时变成了什么 ?

答 : 槟榔

Q:世界上什么鸡跑的快?什么鸡慢?

A:肯德鸡块(快)   妮可基特曼(慢)

Q:非洲食人族的酋长吃什么?

A:人啊!

Q:那有一天,酋长病了,医生告诉他要吃素,那他吃什么?

A:吃植物人!~~

Q:什么动物是高手?

A:猪,因为猪 (珠)算高手

Q:什么动物最容易被贴在墙壁上?

A:海(报 )豹

Q:胖子从12楼掉下来会变什么?

A: 死胖子

Q:吃饱饭了谁会帮你添饭?

A:飞龙嘛 ,因为飞龙在(天)添

Q:一只小狗在沙漠中旅行,结果死了,问他是怎么死的?

A:他是憋死的,因为沙漠里没有电线杆尿尿。

Q:一只小狗在沙漠中旅行,找到了电线杆,结果还是憋死了,为什么?

A:点线杆上贴着"此处不许小便"

Q:一只小狗在沙漠中旅行,找到了电线杆,上面没贴任何东西,结果还是憋死了,为什么?

A:很多小狗在排队,没等到.

Q:一只小狗在沙漠中旅行,找到了电线杆,上面没贴任何东西,排队也排到了,结果还是憋死了,为什么?

A:因为后面是两个漂亮狗MM,他不好意思。

Q 有一棵三角形的树被送到北极去种 ...请问长大后!那棵树叫 ....?

A…三角函数(寒树 )..............       

Q:老板,你这不叫牛肉面吗?怎么连牛肉都没有?!  

A:人家还叫老婆饼呢,难不成你买的时候还送你一个老婆 ?!       

Q:白色的马叫白马,黑色的马叫黑马,黑白相间的马叫斑马,那么黑色白色红色相间的马叫什么马?  

A:是害羞的斑马,呵呵       

Q:有一天,有一根火柴棒它头很痒,就去抓,头就烧起来了。然后被送去医院,从急诊室出来之后,猜猜变成什么了  

A:棉花棒,因为头被包扎起来了。       

Q:为什么蚕宝宝很有钱  

A:因为 .....蚕会结茧(节俭 )       

Q:狼、老虎和狮子谁玩游戏一定会被淘汰?

A:狼,因为:桃太郎(淘汰狼)       

Q:神的交通工具是什么?

A:-- 神奇(骑)宝贝       

Q:巧克力和西红柿打架,巧克力赢了。(打一食品名)  

A:谜底:巧克力棒       

Q巧克力和鸡蛋打架,巧克力又赢了。(再打一食品名)  

A谜底:巧克力棒棒       

Q巧克力和西红柿、鸡蛋同时打架,巧克力又赢了。(再次打一食品名)  

A谜底:西红柿鸡蛋面   :  

Q巧克力和鸡蛋又打架,巧克力又赢了。(再打一食品名)  

A鸡蛋酥 (输)       

Q一根手指头的英文叫做 ONE,两根手指头的英文叫做TWO,依次类推,四根手手指头的英文叫做 four,那么弯起来的四根手指头的英文叫什么  

A答案:WONDERFFUL (弯的 FOUR)       

Q为什么狗越来越小?  

A答案:因为狗越走越远       

Q有一只蜘蛛它走过一堆屎,请问他用几只脚走路?  

A-不是 8脚走...而是用6只脚 ,因为它用了两脚塞鼻子捂臭~       

Q小白,小黄 ,小蓝坐长途汽车,谁会晕车 ?  

A答:小白 ,因为小白会吐(小白兔 )       

Q小白 +小白=?  

A答:小白兔 (小白TWO):  

Q屈原的老婆姓什么?  

A姓陈,因为屈陈(臣)氏       

Q猴子最讨厌什么线?  

A平行线,因为没有相交(香蕉)       

Q哪为历史人物最欠扁  

A苏武 -苏武牧羊北海边(被海扁)       

Q:一只兔子和一只跑得很快的乌龟赛跑,猜一猜谁赢拉?  

A:兔子 ~~  

Q:错~!是乌龟拉,前面有说是一只跑很快的乌龟,跑很快噢~~  

Q:兔子不甘心,又和一只戴了墨镜的乌龟比赛跑步,这次谁赢拉?  

A:恩。。兔子吧  

Q:错~~!那只乌龟把墨镜一摘,也!又是刚才那只跑很快的乌龟噢

^O^ 笑了麻烦添个人气咯~

星期三, 一月 16, 2008

Index of Documentation for People Interested in Writing and/or Understanding the Linux Kernel.

Index of Documentation for People Interested in Writing and/or
Understanding the Linux Kernel.


  • ON-LINE DOCS:

      • Title: "The Linux Kernel"
        Author: David A. Rusling.
        URL: http://www.linuxdoc.org/LDP/tlk/tlk.html
        Keywords: everything!, book.
        Description: On line, 200 pages book describing most aspects of the Linux Kernel. Probably, the first reference for beginners. Lots of illustrations explaining data structures use and relationships in the purest Richard W. Stevens' style. Contents: "1.-Hardware Basics, 2.-Software Basics, 3.-Memory Management, 4.-Processes, 5.-Interprocess Communication Mechanisms, 6.-PCI, 7.-Interrupts and Interrupt Handling, 8.-Device Drivers, 9.-The File system, 10.-Networks, 11.-Kernel Mechanisms, 12.-Modules, 13.-The Linux Kernel Sources, A.-Linux Data Structures, B.-The Alpha AXP Processor, C.-Useful Web and FTP Sites, D.-The GNU General Public License, Glossary". In short: a must have.


      • Title: "The Linux Kernel Hackers' Guide"
        Author: Michael K.Johnson and others.
        URL: http://www.linuxdoc.org/LDP/khg/HyperNews/get/khg.html
        Keywords: everything!
        Description: No more Postscript book-like version. Only HTML now. Many people have contributed. The interface is similar to web available mailing lists archives. You can find some articles and then some mails asking questions about them and/or complementing previous contributions. A little bit anarchic in this aspect, but with some valuable information in some cases.


      • Title: "Conceptual Architecture of the Linux Kernel"
        Author: Ivan T. Bowman.
        URL: http://plg.uwaterloo.ca/~itbowman/papers/CS746G-a1.html
        Keywords: conceptual software arquitecture, extracted design, reverse engineering, system structure.
        Description: Conceptual software arquitecture of the Linux kernel, automatically extracted from the source code. Very detailed. Good figures. Gives good overall kernel understanding.


      • Title: "Concrete Architecture of the Linux Kernel"
        Author: Ivan T. Bowman, Saheem Siddiqi, and Meyer C. Tanuan.
        URL: http://plg.uwaterloo.ca/~itbowman/papers/CS746G-a2.html
        Keywords: concrete arquitecture, extracted design, reverse engineering, system structure, dependencies.
        Description: Concrete arquitecture of the Linux kernel, automatically extracted from the source code. Very detailed. Good figures. Gives good overall kernel understanding. This papers focus on lower details than its predecessor (files, variables...).


      • Title: "Linux as a Case Study: Its Extracted Software Architecture"
        Author: Ivan T. Bowman, Richard C. Holt and Neil V. Brewster.
        URL: http://plg.uwaterloo.ca/~itbowman/papers/linuxcase.html
        Keywords: software architecture, architecture recovery, redocumentation.
        Description: Paper appeared at ICSE'99, Los Angeles, May 16-22, 1999. A mixture of the previous two documents from the same author.


      • Title: "Overview of the Virtual File System"
        Author: Richard Gooch.
        URL: http://www.atnf.csiro.au/~rgooch/linux/vfs.txt
        Keywords: VFS, File System, mounting filesystems, opening files, dentries, dcache.
        Description: Brief introduction to the Linux Virtual File System. What is it, how it works, operations taken when opening a file or mounting a file system and description of important data structures explaining the purpose of each of their entries.


      • Title: "The Linux RAID-1, 4, 5 Code"
        Author: Ingo Molnar, Gadi Oxman and Miguel de Icaza.
        URL: http://www2.linuxjournal.com/lj-issues/issue44/2391.html
        Keywords: RAID, MD driver.
        Description: Linux Journal Kernel Korner article. Here is it's abstract: "A description of the implementation of the RAID-1, RAID-4 and RAID-5 personalities of the MD device driver in the Linux kernel, providing users with high performance and reliable, secondary-storage capability using software".


      • Title: "Dynamic Kernels: Modularized Device Drivers"
        Author: Alessandro Rubini.
        URL: http://www2.linuxjournal.com/lj-issues/issue23/1219.html
        Keywords: device driver, module, loading/unloading modules, allocating resources.
        Description: Linux Journal Kernel Korner article. Here is it's abstract: "This is the first of a series of four articles co-authored by Alessandro Rubini and Georg Zezchwitz which present a practical approach to writing Linux device drivers as kernel loadable modules. This installment presents an introduction to the topic, preparing the reader to understand next month's installment".


      • Title: "Dynamic Kernels: Discovery"
        Author: Alessandro Rubini.
        URL: http://www2.linuxjournal.com/lj-issues/issue24/1220.html
        Keywords: character driver, init_module, clean_up module, autodetection, mayor number, minor number, file operations, open(), close().
        Description: Linux Journal Kernel Korner article. Here is it's abstract: "This article, the second of four, introduces part of the actual code to create custom module implementing a character device driver. It describes the code for module initialization and cleanup, as well as the open() and close() system calls".


      • Title: "The Devil's in the Details"
        Author: Georg v. Zezschwitz and Alessandro Rubini.
        URL: http://www2.linuxjournal.com/lj-issues/issue25/1221.html
        Keywords: read(), write(), select(), ioctl(), blocking/non blocking mode, interrupt handler.
        Description: Linux Journal Kernel Korner article. Here is it's abstract: "This article, the third of four on writing character device drivers, introduces concepts of reading, writing, and using ioctl-calls".


      • Title: "Dissecting Interrupts and Browsing DMA"
        Author: Alessandro Rubini and Georg v. Zezschwitz.
        URL: http://www2.linuxjournal.com/lj-issues/issue26/1222.html
        Keywords: interrupts, irqs, DMA, bottom halves, task queues.
        Description: Linux Journal Kernel Korner article. Here is it's abstract: "This is the fourth in a series of articles about writing character device drivers as loadable kernel modules. This month, we further investigate the field of interrupt handling. Though it is conceptually simple, practical limitations and constraints make this an ``interesting'' part of device driver writing, and several different facilities have been provided for different situations. We also investigate the complex topic of DMA".


      • Title: "Device Drivers Concluded"
        Author: Georg v. Zezschwitz.
        URL: http://www2.linuxjournal.com/lj-issues/issue28/1287.html
        Keywords: address spaces, pages, pagination, page management, demand loading, swapping, memory protection, memory mapping, mmap, virtual memory areas (VMAs), vremap, PCI.
        Description: Finally, the above turned out into a five articles series. This latest one's introduction reads: "This is the last of five articles about character device drivers. In this final section, Georg deals with memory mapping devices, beginning with an overall description of the Linux memory management concepts".


      • Title: "Network Buffers And Memory Management"
        Author: Alan Cox.
        URL: http://www2.linuxjournal.com/lj-issues/issue30/1312.html
        Keywords: sk_buffs, network devices, protocol/link layer variables, network devices flags, transmit, receive, configuration, multicast.
        Description: Linux Journal Kernel Korner. Here is the abstract: "Writing a network device driver for Linux is fundamentally simple---most of the complexity (other than talking to the hardware) involves managing network packets in memory".


      • Title: "Writing Linux Device Drivers"
        Author: Michael K. Johnson.
        URL: http://people.redhat.com/johnsonm/devices.html
        Keywords: files, VFS, file operations, kernel interface, character vs block devices, I/O access, hardware interrupts, DMA, access to user memory, memory allocation, timers.
        Description: Introductory 50-minutes (sic) tutorial on writing device drivers. 12 pages written by the same author of the "Kernel Hackers' Guide" which give a very good overview of the topic.


      • Title: "The Venus kernel interface"
        Author: Peter J. Braam.
        URL: http://www.coda.cs.cmu.edu/doc/html/kernel-venus-protocol.html
        Keywords: coda, filesystem, venus, cache manager.
        Description: "This document describes the communication between Venus and kernel level file system code needed for the operation of the Coda filesystem. This version document is meant to describe the current interface (version 1.0) as well as improvements we envisage".


      • Title: "Programming PCI-Devices under Linux"
        Author: Claus Schroeter.
        URL: ftp://ftp.llp.fu-berlin.de/pub/linux/LINUX-LAB/whitepapers/pcip.ps.gz
        Keywords: PCI, device, busmastering.
        Description: 6 pages tutorial on PCI programming under Linux. Gives the basic concepts on the architecture of the PCI subsystem, as long as basic functions and macros to read/write the devices and perform busmastering.


      • Title: "Writing Character Device Driver for Linux"
        Author: R. Baruch and C. Schroeter.
        URL: ftp://ftp.llp.fu-berlin.de/pub/linux/LINUX-LAB/whitepapers/drivers.ps.gz
        Keywords: character device drivers, I/O, signals, DMA, accessing ports in user space, kernel environment.
        Description: 68 pages paper on writing character drivers. A little bit old (1.993, 1.994) although still useful.


      • Title: "Design and Implementation of the Second Extended Filesystem"
        Author: Rémy Card, Theodore Ts'o, Stephen Tweedie.
        URL: http://web.mit.edu/tytso/www/linux/ext2intro.html
        Keywords: ext2, linux fs history, inode, directory, link, devices, VFS, physical structure, performance, benchmarks, ext2fs library, ext2fs tools, e2fsck.
        Description: Paper written by three of the top ext2 hackers. Covers Linux filesystems history, ext2 motivation, ext2 features, design, physical structure on disk, performance, benchmarks, e2fsck's passes description... A must read!
        Notes: This paper was first published in the Proceedings of the First Dutch International Symposium on Linux, ISBN 90-367-0385-9.



      • Title: "Journaling the Linux ext2fs Filesystem"
        Author: Stephen C. Tweedie.
        URL: ftp://ftp.uk.linux.org/pub/linux/sct/fs/jfs/journal-design.ps.gz
        Keywords: ext3, journaling.
        Description: Excellent 8-pages paper explaining the journaling capabilities added to ext2 by the author, showing different problems faced and the alternatives chosen.




      • Title: "Linux Kernel Module Programming Guide"
        Author: Ori Pomerantz.
        URL: http://www.linuxdoc.org/LDP/lkmpg/mpg.html
        Keywords: modules, GPL book, /proc, ioctls, system calls, interrupt handlers .
        Description: Very nice 92 pages GPL book on the topic of modules programming. Lots of examples.


      • Title: "Device File System (devfs) Overview"
        Author: Richard Gooch.
        URL: http://www.atnf.csiro.au/~rgooch/linux/docs/devfs.txt
        Keywords: filesystem, /dev, devfs, dynamic devices, major/minor allocation, device management.
        Description: Document describing Richard Gooch's controversial devfs, which allows for dynamic devices, only shows present devices in /dev, gets rid of major/minor numbers allocation problems, and allows for hundreds of identical devices (which some USB systems might demand soon).


      • Title: "I/O Event Handling Under Linux"
        Author: Richard Gooch.
        URL: http://www.atnf.csiro.au/~rgooch/linux/docs/io-events.html
        Keywords: IO, I/O, select(2), poll(2), FDs, aio_read(2), readiness event queues.
        Description: From the Introduction: "I/O Event handling is about how your Operating System allows you to manage a large number of open files (file descriptors in UNIX/POSIX, or FDs) in your application. You want the OS to notify you when FDs become active (have data ready to be read or are ready for writing). Ideally you want a mechanism that is scalable. This means a large number of inactive FDs cost very little in memory and CPU time to manage".


      • Title: "The Kernel Hacking HOWTO"
        Author: Various Talented People, and Rusty.
        URL: http://www.lisoleg.net/doc/Kernel-Hacking-HOWTO/kernel-hacking-HOWTO.html
        Keywords: HOWTO, kernel contexts, deadlock, locking, modules, symbols, return conventions.
        Description: From the Introduction: "Please understand that I never wanted to write this document, being grossly underqualified, but I always wanted to read it, and this was the only way. I simply explain some best practices, and give reading entry-points into the kernel sources. I avoid implementation details: that's what the code is for, and I ignore whole tracts of useful routines. This document assumes familiarity with C, and an understanding of what the kernel is, and how it is used. It was originally written for the 2.3 kernels, but nearly all of it applies to 2.2 too; 2.0 is slightly different".


      • Title: "Kernel Hacking HOWTO"
        Author: Andrew Ebling.
        URL: http://www.kernelhacking.org/docs/kernelhacking-HOWTO/
        Keywords: HOWTO, kernel hacking, getting started, source navigation, kernel debugging, profiling, benchmarking.
        Description: Another kernel hacking howto. More recent than Rusty's.
        Notes: Some TODO sections. Want to help?


      • Title: "ALSA 0.5.0 Developer documentation"
        Author: Stephan 'Jumpy' Bartels .
        URL: http://www.math.TU-Berlin.de/~sbartels/alsa/
        Keywords: ALSA, sound, soundcard, driver, lowlevel, hardware.
        Description: Advanced Linux Sound Architecture for developers, both at kernel and user-level sides. Work in progress. ALSA is supposed to be Linux's next generation sound architecture.


      • Title: "Programming Guide for Linux USB Device Drivers"
        Author: Detlef Fliegl.
        URL: http://usb.in.tum.de/usbdoc/
        Keywords: USB, universal serial bus.
        Description: A must-read. From the Preface: "This document should give detailed information about the current state of the USB subsystem and its API for USB device drivers. The first section will deal with the basics of USB devices. You will learn about different types of devices and their properties. Going into detail you will see how USB devices communicate on the bus. The second section gives an overview of the Linux USB subsystem [2] and the device driver framework. Then the API and its data structures will be explained step by step. The last section of this document contains a reference of all API calls and their return codes".
        Notes: Beware: the main page states: "This document may not be published, printed or used in excerpts without explicit permission of the author". Fortunately, it may still be read...


      • Title: "Tour Of the Linux Kernel Source"
        Author: Vijo Cherian.
        URL: http://www.geocities.com/vijoc/tolks/tolks.html
        Keywords: .
        Description: A classic of this page! Was lost for a while and is back again. Thanks Vijo! TOLKS: the name says it all. A tour of the sources, describing directories, files, variables, data structures... It covers general stuff, device drivers, filesystems, IPC and Networking Code.


      • Title: "Linux Kernel Mailing List Glossary"
        Author: John Levon.
        URL: http://www.movement.uklinux.net/glossary.html
        Keywords: glossary, terms, linux-kernel.
        Description: From the introduction: "This glossary is intended as a brief description of some of the acronyms and terms you may hear during discussion of the Linux kernel".


      • Title: "Linux Kernel Locking HOWTO"
        Author: Various Talented People, and Rusty.
        URL: http://netfilter.kernelnotes.org/unreliable-guides/kernel-locking-HOWTO.html
        Keywords: locks, locking, spinlock, semaphore, atomic, race condition, bottom halves, tasklets, softirqs.
        Description: The title says it all: document describing the locking system in the Linux Kernel either in uniprocessor or SMP systems.
        Notes: "It was originally written for the later (>2.3.47) 2.3 kernels, but most of it applies to 2.2 too; 2.0 is slightly different". Freely redistributable under the conditions of the GNU General Public License.


      • Title: "Global spinlock list and usage"
        Author: Rick Lindsley.
        URL: http://lse.sourceforge.net/lockhier/global-spin-lock
        Keywords: spinlock.
        Description: This is an attempt to document both the existence and usage of the spinlocks in the Linux 2.4.5 kernel. Comprehensive list of spinlocks showing when they are used, which functions access them, how each lock is acquired, under what conditions it is held, whether interrupts can occur or not while it is held...


      • Title: "Porting Linux 2.0 Drivers To Linux 2.2: Changes and New Features "
        Author: Alan Cox.
        URL: http://www.linux-mag.com/1999-05/gear_01.html
        Keywords: ports, porting.
        Description: Article from Linux Magazine on porting from 2.0 to 2.2 kernels.



      • Title: "How To Make Sure Your Driver Will Work On The Power Macintosh"
        Author: Paul Mackerras.
        URL: http://www.linux-mag.com/1999-07/gear_01.html
        Keywords: Mac, Power Macintosh, porting, drivers, compatibility.
        Description: The title says it all.







      • Title: "Video4linux Drivers, Part 1: Video-Capture Device"
        Author: Alan Cox.
        URL: http://www.linux-mag.com/2000-01/gear_01.html
        Keywords: video4linux, driver, video capture, capture devices, camera driver.
        Description: The title says it all.


      • Title: "Video4linux Drivers, Part 2: Video-capture Devices"
        Author: Alan Cox.
        URL: http://www.linux-mag.com/2000-02/gear_01.html
        Keywords: video4linux, driver, video capture, capture devices, camera driver, control, query capabilities, capability, facility.
        Description: The title says it all.



      • Title: "Linux 2.4 Kernel Internals"
        Author: Tigran Aivazian and Christoph Hellwig.
        URL: http://www.moses.uklinux.net/patches/lki.html
        Keywords: Linux, kernel, booting, SMB boot, VFS, page cache.
        Description: A little book used for a short training course. Covers building the kernel image, booting (including SMP bootup), process management, VFS and more.


      • Title: "Linux IP Networking. A Guide to the Implementation and Modification of the Linux Protocol Stack."
        Author: Glenn Herrin.
        URL: http://www.cs.unh.edu/cnrg/gherrin
        Keywords: network, networking, protocol, IP, UDP, TCP, connection, socket, receiving, transmitting, forwarding, routing, packets, modules, /proc, sk_buff, FIB, tags.
        Description: Excellent paper devoted to the Linux IP Networking, explaining anything from the kernel's to the user space configuration tools' code. Very good to get a general overview of the kernel networking implementation and understand all steps packets follow from the time they are received at the network device till they are delivered to applications. The studied kernel code is from 2.2.14 version. Provides code for a working packet dropper example.



      • Title: "Linux PCMCIA Programmer's Guide"
        Author: David Hinds.
        URL: http://pcmcia-cs.sourceforge.net/ftp/doc/PCMCIA-PROG.html
        Keywords: PCMCIA.
        Description: "This document describes how to write kernel device drivers for the Linux PCMCIA Card Services interface. It also describes how to write user-mode utilities for communicating with Card Services.



      • Title: "(nearly) Complete Linux Loadable Kernel Modules. The definitive guide for hackers, virus coders and system administrators."
        Author: pragmatic/THC.
        URL: http://packetstormsecurity.org/docs/hack/LKM_HACKING.html
        Keywords: syscalls, intercept, hide, abuse, symbol table.
        Description: Interesting paper on how to abuse the Linux kernel in order to intercept and modify syscalls, make files/directories/processes invisible, become root, hijack ttys, write kernel modules based virus... and solutions for admins to avoid all those abuses.
        Notes: For 2.0.x kernels. Gives guidances to port it to 2.2.x kernels. Also available in txt format at http://www.blacknemesis.org/hacking/txt/cllkm.txt


      • Title: "Linux Device Drivers, 2nd Edition"
        Author: Alessandro Rubini and Jonathan Corbet.
        URL: http://www.oreilly.com/catalog/linuxdrive2/chapter/book/index.html
        Keywords: device drivers, modules, debugging, memory, hardware, interrupt handling, char drivers, block drivers, kmod, mmap, DMA, buses.
        Description: O'Reilly's popular book, now also on-line under the GNU Free Documentation License.
        Notes: You can also buy it in paper-form from O'Reilly. See below under BOOKS (Not on-line).


      • Title: "Linux Kernel Threads in Device Drivers"
        Author: Martin Frey.
        URL: http://www.scs.ch/~frey/linux/kernelthreads.html
        Keywords: threads, creation, stopping, initialization.
        Description: How to start and stop kernel threads in a loadable module.



    • BOOKS: (Not on-line)

      • Title: "Linux Device Drivers"
        Author: Alessandro Rubini.
        Publisher: O'Reilly & Associates.
        Date: 1998.
        Pages: 439.
        ISBN: 1-56592-292-1



      • Title: "Linux Kernel Internals"
        Author: Michael Beck.
        Publisher: Addison-Wesley.
        Date: 1997.
        ISBN: 0-201-33143-8 (second edition)


      • Title: "The Design of the UNIX Operating System"
        Author: Maurice J. Bach.
        Publisher: Prentice Hall.
        Date: 1986.
        Pages: 471.
        ISBN: 0-13-201757-1


      • Title: "The Design and Implementation of the 4.3 BSD UNIX Operating System"
        Author: Samuel J. Leffler, Marshall Kirk McKusick, Michael J. Karels, John S. Quarterman.
        Publisher: Addison-Wesley.
        Date: 1989 (reprinted with corrections on October, 1990).
        ISBN: 0-201-06196-1


      • Title: "The Design and Implementation of the 4.4 BSD UNIX Operating System"
        Author: Marshall Kirk McKusick, Keith Bostic, Michael J. Karels, John S. Quarterman.
        Publisher: Addison-Wesley.
        Date: 1996.
        ISBN: 0-201-54979-4


      • Title: "Programmation Linux 2.0 API systeme et fonctionnement du noyau"
        Author: Remy Card, Eric Dumas, Franck Mevel.
        Publisher: Eyrolles.
        Date: 1997.
        Pages: 520.
        ISBN: 2-212-08932-5
        Notes: French.


      • Title: "The Linux Kernel Book"
        Author: Remy Card, Eric Dumas, Franck Mevel.
        Publisher: John Wiley & Sons.
        Date: 1998.
        ISBN: 0-471-98141-9
        Notes: English translation.


      • Title: "Linux 2.0"
        Author: Remy Card, Eric Dumas, Franck Mevel.
        Publisher: Gestión 2000.
        Date: 1997.
        Pages: 501.
        ISBN: 8-480-88208-5
        Notes: Spanish translation.


      • Title: "Unix internals -- the new frontiers"
        Author: Uresh Vahalia.
        Publisher: Prentice Hall.
        Date: 1996.
        Pages: 600.
        ISBN: 0-13-101908-2


      • Title: "Linux Core Kernel Commentary. Guide to Insider's Knowledge on the Core Kernel of the Linux Code"
        Author: Scott Maxwell.
        Publisher: Coriolis.
        Date: 1999.
        Pages: 592.
        ISBN: 1-57610-469-9
        Notes: CD-ROM included. Line by line commentary of the kernel code.


      • Title: "Linux IP Stacks Commentary"
        Author: Stephen Satchell and HBJ Clifford.
        Publisher: Coriolis.
        Date: 2000.
        Pages: ???.
        ISBN: 1-57610-470-2
        Notes: Line by line source code commentary book.


      • Title: "Programming for the real world - POSIX.4"
        Author: Bill O. Gallmeister.
        Publisher: O'Reilly & Associates, Inc..
        Date: 1995.
        Pages: ???.
        ISBN: I-56592-074-0
        Notes: Though not being directly about Linux, Linux aims to be POSIX. Good reference.


      • Title: "Understanding the Linux Kernel"
        Author: Daniel P. Bovet and Marco Cesati.
        Publisher: O'Reilly & Associates, Inc..
        Date: 2000.
        Pages: 702.
        ISBN: 0-596-00002-2
        Notes: Further information in http://www.oreilly.com/catalog/linuxkernel/


      • Title: "Kernel Projects for Linux"
        Author: Gary J. Nutt.
        Publisher: Addison-Wesley.
        Date: 2000.
        Pages: 239.
        ISBN: 0-201-61243-7
        Notes: Provides 12 exercises related to OS functions implementation. Comes with a CD-ROM.


      • Title: "UNIX Systems for Modern Architectures: Symmetric Multiprocesssing and Caching for Kernel Programmers"
        Author: Curt Schimmel.
        Publisher: Addison Wesley.
        Date: June, 1994.
        Pages: 432.
        ISBN: 0-201-63338-8
        Notes: .


    • MISCELLANEOUS:

      • Name: linux/Documentation
        Author: Many.
        URL: Just look inside your kernel sources.
        Keywords: anything, DocBook.
        Description: Documentation that comes with the kernel sources, inside the Documentation directory. Some pages from this document (including this document itself) have been moved there, and might be more up to date than the web version.


      • Name: "Linux Source Driver"
        URL: http://lsd.linux.cz/
        Keywords: Browsing source code.
        Description: "Linux Source Driver (LSD) is an application, which can make browsing source codes of Linux kernel easier than you can imagine. You can select between multiple versions of kernel (e.g. 0.01, 1.0.0, 2.0.33, 2.0.34pre13, 2.0.0, 2.1.101 etc.). With LSD you can search Linux kernel (fulltext, macros, types, functions and variables) and LSD can generate patches for you on the fly (files, directories or kernel)".


      • Name: "Linux Kernel Source Reference"
        Author: Thomas Graichen.
        URL: http://innominate.org/~graichen/projects/lksr/
        Keywords: CVS, web, cvsweb, browsing source code.
        Description: Web interface to a CVS server with the kernel sources. "Here you can have a look at any file of the Linux kernel sources of any version starting from 1.0 up to the (daily updated) current version available. Also you can check the differences between two versions of a file".


      • Name: "Cross-Referencing Linux"
        URL: http://lxr.linux.no/source/
        Keywords: Browsing source code.
        Description: Another web-based Linux kernel source code browser. Lots of cross references to variables and functions. You can see where they are defined and where they are used.


      • Name: "Linux Weekly News"
        URL: http://lwn.net/
        Keywords: latest kernel news.
        Description: The title says it all. There's a fixed kernel section summarizing developers' work, bug fixes, new features and versions produced during the week. Published every Thursday.


      • Name: "Kernel Traffic"
        URL: http://kt.zork.net/kernel-traffic/
        Keywords: linux-kernel mailing list, weekly kernel news.
        Description: Weekly newsletter covering the most relevant discussions of the linux-kernel mailing list.


      • Name: "CuTTiNG.eDGe.LiNuX"
        URL: http://edge.linuxhq.com/
        Keywords: changelist.
        Description: Site which provides the changelist for every kernel release. What's new, what's better, what's changed. Myrdraal reads the patches and describes them. Pointers to the patches are there, too.


      • Name: "New linux-kernel Mailing List FAQ"
        URL: http://www.tux.org/lkml/
        Keywords: linux-kernel mailing list FAQ.
        Description: linux-kernel is a mailing list for developers to communicate. This FAQ builds on the previous linux-kernel mailing list FAQ maintained by Frohwalt Egerer, who no longer maintains it. Read it to see how to join the mailing list. Dozens of interesting questions regarding the list, Linux, developers (who is ...?), terms (what is...?) are answered here too. Just read it.


      • Name: "Linux Virtual File System"
        Author: Peter J. Braam.
        URL: http://www.coda.cs.cmu.edu/doc/talks/linuxvfs/
        Keywords: slides, VFS, inode, superblock, dentry, dcache.
        Description: Set of slides, presumably from a presentation on the Linux VFS layer. Covers version 2.1.x, with dentries and the dcache.


      • Name: "Gary's Encyclopedia - The Linux Kernel"
        Author: Gary (I suppose...).
        URL: http://members.aa.net/~swear/pedia/kernel.html
        Keywords: links, not found here?.
        Description: Gary's Encyclopedia exists to allow the rapid finding of documentation and other information of interest to GNU/Linux users. It has about 4000 links to external pages in 150 major categories. This link is for kernel-specific links, documents, sites... Look there if you could not find here what you were looking for.


      • Name: "The home page of Linux-MM"
        Author: The Linux-MM team.
        URL: http://linux-mm.org/
        Keywords: memory management, Linux-MM, mm patches, TODO, docs, mailing list.
        Description: Site devoted to Linux Memory Management development. Memory related patches, HOWTOs, links, mm developers... Don't miss it if you are interested in memory management development!


      • Name: "Kernel Newbies IRC Channel"
        URL: http://www.kernelnewbies.org/
        Keywords: IRC, newbies, channel, asking doubts.
        Description: #kernelnewbies on irc.openprojects.net. From the web page: "#kernelnewbies is an IRC network dedicated to the 'newbie' kernel hacker. The audience mostly consists of people who are learning about the kernel, working on kernel projects or professional kernel hackers that want to help less seasoned kernel people. [...] #kernelnewbies is on the Open Projects IRC Network, try irc.openprojects.net or irc..openprojects.net as your server and then /join #kernelnewbies". It also hosts articles, documents, FAQs...



      • Name: "The Operating System Resource Center"
        Author: Chris Lattner.
        URL: http://www.nondot.org/~sabre/os/articles
        Keywords: boot process, partitions, file systems, memory management, protected mode, executable file formats, plug and play specs, device driver interfaces, processor architectures, interconnect buses, disk and disc drives, human interface devices, sound devices, communication devices, networking devices, specifications, specs, specs, specs.
        Description: Site with specifications covering everything OS-related.


  • 星期二, 一月 15, 2008

    高手高手高高手 (转)

    1 计算机科学与技术学习心得【转】

    计算机科学与技术这一门科学深深的吸引着我们这些同学们,上计算机系已经有近三年了,自己也做了一些思考,原先不管是国内还是国外都喜欢把这个系 分为计算机软件理论、计算机系统、计算机技术与应用。后来又合到一起,变成了现在的计算机科学与技术。我一直认为计算机科学与技术这门专业,在本科阶段是 不可能切分成计算机科学和计算机技术的,因为计算机科学需要相当多的实践,而实践需要技术;每一个人(包括非计算机专业),掌握简单的计算机技术都很容易 (包括原先Major们自以为得意的程序设计),但计算机专业的优势是:我们掌握许多其他专业并不"深究"的东西,例如,算法,体系结构,等等。非计算机 专业的人可以很容易地做一个芯片,写一段程序,但他们做不出计算机专业能够做出来的大型系统。今天我想专门谈一谈计算机科学,并将重点放在计算理论上。

    1、计算机理论的一个核心问题--从数学谈起:
      [1]高等数学Vs数学分析    
      记得当年大一入学,每周四课时高等数学,天天作业不断(那时是七天工作制)。颇有些同学惊呼走错了门:咱们这到底念的是什么系?不错,你没走 错门,这就是计算机科学与技术系。我国计算机科学系里的传统是培养做学术研究,尤其是理论研究的人(方向不见得有多大的问题,但是做得不是那么尽如人 意)。而计算机的理论研究,说到底了,如网络安全学,图形图像学,视频音频处理,哪个方向都与数学有着很大的关系,虽然也许是正统数学家眼里非主流的数 学。这里我还想阐明我的一个观点:我们都知道,数学是从实际生活当中抽象出来的理论,人们之所以要将实际抽象成理论,目的就在于想用抽象出来的理论去更好 的指导实践,有些数学研究工作者喜欢用一些现存的理论知识去推导若干条推论,殊不知其一:问题考虑不全很可能是个错误的推论,其二:他的推论在现实生活中 找不到原型,不能指导实践。严格的说,我并不是一个理想主义者,政治课上学的理论联系实际一直是指导我学习科学文化知识的航标(至少我认为搞计算机科学与 技术的应当本着这个方向)。
      其实我们计算机系学数学仅学习高等数学是不够的(典型的工科院校一般都开的是高等数学),我们应该像数学系一样学一下数学分析(清华计算机 系开的好像就是数学分析,我们学校计算机学院开的也是,不过老师讲起来好像还是按照高等数学讲),数学分析这门科学,咱们学计算机的人对它有很复杂的感 情。在于它是偏向于证明型的数学课程,这对我们培养良好的分析能力和推理能力极有帮助。我的软件工程学导师北工大数理学院的王仪华先生就曾经教导过我们, 数学系的学生到软件企业中大多作软件设计与分析工作,而计算机系的学生做程序员的居多,原因就在于数学系的学生分析推理能力,从所受训练的角度上要远远在 我们平均水平之上。当年出现的怪现象是:计算机系学生的高中数学基础在全校数一数二(希望没有冒犯其它系的同学),教学课时数也仅次于数学系,但学完之后 的效果却不尽如人意。难道都是学生不努力吗,我看未见得,方向错了也说不一定,其中原因何在,发人深思。
      我个人的浅见是:计算机系的学生,对数学的要求固然跟数学系不同,跟物理类差别则更大。通常非数学专业的所?quot;高等数学",无非是 把数学分析中较困难的理论部分删去,强调套用公式计算而已。而对计算机系来说,数学分析里用处最大的恰恰是被删去的理论部分。说得难听一点,对计算机系学 生而言,追求算来算去的所谓"工程数学"已经彻底地走进了误区。记上一堆曲面积分的公式,难道就能算懂了数学?那倒不如现用现查,何必费事记呢?再不然直 接用Mathematica或是Matlab好了。 退一万步讲,即使是学高等数学我想大家看看华罗庚先生的《高等数学导论》也是比一般的教材好得多。华 罗庚在数学上的造诣不用我去多说,但是他这光辉的一生做得我认为对我们来说,最重要的几件事情: 首先是它筹建了中国科学院计算技术研究所,这是我们国家 计算机科学的摇篮。在有就是他把很多的高等数学理论都交给了做工业生产的技术人员,推动了中国工业的进步。第三件就是他一生写过很多书,但是对高校师生价 值更大的就是他在病期间在病床上和他的爱徒王元写了《高等数学引论》(王元与其说是他的爱徒不如说是他的同事,是中科院数学所的老一辈研究员,对歌德巴赫 猜想的贡献全世界仅次于陈景润)这书在我们的图书馆里居然找得到,说实话,当时那个书上已经长了虫子,别人走到那里都会闪开,但我却格外感兴趣,上下两册 看了个遍,我的最大收获并不在于理论的阐述,而是在于他的理论完全的实例化,在生活中去找模型。这也是我为什么比较喜欢具体数学的原因,正如我在上文中提 到的,理论脱离了实践就失去了它存在的意义。正因为理论是从实践当中抽象出来的,所以理论的研究才能够更好的指导实践,不用于指导实践的理论可以说是毫无 价值的。



    作者: dapplehou 2006-5-25 11:28   回复此发言


    2 计算机科学与技术学习心得【转】

      我在系里最爱做的事情就是给学弟学妹们推荐参考书。没有别的想法,只是希望他们少走弯路。中文的数学分析书,一般都认为以北大张筑生老师的" 数学分析新讲"为最好。张筑生先生一生写的书并不太多,但是只要是写出来的每一本都是本领域内的杰作,这本当然更显突出些。这种老书看起来不仅是在传授你 知识,而是在让你体会科学的方法与对事物的认识方法。万一你的数学实在太好,那就去看菲赫金哥尔茨?quot;微积分学教程"好了--但我认为没什么必 要,毕竟你不想转到数学系去。吉米多维奇的"数学分析习题集"也基本上是计算型的书籍。书的名气很大,倒不见得适合我们,还是那句话,重要的是数学思想的 建立,生活在信息社会里我们求的是高效,计算这玩意还是留给计算机吧。不过现在多用的似乎是复旦大学的《数学分析》,高等教育出版社的,也是很好的教材。
      中国的所谓高等代数,就等于线性代数加上一点多项式理论。我以为这有好的一面,因为可以让学生较早感觉到代数是一种结构,而非一堆矩阵翻来 覆去。这里不得不提南京大学林成森,盛松柏两位老师编的"高等代数",感觉相当舒服。此书相当全面地包含了关于多项式和线性代数的基本初等结果,同时还提 供了一些有用的又比较深刻的内容,如Sturm序列,Shermon-Morrison公式,广义逆矩阵等等。可以说,作为本科生如能吃透此书,就可以算 是高手。国内较好的高等代数教材还有清华计算机系用的那本,清华出版社出版,书店里多多,一看就知道。从抽象代数的观点来看,高等代数里的结果不过是代数 系统性质的一些例子而已。莫宗坚先生的《代数学》里,对此进行了深刻的讨论。然而莫先生的书实在深得很,作为本科生恐怕难以接受,不妨等到自己以后成熟了 一些再读。
      正如上面所论述的,计算机系的学生学习高等数学:知其然更要知其所以然。你学习的目的应该是:将抽象的理论再应用于实践,不但要掌握题目的 解题方法,更要掌握解题思想,对于定理的学习:不是简单的应用,而是掌握证明过程即掌握定理的由来,训练自己的推理能力。只有这样才达到了学习这门科学的 目的,同时也缩小了我们与数学系的同学之间思维上的差距。
      [2]计算数学基础
      概率论与数理统计这门课很重要,可惜大多数院校讲授这门课都会少些东西。少了的东西现在看至少有随机过程。到毕业还没有听说过Markov过 程,此乃计算机系学生的耻辱。没有随机过程,你怎么分析网络和分布式系统?怎么设计随机化算法和协议?据说清华计算机系开有"随机数学",早就是必修课。 另外,离散概率论对计算机系学生来说有特殊的重要性。而我们国家工程数学讲的都是连续概率。现在,美国已经有些学校开设了单纯的"离散概率论"课程,干脆 把连续概率删去,把离散概率讲深些。我们不一定要这么做,但应该更加强调离散概率是没有疑问的。这个工作我看还是尽早的做为好。
      计算方法学(有些学校也称为数学分析学)是最后一门由数理学院给我们开的课。一般学生对这门课的重视程度有限,以为没什么用。不就是照套公 式嘛!其实,做图形图像可离不开它,密码学搞深了也离不开它。而且,在很多科学工程中的应用计算,都以数值的为主。这门课有两个极端的讲法:一个是古典的 "数值分析",完全讲数学原理和算法;另一个是现在日趋流行的"科学与工程计算",干脆教学生用软件包编程。我个人认为,计算机系的学生一定要认识清楚我 们计算机系的学生为什么要学这门课,我是很偏向于学好理论后用计算机实现的,最好使用C语言或C++编程实现。向这个方向努力的书籍还是挺多的,这里推荐 大家高等教育出版社(CHEP)和施普林格出版社(Springer)联合出版的《计算方法(Computational Methods)》,华中理工 大学数学系写的(现华中科技大学),这方面华科大做的工作在国内应算是比较多的,而个人认为以这本最好,至少程序设计方面涉及了:任意数学函数的求值,方 程求根,线性方程组求解,插值方法,数值积分,场微分方程数值求解。李庆扬先生的那本则理论性过强,与实际应用结合得不太紧,可能比较适合纯搞理论的。



    作者: dapplehou 2006-5-25 11:28   回复此发言


    3 计算机科学与技术学习心得【转】

      [3]也谈离散数学   
      每个学校本系里都会开一门离散数学,涉及集合论,图论,和抽象代数,数理逻辑。不过,这么多内容挤在离散数学一门课里,是否时间太紧了点?另 外,计算机系学生不懂组合和数论,也是巨大的缺陷。要做理论,不懂组合或者数论吃亏可就太大了。从理想的状态来看,最好分开六门课:集合,逻辑,图论,组 合,代数,数论。这个当然不现实,因为没那么多课时。也许将来可以开三门课:集合与逻辑,图论与组合,代数与数论。(这方面我们学校已经着手开始做了)不 管课怎么开,学生总一样要学。下面分别谈谈上面的三组内容。
      古典集合论,北师大出过一本《基础集合论》不错。
      数理逻辑,中科院软件所陆钟万教授的《面向计算机科学的数理逻辑》就不错。现在可以找到陆钟万教授的讲课录像,http://www.cas.ac.cn/html/Dir/2001/11/06/3391.htm自己去看看吧。总的来说,学集合/逻辑起手不难,普通高中生都能看懂。但越往后越感觉深不可测。
      学完以上各书之后,如果你还有精力兴趣进一步深究,那么可以试一下GTM系列中的 《Introduction to Axiomatic Set Theory》和《A Course of Mathematical Logic》。 这两本都有世界图书出版社的引进版。你如果能搞定这两本,可以说在逻辑方面真正入了门,也就不用再浪费时间听我瞎侃了。
      据说全中国最多只有三十个人懂图论。此言不虚。图论这门科学,技巧性太强,几乎每个问题都有一个独特的方法,让人头痛。不过这也正是它魅力 所在:只要你有创造性,它就能给你成就感。我的导师说,图论里面随便找一块东西就可以写篇论文。大家可以体会里面内容之深广了吧!国内的图论书中,王树禾 老师的"图论及其算法"非常成功(顺便推荐大家王先生的"数学思想史",个人认为了解科学史会对我们的学习和研究起到很大的推动作用)。一方面,其内容在 国内教材里算非常全面的。另一方面,其对算法的强调非常适合计算机系(本来就是科大计算机系教材)。有了这本书为主,再参考几本翻译的,如 Bondy & Murty的《图论及其应用》,人民邮电出版社翻译的《图论和电路网络》等等,就马马虎虎,对本科生绝对足够了。再进一步,世界 图书引进有GTM系列的"Modern Graph Theory"。此书确实经典!国内好象还有一家出版了个翻译版。不过,学到这个层次,还是读原版好 (说实话,主要是亲身体验翻译版的弊端,这个大家自己体会)。搞定这本书,也标志着图论入了门。
      离散数学方面我们北京工业大学实验学院有个世界级的专家,叫邵学才,复旦大学概率论毕业的,教过高等数学,线性代数,概率论,最后转向离散 数学,出版著作无数,论文集新加坡有一本,堪称经典,大家想学离散数学的真谛不妨找来看看。这老师的课我专门去听过,极为经典。不过你要从他的不经意的话 中去挖掘精髓。在同他的交谈当中我又深刻地发现一个问题,虽说邵先生写书无数,但依他自己的说法每本都差不多,我实在觉得诧异,他说主要是有大纲的限制, 不便多写。这就难怪了,很少听说国外写书还要依据个什么大纲(就算有,内容也宽泛的多),不敢越雷池半步,这样不是看谁的都一样了。外版的书好就好在这 里,最新的科技成果里面都有论述,别的先不说,至少?quot;紧跟时代的理论知识"。
      原先离散数学和数据结构归在一起成为离散数学结构,后来由于数据结构的内容比较多,分出来了,不过最近国外好像有些大学又把它们合并到了一 起,道理当然不用说,可能还是考虑到交叉的部分比较多。比较经典的书我看过得应算是 《Discrete Mathematical Structures》了,清华大学出版社有个影印版的。
      [4]续谈其他的一些计算数学
      组合数学我看的第一本好像是北大捐给我们学院的,一本外版书。感觉没有太适合的国产书。还是读Graham和Knuth等人合著的经典"具体数学"吧,西安电子科技大学出版社有翻译版。



    作者: dapplehou 2006-5-25 11:28   回复此发言


    4 计算机科学与技术学习心得【转】

      《组合数学》,《空间解析几何》还有那本《拓扑学》,看这三本书的时候是极其费事的,原因有几点,首先是这三本书无一例外,都是用繁体字写 的,第二就是书真得实在是太脏了,我在图书馆的座位上看,同学们都离我做得很远。我十分不自然,不愿意影响同学,但是学校不让向外借这种书(呵呵,说起这 是也挺有意思,别人都不看这种书,只有我在看,老师就特别的关注我,后来我和他讲了这些书的价值,他居然把他们当作是震馆之宝,老师都不许借,不过后来他 们看我真得很喜欢看,就把书借给了我,当然用的是馆长的名义借出去的。)不过收获是非常大的,再后来学习计算机理论时里面的很多东西都是常会用到的。当然 如果你没看过这些书绝对理解不到那个层次。拿拓扑学来说,我们学校似乎是美开设这门课程,但是这门课程的重要性是显而易见的,没有想到的是在那本书的很多 页中都夹着一些读书笔记,而那个笔记的作者及有些造诣,有些想法可以用到现代网络设计当中。
      抽象代数,国内经典为莫宗坚先生的《代数学》。此书听说是北大数学系教材,深得好评。然而对本科生来说,此书未免太深。可以先学习一些其它 的教材,然后再回头来看"代数学"。国际上的经典可就多了,GTM系列里就有一大堆。推荐一本谈不上经典,但却最简单的,最容易学的:http://www.math.miami.edu/~ec/book/这本"Introduction to Linear and Abstract Algebra"非常通俗易懂,而且把抽象代数和线性代数结合起来,对初学者来说非常理想,我校比较牛的同学都有收藏。
      数论方面,国内有经典而且以困难著称摹冻醯仁邸?(潘氏兄弟著,北大版)。再追溯一点,还有更加经典(可以算世界级)并且更加困难的"数论 导引"(华罗庚先生的名著,科学版,九章书店重印,繁体的看起来可能比较困难)。把基础的几章搞定一个大概,对本科生来讲足够了。但这只是初等数论。本科 毕业后要学计算数论,你必须看英文的书,如Bach的"Introduction to Algorithmic Number Theory"。
      计算机科学理论的根本,在于算法。现在很多系里给本科生开设算法设计与分析,确实非常正确。环顾西方世界,大约没有一个三流以上计算机系不 把算法作为必修的。算法教材目前公认以Corman等著的《Introduction to Algorithms》为最优。对入门而言,这一本已经足 够,不需要再参考其它书。 深一点的就是大家作为常识都知道的TAOCP了。即是《The Art of Computer Programming》3 册内容全世界都能看下来的本身就不多,Gates曾经说过"若是你能把这书上面的东西都看懂,请把你的简历发给我一份"我的学长司徒彦南兄就曾千里迢迢从 美国托人买这书回来,别的先不说,可见这书的在我们计算机科学与技术系中的分量。
       再说说形式语言与自动机。我看过北邮的教材,应该说写的还清楚。有一本通俗易懂的好书,MIT的sipser的 《introduction to theory of computation》。但是,有一点要强调:形式语言和自动机的作用主要在作为计算模型,而 不是用来做编译。事实上,编译前端已经是死领域,没有任何open problems,北科大的班晓娟博士也曾经说过,编译的技术已相当成熟。如果为了这 个,我们完全没必要去学形式语言--用用yacc什么的就完了。北邮的那本在国内还算比较好,但是在深度上,在跟可计算性的联系上都有较大的局限,现代感 也不足。所以建议有兴趣的同学去读英文书,不过国内似乎没引进这方面的教材。可以去互动出版网上看一看。入门以后,把形式语言与自动机中定义的模型,和数 理逻辑中用递归函数定义的模型比较一番,可以说非常有趣。现在才知道,什么叫"宫室之美,百官之富"!
      计算机科学和数学的关系有点奇怪。二三十年以前,计算机科学基本上还是数学的一个分支。而现在,计算机科学拥有广泛的研究领域和众多的研究 人员,在很多方面反过来推动数学发展,从某种意义上可以说是孩子长得比妈妈还高了。但不管怎么样,这个孩子身上始终流着母亲的血液。这血液是 the mathematical underpinning of computer science(计算机科学的数学基础),也就是理论计算机科 学。原来在东方大学城图书馆中曾经看过一本七十年代的译本(书皮都没了,可我就爱关注这种书),大概就叫《计算机数学》。那本书若是放在当时来讲决是一本 好书,但现在看来,涵盖的范围还算广,深度则差了许多,不过推荐大一的学生倒可以看一看,至少可以使你的计算数学入入门,也就是说至少可以搞清数学到底在 计算机科学什么地方使用。
      最常和理论计算机科学放在一起的一个词是什么?答:离散数学。这两者的关系是如此密切,以至于它们在不少场合下成为同义词。(这一点在前面 的那本书中也有体现)传统上,数学是以分析为中心的。数学系的同学要学习三四个学期的数学分析,然后是复变函数,实变函数,泛函数等等。实变和泛函被很多 人认为是现代数学的入门。在物理,化学,工程上应用的,也以分析为主。
      随着计算机科学的出现,一些以前不太受到重视的数学分支突然重要起来。人们发现,这些分支处理的数学对象与传统的分析有明显的区别:分析研 究的问题解决方案是连续的,因而微分,积分成为基本的运算;而这些分支研究的对象是离散的,因而很少有机会进行此类的计算。人们从而称这些分支为"离散数 学"。"离散数学"的名字越来越响亮,最后导致以分析为中心的传统数学分支被相对称为"连续数学"。
      离散数学经过几十年发展,基本上稳定下来。一般认为,离散数学包含以下学科



    作者: dapplehou 2006-5-25 11:28   回复此发言


    6 回复:计算机科学与技术学习心得【转】

    1) 集合论,数理逻辑与元数学。这是整个数学的基础,也是计算机科学的基础。
    2) 图论,算法图论;组合数学,组合算法。计算机科学,尤其是理论计算机科学的核心是算法,而大量的算法建立在图和组合的基础上。
    3) 抽象代数。代数是无所不在的,本来在数学中就非常重要。在计算机科学中,人们惊讶地发现代数竟然有如此之多的应用。
     但是,理论计算机科学仅仅就是在数学的上面加上"离散"的帽子这么简单吗?一直到大约十几年前,终于有一位大师告诉我们:不是。 D.E.Knuth(他有多伟大,我想不用我再说了)在Stanford开设了一门全新的课程Concrete Mathematics。 Concrete这个词在这里有两层含义:
      首先:对abstract而言。Knuth认为,传统数学研究的对象过于抽象,导致对具体的问题关心不够。他抱怨说,在研究中他需要的数学 往往并不存在,所以他只能自己去创造一些数学。为了直接面向应用的需要,他要提倡"具体"的数学。在这里我做一点简单的解释。例如在集合论中,数学家关心 的都是最根本的问题--公理系统的各种性质之类。而一些具体集合的性质,各种常见集合,关系,映射都是什么样的,数学家觉得并不重要。然而,在计算机科学 中应用的,恰恰就是这些具体的东西。Knuth能够首先看到这一点,不愧为当世计算机第一人。其次,Concrete是Continuous(连续)加上 discrete(离散)。不管连续数学还是离散数学,只要是能与我们研究的内容挂上钩的都是有用的数学!
    2、理论与实际的结合--计算机科学技术研究的范畴与学习方法      前面主要是从数学角度来看的。从计算机角度来看,理论计算机科学目前 主要的研究领域包括:可计算性理论,算法设计与复杂性分析,密码学与信息安全,分布式计算理论,并行计算理论,网络理论,生物信息计算,计算几何学,程序 语言理论等等。这些领域互相交叉,而且新的课题在不断提出,所以很难理出一个头绪来。想搞搞这方面的工作,推荐看中国计算机学会的一系列书籍,至少代表了 我国的权威。下面随便举一些例子。



    作者: dapplehou 2006-5-25 11:48   回复此发言


    7 回复:计算机科学与技术学习心得【转】

    1) 集合论,数理逻辑与元数学。这是整个数学的基础,也是计算机科学的基础。
    2) 图论,算法图论;组合数学,组合算法。计算机科学,尤其是理论计算机科学的核心是算法,而大量的算法建立在图和组合的基础上。
    3) 抽象代数。代数是无所不在的,本来在数学中就非常重要。在计算机科学中,人们惊讶地发现代数竟然有如此之多的应用。
     但是,理论计算机科学仅仅就是在数学的上面加上"离散"的帽子这么简单吗?一直到大约十几年前,终于有一位大师告诉我们:不是。 D.E.Knuth(他有多伟大,我想不用我再说了)在Stanford开设了一门全新的课程Concrete Mathematics。 Concrete这个词在这里有两层含义:
      首先:对abstract而言。Knuth认为,传统数学研究的对象过于抽象,导致对具体的问题关心不够。他抱怨说,在研究中他需要的数学 往往并不存在,所以他只能自己去创造一些数学。为了直接面向应用的需要,他要提倡"具体"的数学。在这里我做一点简单的解释。例如在集合论中,数学家关心 的都是最根本的问题--公理系统的各种性质之类。而一些具体集合的性质,各种常见集合,关系,映射都是什么样的,数学家觉得并不重要。然而,在计算机科学 中应用的,恰恰就是这些具体的东西。Knuth能够首先看到这一点,不愧为当世计算机第一人。其次,Concrete是Continuous(连续)加上 discrete(离散)。不管连续数学还是离散数学,只要是能与我们研究的内容挂上钩的都是有用的数学!
    2、理论与实际的结合--计算机科学技术研究的范畴与学习方法      前面主要是从数学角度来看的。从计算机角度来看,理论计算机科学目前 主要的研究领域包括:可计算性理论,算法设计与复杂性分析,密码学与信息安全,分布式计算理论,并行计算理论,网络理论,生物信息计算,计算几何学,程序 语言理论等等。这些领域互相交叉,而且新的课题在不断提出,所以很难理出一个头绪来。想搞搞这方面的工作,推荐看中国计算机学会的一系列书籍,至少代表了 我国的权威。下面随便举一些例子。
      由于应用需求的推动,密码学现在成为研究的热点。密码学建立在数论(尤其是计算数论),代数,信息论,概率论和随机过程的基础上,有时也用到图论和组合学等。很多人以为密码学就是加密解密,而加密就是用一个函数把数据打乱。这样的理解太浅显了。
    现代密码学至少包含以下层次的内容:
    第一,密码学的基础。例如,分解一个大数真的很困难吗?能否有一般的工具证明协议正确?
    第二,密码学的基本课题。例如,比以前更好的单向函数,签名协议等。
    第三,密码学的高级问题。例如,零知识证明的长度,秘密分享的方法。
    第四,密码学的新应用。例如,数字现金,叛徒追踪等。
      密码学方面值得推荐的有一本《应用密码学》还有就是平时多看看年会的论文集,感觉这种材料实用性比较强,会提高很快。
    在分布式系统中,也有很多重要的理论问题。例如,进程之间的同步,互斥协议。一个经典的结果是:在通信信道不可靠时,没有确定型算法能实现进程间 协同。所以,改进TCP三次握手几乎没有意义。例如时序问题。常用的一种序是因果序,但因果序直到不久前才有一个理论上的结果....例如,死锁没有实用 的方法能完美地对付。例如,......操作系统研究过就自己去举吧!
      如果计算机只有理论,那么它不过是数学的一个分支,而不成为一门独立的科学。事实上,在理论之外,计算机科学还有更广阔的天空。
    我一直认为,4年根本不够学习计算机的基础知识,因为面太宽了,要是真学的话,我想至少8年的学习能使你具有一定的科学素养......
      这方面我想先说说我们系在各校普遍开设的《计算机基础》。在高等学校开设《计算机基础课程》是我国高教司明文规定的各专业必修课程要求。主要 内容是使学生初步掌握计算机的发展历史,学会简单的使用操作系统,文字处理,表格处理功能和初步的网络应用功能。但是在计算机科学系教授此门课程的目标决 不能与此一致。在计算机系课程中目标应是:让学生较为全面的了解计算机学科的发展,清晰的把握计算机学科研究的方向,发展的前沿即每一个课程在整个学科体 系中所处的地位。搞清各学科的学习目的,学习内容,应用领域。使学生在学科学习初期就对整个学科有一个整体的认识,以做到在今后的学习中清楚要学什么,怎 么学。计算机基本应用技能的位置应当放在第二位或更靠后,因为这一点对于本系的学生应当有这个摸索能力。这一点很重要。推荐给大家一本书:机械工业出版社 的《计算机文化》(New Perspective of Computer Science),看了这本书我才深刻的体会到自己还是个计算机科学初学 者,才比较透彻的了解了什么是计算机科学。科学出版社的《计算科学导论》 (赵致琢先生的著作)可以说是在高校计算机教育改革上作了很多的尝试,也是这方 面我受益很大的一本书。



    作者: dapplehou 2006-5-25 12:13   回复此发言


    8 回复:计算机科学与技术学习心得【转】

      一个一流计算机系的优秀学生决不该仅仅是一个编程高手,但他一定首先是一个编程高手。我上大学的时候,第一门专业课是C语言程序设计,念计算 机的人从某种角度讲相当一部分人是靠写程序吃饭的。在我们北京工业大学实验学院计算机系里一直有这样的争论(时至今日CSDN上也有),关于第一程序设计 语言该用哪一种。我个人认为,用哪种语言属于末节,关键在养成良好的编程习惯。当年老师对我们说,打好基础后学一门新语言只要一个星期。现在我觉得根本不 用一个星期,前提是先把基础打好。不要再犹豫了,学了再说,等你抉择好了,别人已经会了几门语言了。
      [1]专谈计算机系统的学习
     汇编语言和微机原理是两门特烦人的课。你的数学/理论基础再好,也占不到什么便宜。这两门课之间的次序也好比先有鸡还是先有蛋,无论你先学哪 门,都会牵扯另一门课里的东西。所以,只能静下来慢慢琢磨。这就是典型的工程课,不需要太多的聪明和顿悟,却需要水滴石穿的渐悟。有关这两门课的书,计算 机书店里不难找到。弄几本最新的,对照着看吧。组成原理推荐《计算机组成与结构》清华大学王爱英教授写的。汇编语言大家拿8086/8088入个门,之后 一定要学80x86汇编语言。实用价值大,不落后,结构又好,写写高效病毒,高级语言里嵌一点汇编,进行底层开发,总也离不开他,推荐清华大学沈美明的 《IBM-PC汇编语言程序设计》。有些人说不想了解计算机体系结构,也不想制造计算机,所以诸如计算机原理,汇编语言,接口之类的课觉得没必要学,这样 合理吗?显然不合理,这些东西迟早得掌握,肯定得接触,而且,这是计算机专业与其他专业学生相比的少有的几项优势。做项目的时候,了解这些是非常重要的, 不可能说,仅仅为了技术而技术,只懂技术的人最多做一个编码工人,而永远不可能全面地了解整个系统的设计,而编码工人是越老越不值钱。关于组成原理还有个 讲授的问题,在我学这门课程时老师讲授时把CPU工作原理誉微程序设计这一块略掉了,理由是我们国家搞CPU技术不如别的国家,搞了这么长时间好不容易出 了个龙芯比Intel的还差个十万八千里,所以建议我们不要学了。我看这在各校也未见得不是个问题吧!若真是如他所说,那中国的计算机科学哪个方向都可以 停了,软硬件,应用,有几项搞得过美国,搞不过别人就不搞了,那我们坐在这里干什么?教学的观念需要转变的。我们学校现在有一个学弟就专攻CPU设计,平 时交流不少,发现他能够将软件的设计思想应用到芯片设计上,我看真的是不错的,比起那些望而生畏的恐怕要强上百倍。
      模拟电路这个学科,如今不仅计算机系学生搞不定,电子系学生也多半害怕。如果你真想软硬件通吃,那么建议你先看看邱关源的"电路原理",也 许此后再看模拟电路底气会足些。教材:康华光的"电子技术基础"(高等教育出版社)还是不错的(我校电子系在用)。有兴趣也可以参考童诗白的书。
      数字电路比模拟电路要好懂得多。推荐大家看一看北京工业大学刘英娴教授写的《数字逻辑》。业绩人士都说这本书很有参考价值(机械工业出版社 的)。原因很明了,实用价值高,能听听她讲授的课程更是有一种"享受科学"的感觉。清华大学阎石的书也算一本好教材,遗憾的一点是集成电路讲少了些。真有 兴趣,看一看大规模数字系统设计吧(北航那本用的还比较多)。
      计算机系统结构该怎么教,国际上还在争论。国内能找到的较好教材为Stallings的 《Computer Organization and Architecture:Designing for Performance》(清华影印 本)。国际上最流行的则是《Computer architecture: aquantitative approach》, by Patterson & Hennessy。
      [2]一些其他的专业课程   
      操作系统可以随便选用《操作系统的内核设计与实现》和《现代操作系统》两书之一。这两部都可以算经典,唯一缺点就是理论上不够严格。不过这领 域属于Hardcore System,所以在理论上马虎一点也情有可原。想看理论方面的就推荐清华大学出版社《操作系统》吧,高教司司长张尧学写的,我 们教材用的是那本。 可以说理论涉及的比较全,在有就是他的实验指导书,操作系统这门学科同程序设计一样,不自己试着做些什么恐怕很难搞通。另外推荐一本 《Windows操作系统原理》机械工业出版社的,这本书是我国操作系统专家在微软零距离考察半年,写作历时一年多写成的,教操作系统的顶级教授除了清华 大学的张尧学(现高教司司长)很多专家都参加了。Bill Gates亲自写序。里面不但结合windows2000,xp详述操作系统的内核,而且后面 讲了一些windows编程基础,有外版书的味道,而且上面一些内容可以说在国内外只有那本书才有对windows内核细致入微的介绍。



    作者: dapplehou 2006-5-25 12:13   回复此发言


    9 回复:计算机科学与技术学习心得【转】

      如果先把形式语言学好了,则编译原理中的前端我看只要学四个算法:最容易实现的递归下降;最好的自顶向下算法LL(k);最好的自底向上算法 LR(k);LR(1)的简化SLR(也许还有另一简化LALR)。后端完全属于工程性质,自然又是another story。 推荐教材: Kenneth C.Louden写的《Compiler Construction Principles and Practice》即是《编译原理 及实践》(机械工业出版社的译本)
    学数据库要提醒大家的是,会用VFP,VB, Power builder不等于懂数据库。(这世界上自以为懂数据库的人太多了!)数据库设计 既是科学又是艺术,数据库实现则是典型的工程。所以从某种意义上讲,数据库是最典型的一门计算机课程--理工结合,互相渗透。另外推荐大家学完软件工程学 后再翻过来看看数据库技术,又会是一番新感觉。至少对一些基本概念与描述方法会有很深的体会,比如说数据字典,E-R图之类的。推荐教材: Abraham Silberschatz等著的 "Database System Concepts".作为知识的完整性,还推荐大家看一看机械工业 出版社的《数据仓库》译本。
      计算机网络的标准教材还是来自Tanenbaum的《Computer Networks》(清华大学有译本)。还有就是推荐谢希仁的《计 算机网络教程》(人民邮电出版社)问题讲得比较清楚,参考文献也比较权威。不过,网络也属于Hardcore System,所以光看书是不够的。建议多 读RFC,http://www.ietf.org/rfc.html里可以按编号下载RFC文档。从IP的读起。等到能掌握10种左右常用协议,就没有几个人敢小看你了。再做的工作我看放在网络设计上就比较好了。
      数据结构的重要性就不言而喻了,学完数据结构你会对你的编程思想进行一番革命性的洗礼,会对如何建立一个合理高效的算法有一个清楚的认识。对于算法的建立我想大家应当注意以下几点:
      当遇到一个算法问题时,首先要知道自己以前有没有处理过这种问题.如果见过,那么你一般会顺利地做出来;如果没见过,那么考虑以下问题:
    1. 问题是否是建立在某种已知的熟悉的数据结构(例如,二叉树)上?如果不是,则要自己设计数据结构。
    2. 问题所要求编写的算法属于以下哪种类型?(建立数据结构,修改数据结构,遍历,查找,排序...)
    3. 分析问题所要求编写的算法的数学性质.是否具备递归特征?(对于递归程序设计,只要设计出合理的参数表以及递归结束的条件,则基本上大功告成.)
    4. 继续分析问题的数学本质.根据你以前的编程经验,设想一种可能是可行的解决办法,并证明这种解决办法的正确性.如果题目对算法有时空方面的要求,证明你的设想满足其要求.一般的,时间效率和空间效率难以兼得.有时必须通过建立辅助存储的方法来节省时间.
    5. 通过一段时间的分析,你对解决这个问题已经有了自己的一些思路.或者说,你已经可以用自然语言把你的算法简单描述出来.继续验证其正确性,努力发现其中的错误并找出解决办法.在必要的时候(发现了无法解决的矛盾),推翻自己的思路,从头开始构思.
    6. 确认你的思路可行以后,开始编写程序.在编写代码的过程中,尽可能把各种问题考虑得详细,周密.程序应该具有良好的结构,并且在关键的地方配有注释.
    7. 举一个例子,然后在纸上用笔执行你的程序,进一步验证其正确性.当遇到与你的设想不符的情况时,分析问题产生的原因是编程方面的问题还是算法思想本身有问题.
    8. 如果程序通过了上述正确性验证,那么在将其进一步优化或简化。
    9. 撰写思路分析,注释.
    对于具体的算法思路,只能靠你自己通过自己的知识和经验来加以获得,没有什么特定的规律(否则程序员全部可以下岗了,用机器自动生成代码就可以 了).要有丰富的想象力,就是说当一条路走不通时,不要钻牛角尖,要敢于推翻自己的想法.我也只不过是初学者,说出上面的一些经验,仅供大家参考和讨论。
      关于人工智能,我觉得的也是非常值得大家仔细研究的,虽然不能算是刚刚兴起的学科了,但是绝对是非常有发展前途的一门学科。我国人工智能创 始人之一,北京科技大学涂序彦教授(这老先生是我的导师李小坚博士的导师)对人工智能这样定义:人工智能是模仿、延伸和扩展人与自然的智能的技术科学。在 美国人工智能官方教育网站上对人工智能作了如下定义:Artificial Intelligence, or AI for short, is a combination of computer science, physiology, and philosophy. AI is a broad topic, consisting of different fields, from machine vision to expert systems. The element that the fields of AI have in common is the creation of machines that can "think".



    作者: dapplehou 2006-5-25 12:13   回复此发言


    10 回复:计算机科学与技术学习心得【转】

    这门学科研究的问题大概说有:
    (1)符号主义: 符号计算与程序设计基础,知识表达方法 :知识与思维,产生式规则,语意网络,一阶谓词逻辑问题求解方法:搜索策略,启发式搜寻,搜寻算法,问题规约方法,谓词演算:归结原理,归结过程专家系统:建立专家系统的方法及工具
    (2)联接主义(神经网络学派):1988年美国权威机构指出:数据库,网络发展呈直线上升,神经网络可能是解决人工智能的唯一途径。关于神经网络学派,现在很多还是在发展阶段。
      我想对于人工智能的学习,大家一定不要像学数学似的及一些现成的结论,要学会分析问题,最好能利用程序设计实现,这里推荐给大家ACM最佳博 士论文奖获得者涂晓媛博士的著作《人工鱼-计算机动画的人工生命方法》(清华大学出版社)。搞人工生命的同学不会不知道国际知名的涂氏父女吧。关于人工智 能的书当然首选《Artificial Intelligence A New Synthesis》Nils J.Nilsson.鼻祖嘛!
      关于网络安全我也想在这里说两句,随着计算机技术的发展,整个社会的信息化水平突飞猛进,计算机网络技术日新月异,网络成了当即社会各个工 作领域不可缺少的组成部分,只要有网络存在,网络安全问题就是一个必须解决好的问题,学习网络安全不是简简单单的收集一些黑客工具黑一黑别人的网站,而是 要学习他的数学原理,实现原理,搞清底层工作机制,这样才能解决大部分的现有问题和新出现的安全问题。 总的来说信息安全学的研究还是非常深奥的,这方面 体会比较深的要算是在最近的微软杯程序设计大赛中利用.NET平台开发的那个项目My E-business Fairy.NET过程中了。
      [3]闲聊软件工程
      关于计算机科学的一些边缘科学我想谈一谈软件工程技术,对于一个企业,推出软件是不是就是几个程序员坐在一起,你写一段程序,我写一段程序 呢?显然不是。软件工程是典型的计算机科学和数学,管理科学,心理学,社会学等学科的综合。它使我们这些搞理论和技术的人进入了一个社会。你所要考虑的不 仅仅是程序的优劣,更应该考虑程序与软件的区别,软件与软件产品的区别,软件软件产品的市场前景,如何去更好的与人交流。这方面我还在学习阶段,以后这方 面再写文章吧,先推荐给大家几本书:畅销20年不衰的《人月神话》(清华大学中文版,中国电力出版社影印版),《软件工程-实践者研究的方法》(机械工业 出版社译本),《人件》(据说每一位微软公司的部门经理都读过这本书,推荐老总们和想当老总的同学都看看,了解一下什么是软件企业中的人)以及微软公司的 《软件开发的科学与艺术》和《软件企业的管理与文化》(研究软件企业的制胜之道当然要研究微软的成功经验了!) 看完上面的书,结合自己做的一些团队项 目,我的一些比较深的体会有这么几点:
    1.How important a plan is for a project development.
    2.How to communicate with your team members in a more effective way.
    3.How to solve unexpected situations.
    4.The importance of unification.
    5.The importance of doing what you should do.
    6.The importance of designing before programming.
    7.The importance of management.
    8.The importance of thinking what your teammates think.
    在软件开发过程中我们应当具有以下能力:
    1.Like it if you would like to do it.
    We believe that your attitude toward your work will definitely makes great effect on the project.
    2.The spirit of group working.
    Take myself as an example. I am just a part of the team, just a little part. You must make it clear that you are just a member of the team, but your effort will change your project a lot.
    3.Passion
    With passion, you can do your job in a more effective way.



    作者: dapplehou 2006-5-25 12:15   回复此发言


    11 回复:计算机科学与技术学习心得【转】

    4.The ability of solving unexpected problems.
    5.Learning New things in a very short time
    It is the basic requirement for we computer major to learn new technology.
    6.Creativity
    The tools are changing. As for us, what's more important is to use these new tools and technology to enable people and businesses throughout the world to realize their full potential.
    7.The ability to do your work independently.
    Every member has his own business. In a team, your work cannot be replaced by others' so you must do your business well in order to assure the project development process.
    团队开发当中的一些具体精神应当有:
    <1> Success and Failure is not one person's effect.
    Your team's success is not the contribution of a single person. Success contributes to the whole team. If your project failed, it also is not just because of one person's poor work. It is also your failure.
    <2> Learn from each other.
    Every person has his own specialty. Even Bill Gates cannot know all the things about software development. We often learn from each other and gains a lot. The old saying goes like this:
    There must be one out of three who can be your teacher. In our team we say: Every person is your teacher.
    <3> Help those who have problems. Use the group working spirit to overcome all the difficulties.
    There is no need to explain it. As the old saying: Two heads are better than one. We always find it difficult to solve all the problems just by oneself.
    <4> Praise them who have got some improvement.
    In our team, I always praise the members when they have finished something or just solved one problem, and they think that it is interesting and gains a lot. Because they can see their efforts.
    <5> Say something if needed.
    这个是一次软件大赛当中的体会,和大家也做个交流,不过不能再说了,软件工程学说起来写本2000页的书一点也不多,恕我才疏学浅,不再做过多论述了。
      [4]谈谈学习态度的问题
      关于计算机技术的学习我想是这样的:学校开设的任何一门科学都有其滞后性,不要总认为自己掌握的某门技术就已经是天下无敌手了,虽然现在 Java,VB,C,C++用的都很多,怎能保证没有被淘汰的一天,我想.NET平台的诞生和X#语言的初见端倪完全可以说明问题。换言之,在我们掌握一 门新技术的同时就又有更新的技术产生,身为当代的大学生应当有紧跟科学发展的素质。举个例子,就像有些同学总说,我做网页设计就喜欢直接写html,不愿 意用什么Frontpage,Dreamweaver。能用语言写网页固然很好,但有高效的手段你为什么不使呢?仅仅是为了显示自己的水平高, unique? 我看真正水平高的是能够以最快的速度接受新事物的人。高级程序设计语言的发展日新月异,今后的程序设计就像人们在说话一样,我想大家从 xml中应是有所体会了。难道我们真就写个什么都要用汇编,以显示自己的水平高,真是这样倒不如直接用机器语言写算了。反过来说,想要以最快的速度接受并 利用新技术关键还是在于你对计算机科学地把握程度。
      计算机技术牵扯的内容更为广泛些,一项一项说恐怕没个一年半载也说不清。我只想提醒大家的还是那句话,技术与科学是不能分家的,学好了科学 同时搞技术,这才是上上策。犹如英语,原先人们与老外交流必须要个翻译,现在满马路的人都会说英语。就连21世纪英语演讲比赛的冠军都轮不到英语系的学生 了。计算机也是一样的,我们必须面对的一个现实就是:计算机真就只是一个工具,如果不具备其它方面的素养,计算机系的学生虽然不能说找不到工作,不过总有 一天当其他专业性人才掌握了计算机技术后将比我们出色许多。原因就在于计算机解决的大都是实际问题,实际问题的知识却是我们少有的。单一的计算机技术没有 立足之地。



    作者: dapplehou 2006-5-25 12:15   回复此发言


    12 回复:计算机科学与技术学习心得【转】

      我想是时候指出:学习每一个课程之前,都要先搞清这一课程的学习目的。这一学科的应用领域。据我自身所了解到的同龄同学和低年级的同学的学习 状况:他们之中很少有人知道学一个学科的学习目的,期末考试结束了也不知道学这科做什么用。这就失去了读计算机科学的意义。当然这与现存的教育思想不能说 一点关系都没有。
      总的来说,从教育角度来讲,国内高校的课程安排不是很合理,强调理论,又不愿意在理论上深入教育,无力接受新技术,想避开新技术又无法避得 一干二净。我觉得关键问题就是国内的高校难于突破现状,条条框框限制着怎么求发展。我们虽然认识得到国外教育的优越性,但为什么迟迟不能采取行动?哪怕是 去粗取精的取那么一点点。我们需要改变。从我们自身角度来讲,多数人4年下来既没有学习计算机科学的学术水平,也没有学习计算机技术的那种韧劲。在我刚上 大一时,我的计算机科学入门导师,淮北煤炭师范学院王爱平教授曾经对我说过这样一番话:"当你选择了计算机这一门科学,就意味着你踏上了一条不归路,就意 味着你一生都要为之奋斗……你的身后是悬崖,只有向前走,不能往后退。"
      有些同学说按照这样学习学的东西太多,有的未见得有用,我想打个形象的比方:学校学出来的人都是一个球体,方方面面的知识都应具备。可是社 会上需要球体的地方很少,反而需要的是砖和瓦,即精通某一行的人才。但是对于同等体积的物体,用球体来改造是最方便最省事的。学校的学生很多,为了能够使 更多的学生来适应这个社会,学校也就不得以把所有的学生都打造成一个球体,然后让社会对这些学生进行再加工,成为真正能够有用的人才。即使你非常清楚自己 的将来要干什么,并且非常下定决心要走自己的路,这一步你也必须走,世界是在不断变化的,你不能预料未来。想清楚,努力去干吧!
      必须结束这篇"胡侃"了,再侃下去非我力所能及。其实计算机还有很多基础课都值得一侃。怎奈我造诣有限,不敢再让内行耻笑。计算机科学博大 精深,我只是个初学者。最后声明:这些只针对本科阶段的学习。即使把这些全弄通了,前面的路还长,计算机科学需要我们为之奋斗......学习计算机科学 需要韧性,更需要创新,需要激情。深刻学习理论知识,勇于接受新技术的挑战,这才是我们这一代人应具有的素质。最后送大家一句话 "Wake up every day with a feeling of passion for the difference technology will make in people's life! "。
    在我大一时无意中找到了南京大学网友sir的帖子"胡侃(理论)计算机学习",这个帖子对我的大学学习起了至关重要的作用,后来也同他进行了一 些交流,写这份材料时也引用了其中的不少观点,并得到了sir的支持。再有就是每次和本系司徒彦南兄的交谈,都能从中学到很多东西,在这份材料中也有很多 体现。这份材料是我原来在实验学院进行新生入学教育的讲稿之一,原有基础上改进了其中我认为不太合适的理论,修正了一些观点,在推荐教材方面结合我的学习 情况有了较大改变。值得一提的是增加了一些计算机理论的内容,计算机技术的内容结合我国的教学情况和我们学习的实际情况进行了重写。这里所作的工作也只是 将各位学长和同学们的学习体会以及我在学习计算机科学时的所思所想汇总在一起写了下来,很不成熟。目的就是希望能够给一些刚入学或者是学习计算机科学还没 有入门的同学以一些建议。不期能够起到多大的作用,但求能为同学们的学习计算机科学与技术带来微薄的帮助。还是那句话,计算机科学博大精深,我只是个初学 者,不当之处希望大家批评指正。

    程序员修炼之道

    计算机经典书籍- -

    【程式语言:C】
    1) C : How to Program 0132261197 PTH/1994-2ed
    ***教科书,初学C语言可考虑

    2) the c progamming language 0131103628 PTH/1988-2ed
    ***K&R所着,乃C之bible中的bible,为c programmer 必读之书藉。惟不适合初学者,进阶用书

    3) The C Answer Book 0131096532 PTH/1988-2ed
    ***K&R的解答本....好贵:<....所以不买了....:) 4) C: The Complete Reference 0078821010 McGraw/1995-3ed ***评价直逼K&R的一本好书....可能也不适合初学者(我没看过)

    C++:
    http://www.csdn.net/expert/jjhou/

    1.C++ Primer 3/e(Lippman/AW) 原文书即将出版。旧版有无中译?

    2.The C++ Programming Language 3/e(Stroustrup/AW) 有无中译?儒林?

    3.Inside The C++ Object Model(Lippman/AW) 棋峰将有中译本


    1) C++ primer 0201824701 A-W/1998-3ed
    ***一本十分适合初学者拿来学习的书....
    以下为候捷老师的评语:
    在 「C++ 百科」类书中,与 The C++ Programming Language 齐名,亲和性较佳。老字号,有口碑。副作者 Josee Lajoie 是 ANSI/ISO C++ Standard 委员会的核心语言工作小组主席,因此本书在与C++ Standard 的密合度上,当可令人放心。

    2) the C++ programming language 0201889544 A-W/1998-3ed
    ***以下为候捷候老师评语:
    属 「C++ 百科」级的书。此书可谓 C++ 原典,具权威性,由 C++ 之父所着。连 ANSI C++ 制定时都得叁考此书。不论是内容深度或文字风格,都不适合生手,但很适合做为进阶研究或叁考查阅壮胆之用。原文书之code 编排令我感到不舒服,行文之间学院派的味道颇重。本书为与C++ Standard 相映合,有份量极重之 errata,务请读者上网下载。

    3) Thinking in C++ 0139177094 PTH/1995-1ed
    ***以下为候捷候老师评语:
    也属「C++ 百科」类书。口碑甚佳,唯目录所列页次与实际页次 offset 4 1/e 年代过於陈旧,当此 C++ Standard 已定案之际,应属过时。
    ps.第二版将不会有以上现象,但还未完书
    //蒋按:大陆版有Thinking in Java

    4) C++ Standard 抱歉我查不到资料....
    ***以下为候捷候老师评语:
    醉心学术以及喜欢看 definition 的人,一定会喜欢。有此资料在手,与人争辩 C++ 时可使用最大的胆子和最大的分贝。电子版(PDF 格式)
    可於 http://webstore.ansi.org/ 购得,US$ 18.0。列印出来装订得
    美美的,摆在架上足以唬人。

    5) Effective C++, 2nd Edition: 0201924889 A-W/1998-2ed
    50 Specific Ways to Improve Your Programs and Designs
    ***以下为候捷候老师评语:
    以条列方式列出 50 条宝贵的程式经验。每一条均有深入的原理说明。适合有 C++ programming 经验者。
    //蒋按:有大陆版

    6) More Effective C++: 020163371x A-W/1996-1ed
    35 More Ways to Improve Your Programs and Designs
    ***以下为候捷候老师评语:
    以条列方式列出 35 条宝贵的程式经验。每一条均有深入的原理说明。
    适合有 C++ programming 经验者。

    7) Inside the C++ Object Model 0201834545 A-W/1996-1ed
    ***以下为候捷候老师评语:
    适合给已有 C++ 经验的人阅读。可为你扎下 C++ 内部机制的深厚基础。原文书笔误极多(100 个以上,大大小小),影响阅读甚巨,建议读中译本。对大部份人而言,chap3,4 可带来最大边际效益。

    8) The Design and Evolution of C++ 0201543303 A-W/1994-1ed

    9) The Annotated C++ Reference Manual 0201514591 A-W/1990-1ed

    10)Advanced C++ Programming Styles and Idioms 0201548550 A-W/1991-1ed

    11)C++ Programming Style

    Assemble:
    1. Microsoft Macro Assembler Bible 2/e(Barkakati/SAMS) 峰中译

    2. PC Assembly Language and Programming 0137566107 PTH/1997-4ed

    Windows:
    http://www.csdn.net/expert/jjhou/
    1.Windows 2000系统编程 原书名: Windows 2000 Systems Programming Black Book
    原出版社 Coriolis 作者: Al Williams 译者: 钮文良 姜余祥 申功迈 尤克

    2.windows NT/2000本机API参考手册 Gray Nebbett,机工

    1。Windows 2000 内部揭密 原书名: Inside Microsoft Windows 2000,Third Edition
    原出版社 Microsoft Press 作者: (美)David A.Solomon Mark E.Russinovich
    译者: 詹剑锋 等译

    2。inside win2000

    1 rogramming Windows 95(Petzold/MP) 松格中译
    //注:大陆版-清华大学出版社

    2. Windows 95 : A Developer's Guide(Richter/M&T Books) 棋峰中译
    //注:大陆版-清华大学出版社

    3 System Programming for Windows 95(Oney/MP)松岗将有中译

    4 Writing Windows VxDs and Device Deviers 2/e(Hazzah/R&D Books)无中译本

    5 Windows 95 System Programming Secrets(Matt/IDG Books)旗标中译
    //注:大陆版-清华大学出版社

    6 Advanced Windows 3/e(Richter/Microsoft Press)松岗中译

    7 The Windows NT Device Driver Book(Baker/Prentice Hall)

    COM
    1. Essential COM(Don Box/Addison Wesley) 棋峰将有中译

    Cmpiler:
    Compilers Principles, Techniques, and tools 0201100886 A-W/1986-1ed

    【Computer Architecture】
    1) Computer Organization and Design : 1558604286 Morgan/1997-2ed
    The Hardware/Software Interface
    ***大学教科书(计算机组织),这个topic的入门书

    2) Computer Architecture : 1558603298 Morgan/1996-2ed
    A Quantitative Approach
    ***大学教科书(计算机组织),这个topic的入门书

    3) Computer Architecture : Concepts and Evolution 0201105578 A-W/1997-1ed


    【Unix】
    1。Linux内核情景分析,上,下册。浙江大学出版社

    2。Linux内核源代码分析(美)[S.麦克斯韦尔]

    3。Linux编程白皮书

    4。Linux IP协议栈源代码分析

    5。莱昂氏unix源代码分析

    6.Running Linux (3rd Edition) by Matt Welsh, Matthias Kalle Dalheimer, Lar Kaufman, Matthew Welsh

    7.Hacking Linux Exposed by Brian Hatch, James B. Lee, George Kurtz

    8.Linux System Administration (Linux Library)
    by Vicki Stanfield, Roderick Smith, Roderick W. Smith

    9.Linux Complete by Sybex (Editor)


    5) Unix system administration handbook 0131510517 PTH/1995-2ed
    ***网路上昵称其为"红皮书",系统,网路都说的十分详细,无可挑惕!!
    进阶用书,不适合初学者

    1) Unix internals -the new frontiers 0131019082 PTH/1996-1ed
    ***深入UNIX.....进阶用书(SVR4 BSD都有讨论)

    2) 4.4 BSD Operating System 0201549794 A-W/1996-2ed
    ***同上,但以4.4BSD为主题

    3) The Magic Garden Explained : The 0130981389 PTH/1994-1ed
    Internals of Unix System V Release 4 : An Open Systems Design
    ***同上,但以SVR4为主题。台湾没有书,我是向国外订的
    (听说台大图书馆有喔~~~)

    4) The Design of the UNIX operating system 0132017997 PTH/1986-1ed
    ***同上,BACH着,很多教科书都指名它为reference....

    5) Lions' Commentary on Unix : With Source Code 1573980137 P-t-P/1996-6th

    6) Unix Internals : A Practical Approach 020187721X A-W/1996-1ed

    7) Unix Systems for Modern Architecture 0201633388 A-W/1994-1ed
    : Symmetric Multiprocesssing and Caching for Kernel Programmers

    8) The Linux Kernel Book 0471981419 Wiley/1998-1ed
    ***我觉得翻译得怪怪的(因为它是由别国语言翻成英文)....
    最好先对kernel有多些概念再读会较好....

    9) Linux Kernel Internals 0201331438 A-W/1997-2ed
    ***讨论linux kernel的书,恐龙书上在linux部分的reference,个人推荐

    10)Linux Device Drivers 1565922921 O'reilly/1998-1ed
    ***网友推荐,作者是来自义大利的骇客....

    1) Advanced programming in the UNIX environment 0201563177 A-W/1992-1ed
    ***Richard Steven所着,十分适合对系统,C有基础的人,亦是一本好的manual

    2) UNIX systems programming(for SVR4) 1565921631 O'relly/1997-1ed
    ***网路上评语为其讨论内容过杂,但我觉得满适合拿来当reference

    1) managing projects with make 0937175900 O'reilly/1993-2ed
    ***对make有详细的说明

    2) programming with GUN SOFTWARE 1565921127 O'reilly/1997-1ed
    ***个人强力推荐!!教你用emacs,gcc,gdb,gmake....

    1) A Practical Guide to Linux 0201895498 A-W/1997-1ed
    ***(A Practical Guide to UNIX的再版)
    Linus写序提到, 他当初就是用这本书学Unix, 没想到七年後很荣幸的为
    作者写序.

    2) Running Linux ?????????? O'Reilly/1999-3ed

    3) Linux Network Administrator's Guide ?????????? O'Reilly/1999-2ed


    【系统安全】
    1) maximum Security:A hacker's guide to 0672313413 Sams/1998-2ed
    protecting your internet site and network

    2) Cracking Des : Secrets of Encryption 1565925203 O'reilly/1998-1ed
    Research, Wiretap Politics & Chip Design

    3) Practical Unix and Internet Security 1565921488 O'reilly/1996-2ed

    4) Building Internet Firewalls 1565921240 O'reilly/1995-1ed

    Netword:
    3) internetworking with TCP/IP vol 1: 0132169878 PTH/1995-3ed
    Principles, Protocols, and Architecture

    4) internetworking with TCP/IP vol 2: 0130102210 PTH/1999-3ed
    design,implementation and internals

    5) internetworking with TCP/IP vol 3: 0132621487 PTH/1996-2ed
    client-server programming and application
    ***以上三本乃comer所着,属bible级读物。为大学教科书.....
    vol1讲TCPIP的原理,vol2讲TCPIP的implementation,vol3讲APP的写作
    另外vol3分成三个版本,分别为BSDsockets,winsock,TLI

    6) TCP/IP illustrated vol 1 0201633469 A-W/1994-1ed

    7) TCP/IP illustrated vol 2 020163354x A-W/1995-1ed

    8) TCP/IP illustrated vol 3 0201634953 A-W/1996-1ed
    ***以上三本乃Richard Steven所着,影响小弟甚深,bible级读物。
    vol1讲TCPIP的原理,vol2讲TCPIP的implementation,vol3讲APP的写作

    10)UNIX network programming 0136493289 PTH/1998-2ed
    vol 1:networking API:Sockets and XTI
    ***以上两本亦为Richard Steven所着,第一本为第一版,小弟无缘
    第二本为第二版,强力推荐!!

    11)UNIX network Programming 0130810819 PTH/1998-2ed
    vol 2: Interprocess Communications
    ***以IPC为主题,觉得"杂"了点....但不失为一代宗师之作

    【Data structure and algorithm】
    1。数据结构算法与应用-C++语言描述(英文版) 原书名: Data Structures,Algorithms, and Applications in C++ 原出版社 McGraw-hill 作者: Sartaj Sahni

    2。数据结构与程序设计——C++语言描述(影印版)原出版社 Prentice Hall/Pearson
    作者: Robert L.Kruse,Alexander J.Ryba

    3。数据结构C++语言描述 原书名: Data Structures C++
    原出版社 作者: William Ford,William Topp 译者: 刘卫东 沈官林

    4。数据结构 C++语言描述(英文影印版)原书名: Data Structures with C++
    原出版社 Prentice Hall/Pearson 作者: William Ford ,William Topp

    5。数据结构与算法分析 原书名: A Practical Introduction to DATA STRUCTURES AND ALGORITHM ANALYSIS 原出版社 作者: CLIFFORD A.SHAFFER 译者: 张铭 刘晓丹

    6。数据结构算法与应用-C++语言描述 原书名: Data Structures, Algorithms, and Applications in C++ 原出版社 Mcgraw-Hill 作者: Sartej Sahni 译者: 汪诗林等

    1) Fundamemtals of DATA STRUCTURES IN C 0716782502 CS/1993-1ed(?)
    ***大学教科书(data structure),另有PASCAL,C++版本
    //蒋按:有大陆版

    2) Introduction to algorithms 0262031418 MIT/1990-1ed
    ***大学教科书(algorithm)

    3) Computer Algorithms/C++ 0716783150 CS/1996-1ed
    ***大学教科书(algorithm),另有PASCAL版本。
    不必我说,IA和CA两本都是超棒的!!都拿来读读,多读几次......
    阅读顺序由个人选择。我选CA->IA
    //蒋按:有大陆版

    4) The Art of Computer Programming (Vol 1): 0201896834 A-W/1997-3ed
    Fundamental Algorithms

    5) The Art of Computer Programming (Vol 2): 0201896842 A-W/1997-3ed
    Seminumerical Algorithms

    6) The Art of Computer Programming (Vol 3): 0201896850 A-W/1998-2ed
    Sorting and Searching
    ***以上三本....我不必介绍了吧??(好想找时间完整的研究一次....)

    7) Distributed Algorithms 1558603484 M-K/1997-1ed
    ***还没玩完,但只想说: 真的好棒!!

    【作业系统通论】
    1) Operating System concepts 0201591138 A-W/1997-5ed
    ***大学教科书(operating system),俗称"恐龙书"。很棒的作业系统入门书

    2) Modern operating system 9813076623 PTH/1996-2ed
    ***大学教科书,配合恐龙书服用,效果加倍

    3) Operating systems design and implememtation 0136301959 PTH/1997-2ed
    ***大学教科书(advanced operating system)
    教你写一个完整的OS(Minix),不含网路系统

    4) Distributed Operating systems 0131439340 PTH/1995-2ed

    系统分析,设计,软件工程:
    1。《软件工程》实践者的研究方法
    Software Engineering A Practitioner's Approach Fourth Edition
    (美)Roger S.Pressman著
    黄柏素 梅宏 译
    机械工业出版社

    3。软件工程实践者之路(第5版)(英文影印版)
        ROGER S.PRESSMAN/ 7-302-04139-3/清华大学出版社/ 2001-1-1出版

    4。软件需求
        Karl E.Wiegers/ 7-111-08127-7/机械工业出版社/

    2。软件工程——理论与实践(第二版 影印版)
        (美)Shari Lawrence Pfleeger/ 7-04-010099-1/高等教育出版社/

    3。能力成熟度模型(CMM):软件过程改进指南
        (美)卡耐基梅隆大学软件工程研究所/ 7-5053-6729-3/电子工业出版社/

    6。面向对象系统分析与设计
        Ronald J.Norman/ 7-302-02342-5/清华大学出版社/

    7。面向对象系统分析与设计(英文影印版)
        Ronald J.Norman/ 7-302-02944-X/清华大学出版社/ 1999-10-1出版

    8.系统分析与设计方法(第五版 影印版)原出版社 Prentice Hall/Pearson
    作者: Jeffrey L.Whitten,Lonnie D.Bentley,Kev


    Java"
    1。thinking in java
    2。Java2核心技术系列
    3。J2EE服务器端高级编程 Professional Java Server Programming J2EE Edition
    原出版社 Wrox Press 作者: (美)Subrahmanyam Allamaraju 等著
    4。J2EE平台上的EJB组件开发 Applying Enterprise JavaBeans Component-Based Development for the J2EE Platform
    原出版社 Addison Wesley/Pearson 作者: (美)Vlada Matena Beth Stearns
    5。 《Mastering EJB II》Ed Roman http://www.theserverside.com
    6。Enterprise JavaBean
    7.《Java in a Nutshell 》 David Flanagan
    8.JAVA与XML 原出版社 O'Reilly 作者: (美)Brett McLaughlin 译者: 孙照林 汪东 王鹏
    9.Effective Java(TM) Programming Language Guide by Joshua Bloch
    10.Core J2EE Patterns: Best Practices and Design Strategies
    by Deepak Alur, John Crupi, Dan Malks
    11.J2EE Applications and BEA WebLogic Server by Michael Girdley, Rob Woollen, Sandra L. Emerson
    12.Professional EJB

    XML:
    1.Java & XML, 2nd Edition: Solutions to Real-World Problems by Brett McLaughlin
    2.XML in a Nutshell : A Desktop Quick Reference (Nutshell Handbook)
    by Elliotte Rusty Harold, W. Scott Means
    3.XML高级编程 原书名: Professional XML 原出版社 Wrox Press 作者: Didier Martin
    译者: 李喆 严春莹 马琳
    4.Java XML编程指南 原书名: Professional Java XML Programming
    作者: (美)Tom Myers Alexander Nakhimovsky 译者: 王辉 张晓辉 等