Linux Programming By Example 155
Linux Programming By Example | |
author | Kurt Wall |
pages | 533 |
publisher | QUE (InformIT) |
rating | 9/10 |
reviewer | Craig Maloney |
ISBN | 0789722151 |
summary | Linux Programming by Example is a concise and solid introduction to programming under the Linux system. Excellent instructions accompany fully-working examples of code. |
There are plenty of books on this topic as any trip to the bookstore will show. Where this book excels compared with other Linux programming books is its consistent focus throughout. Other books tend to explain a multitude of concepts without relating them back to a real-world example. In Linux Programming By Example, the author introduces a concept, and explains it with an example. In the last chapter, the author integrates the knowledge he's presented, utilizing many of the book's concepts in building a simple CD-Database program. Of course, not all of the concepts relate to the final CD database (The chapters TCP/IP Programming, The Sound API and Using the Mouse are not referred to in the final program), but it's helpful for beginning programmers unsure how all of these pieces fit in the bigger picture of a working program.
Begin at the beginning
Linux Programming By Example begins with topics that don't get covered until the end of many books. The book starts by discussing how to use GCC and make on a Linux machine, and how to create a Makefile. It's always puzzled me why some books don't cover the compiler or the make process until the end of the book. What's the point in that? Granted, chapters in debugging and RCS are left to the end of the book, but presenting key concepts in the development process early in the book helps the reader to get a better feel for how all of these concepts interrelate in a Linux/UNIX environment.
Moving forward
From the basics of compilation and making programs, the book moves to the basics of a Linux system in Part II: System Programming. This is where the book truly shines. In the section on processes, Wall discusses the elements that make up a process, how to manipulate a process, and why you would want to do this anyway. The book assumes no prior UNIX knowledge, but doesn't plod along like most introductory texts. In the section on signals, the book defines what signals are, early signal APIs and their issues, POSIX and Linux signal APIs, and how to use signals and signal sets. In this chapter, the author not only lists the signals supported by the Linux system, but also other signals supported by POSIX and other UNIX systems. While this might sound confusing, the author takes time out to explain which signals are really important in a Linux environment. This is a key reason why this book retains its readability without losing depth. Each chapter in the System Programming portion of the book retains this format -- not only demonstrating what the topic is, but also where this fits in a Linux/UNIX system and why you would even bother to know this in the first place.
What's good?
Linux Programming By Example is clearly aimed at getting programmers up to speed on not only programming Linux systems, but also POSIX based systems. Wherever possible, the author makes a point of pointing out the POSIX way. This book could have been easily called POSIX Programming by Example. The author also makes no bones about implementation issues with Linux and the POSIX or System V way of implementation. The book clearly states where Linux falls short of the full POSIX standard, and where pitfalls with porting code from other systems may occur. It's a refreshing change from other beginner texts which assume the reader will discover these pitfalls on their own.
So what's in it for me?
If you're looking for a quick, effective way to get up to speed in Linux and UNIX programming without breaking the bank, Linux Programming by Example is the book to take you there. This book is designed for programmers who are familiar with programming on other systems but haven't dealt with Linux before.
You might have trouble locating this book, since QUE let it lapse for a while, but there should be another batch hitting stores soon. You won't be disappointed.
You can purchase Linux Programming By Example from bn.com. Slashdot welcomes readers' book reviews -- to see your own review here, read the book review guidelines, then visit the submission page.
Chicken and egg (Score:4, Funny)
Re:Chicken and egg (Score:1)
More importantly, I do not understand examples, what about "examples by example".
Re:Chicken and egg (Score:1)
Re:Chicken and egg (Score:1)
Re:Chicken and egg (Score:1)
On your user page, preferences tab, comment options, there's a section called "Reason Modifier", in which you can penalize funny posts.
Of course, everybody's going to call you a curmudgeon, but you can probably filter that out too.
Re:Chicken and egg (Score:1)
Re:Chicken and egg (Score:1)
WROX press books also very good on the subject (Score:4, Informative)
I've always liked the the red books.
B&N [barnesandnoble.com]
You're just attracted to... (Score:3, Funny)
At least, that's why I buy WROX Press publications. I've got a whole library, and it looks like the bleedin' Chernobyl yearbook exploded on my bookshelf.
Excellent (Score:2, Interesting)
Re:Excellent (Score:1)
I'll bite, so why do you feel that years of Windows programming has left you in the minor leagues? I would think your league is somewhat indicated by pay check and years of windows development should pay nicely.
Re:Excellent (Score:3, Insightful)
They seem so free of the weird little troubles that plague windows people, they are in charge of their own systems and not spoon fed like windows users, they run the entire Internet (at least the bedrock of it), and they have a system that has remained fundamentally almost unchanged for 30 years in this turbulent industry.
I interpret that as a sign of evolution into perfection, or something like it.
Re:Excellent (Score:2)
They seem so free of the weird little troubles that plague windows people, they are in charge of their own systems and not spoon fed like windows users, they run the entire Internet (at least the bedrock of it), and they have a system that has remained fundamentally almost unchanged for 30 years in this turbulent industry.
I interpret that as a sign of evolution into perfection, or something like it.
Don't get mixed up between perfection and people who affect an air of superiority/snobbery.
There's a big difference. Perfection? Unix ain't it.
Simon
Re:Excellent (Score:1)
Re:Excellent (Score:1)
In what régime?
It's certainly not the 'perfect' OS by any stretch. There are systems with more cohesive GUIs out there. There are systems with better handling of removable media out there. There are systems with better real-time support out there. And woebetide you if you try to run Linux on a parallel processor machine.
There's no such thing as perfection. It's an abstract concept. Everything is a shade of gray somewhere in a continuum of choices.
Re:Excellent (Score:1)
Sorry if that's not clear. I never said it was the perfect OS. In fact it is far from perfect, but read the first sentence again. Closest to perfection.
In reply to better GUIs. Most Unices exceed in their lack of GUI. Nothing like a headless machine when you are limited on keyboards and monitors. If you need a GUI there is plenty of window managers out there.
Re:Excellent (Score:2)
I have this book and it has brought me great joy (Score:4, Informative)
The current Linux programming wisdom comes from Richard Stevens, a know-nothing hack who spends more time talking about the out-dated concept of filesystem permissions and socket programming than he spends on GUI design! I mean, for crying out loud, Dick, this is the Aughts! We "aught" to be optimizing for the user experience, not ivory tower "engineering principles"!
Anyway, throw away your copy of Linux Kernel Internals because this book replaces it...and then some!
Re:I have this book and it has brought me great jo (Score:1)
BE SILENT spawn of MSCE! A good user experience is dependent on a good design. A bad GUI in a good design can be replaced/redesign easily. A good GUI in bad design is hopeless.
It is just like a woman - you need a good body for that pretty face. (Thats the best analogy I could think of. It is not very good, however. I don't think it is easy to replace the head... No matter how good the body might be)
Re:I have this book and it has brought me great jo (Score:2)
Linux programs are by and large written in c and c++. These require very little UNIX knowledge as Linux is built for portability. The "current Linux programming wisdom" comes from a variety of places not from one place. I learned C on my one and what I know of OS design I learned from Tanenbaum. "Engineering principles" can be used while designing for user experience, if they are not the end result is an OS that crashes when a program errors out (remember Commodore 64?).
Re:I have this book and it has brought me great jo (Score:2)
Remember Windows? You know, there are a lot of slashdotters that simply aren't old enough to remember the C-64. Around here you might as well say "Remember the PDP-7?" I mean, geez, you could at least use an example people can relate to!
(FWIW, I am old enough to remember the C-64, but I never used one. I was too busy hacking Basic on my TRS-80 (the cartridge slot didn't work, so there was nothing else I could do with it!). In fact, the only Commodores I ever used were the PET in my 4th grade classroom and my friend's Amiga 1000 (now that was a sweet machine!))
Re:I have this book and it has brought me great jo (Score:1)
Well, if you mention windows or Linux you have stuck yourself in one group and joined an ideological argument as far as most are concerned. Also, fwiw, I have never met any serious computer enthusiast who did not know what C 64 was.
Re:I have this book and it has brought me great jo (Score:2)
I have another book for beginners called "Beginning Linux Programming" by Wrox press. It too had an example of a CD database. I guess CD databases make great real life examples.
Re:I have this book and it has brought me great jo (Score:2)
Outdated? (Score:5, Informative)
It might be a little outdated. This review seems to be a couple of years late
Re:Outdated? (Score:4, Funny)
next review: VAX programming by example, circa 1978
I enjoyed... (Score:5, Informative)
Re:I enjoyed... (Score:1, Informative)
Other good Linux programming books (Score:5, Informative)
Linux Programming By Example????? (Score:3, Funny)
Re:Linux Programming By Example????? (Score:4, Funny)
Re:Linux Programming By Example????? (Score:2)
But who's on first?!
Re:Linux Programming By Example????? (Score:1)
>But who's on first?!
Exactly!
Who throws it to Enlightened, Enlightened throws it to Example, Example throws it to Confused and Confused throws an exception. 8)
Cheers
Stor
Linux In a Nutshell (Score:1)
*sorry Austin*
Re:Linux In a Nutshell (Score:2)
Finally. (Score:2, Informative)
One of the advantages of (L)inux. . . (Score:2)
gcc is *typically* installed by default by the major distros. There is something of a "protocol" to do so ( and even then a couple of distros aimed at the desktop newbie have also failed to include it at all, even as an install option).
No matter what though, even if it isn't included with your distro as an *option* at install you can always just go download it.
Now *THAT* is what is the coolest about Free/Open/Artistic/Whatever software.
KFG
Re:One of the advantages of (L)inux. . . (Score:1)
Yeah... but how do you compile it?
learning by example... (Score:3, Funny)
Makefiles.... (Score:5, Insightful)
I am going to get this book because it covers make in the begining. I have always had trouble getting my makefiles to work properly in the few instances of linux programming that I have done. And even then I copied an existing one and adjusted it to my needs.
I suppose the "there is only 1 makefile" saying exists for a reason...
Re:Makefiles.... (Score:2)
Re:Makefiles.... (Score:2, Insightful)
Re:Makefiles.... (Score:2)
The "just let automake take care" mindset is getting really annoying. There are already too many packages out there with an half-an-hour-./configure and shell scripts starting with #!/bin/bash. Duh.
Re:Makefiles.... (Score:3, Informative)
Ever worked on AIX using xlC? And libtool? They're totally different from the rest of the known universe and so even if your code will happily compile on Linux, Solaris, etc. then the makefiles have to be absurdly complex to handle AIX's weirdness.
Of course, you may want to do dynamic linking since libtool and templates don't play well together. But, looky, xlC doesn't play well either so you have to have a separate
Automake and autoconf save us from most of the nightmare here. Oh, and we're also linking against Oracle and MQSeries. More fun.
Yes, avoiding things like #!/bin/bash (or even ksh) is wise, but automake/conf have come into existence for a very good reason. Makefiles are godawful.
Re:Makefiles.... (Score:1)
This is why almost every shop I've worked in (which is several in a variety of industries) uses gcc. Even when I worked for a company that was actually antagonistic towards free software the projects that were Unix based use gcc.
This is also why it seems like most of the shops are closing down their compiler teams. Maybe I'm wrong. I know Sun used to have their own compiler (that cost extra), HP used to have their own (that was extra), IBM had their own as well (what do you know, it cost extra). I don't know how many companies still sell their own compiler; however, I don't see how they can afford to any more.
Re:Makefiles.... (Score:2)
We have gcc compiled here... but it takes twice as long to compile our code as it takes xlC, and the resultant code core dumps as soon as something actually happens. We haven't had time to trace the issue down yet, but we still hope to move to gcc because of issues we have with IBM's xlC and dbx (as in - dbx usually doesn't work).
Someone had to say it (Score:1)
One makefile to rule them all
One makefile to find them
One makefile to bring them all
And in the darkness bind them
Don't get mad. It was either that or "All your makefile are belong to us."
Re:Someone had to say it (Score:2)
I am not sure, but after a year or so, I think it grew concious and started modifing itself. I didnt understand it or any of it's offsprings any longer, but I am quite sure it was evil. And it never liked me! In the end I had no choice but to kill it and there was much rejoycement as the students had feared it as well. I had to write new makefiles for the subdirectories myself And though the new makefiles was simpler, had less features and required a more rigid structure of subdirectories everybody breathed more easily after that.
I just fear some careless student might have a taken a backup and that it is still breeding evil offspring somewhere. Someday it might come back to revenge the murder of it's copies everywhere. So beware!
Not Stocked (Score:3, Informative)
amazon sold out, amazon uk has it (Score:3, Informative)
and as an added bonus you get to read everything with an english accent.
Re:Not Stocked (Score:2)
9/10 ? (Score:5, Informative)
Re:9/10 ? (Score:4, Funny)
Make ? (Score:3, Informative)
Here's the acid test, does it contain a "Hello world" program or something similarly trivial ?
Re:Make ? (Score:1, Insightful)
this can also be had (Score:3, Informative)
What's in a name? (Score:2, Insightful)
Re:What's in a name? (Score:3, Insightful)
I agree with your basic point, however, that simply saying "Programming Linux" implies development work on the core components of a Linux system. If you really wanted to be pedantic about it, it would imply simply the Linux kernel.
Re:What's in a name? (Score:1)
Re:What's in a name? (Score:2)
respect RMS! (Score:1)
"Programming GNU/LINUX"
or
"Programming GNU/LINUX with GNU tools"
or better yet
"Programming GNU/LINUX with GNU tools while using
GNU/EMACS"
nbfn
Re:What's in a name? (Score:2)
great (Score:5, Funny)
Re:great (Score:2, Insightful)
Re:great (Score:2)
No wonder i've been getting all these sores on my feet.
Standard Store Linkages (Score:2, Interesting)
B&N: Not Stocked [bfast.com] [referral]
Bookpool: Not Stocked [bookpool.com]
Looks like the best bet is going to be half.com or a used bookstore - kind of an old text.
Re:Standard My Ass (Score:1)
Alternatively... (Score:5, Informative)
The Wrox P2P title Beginning Linux Programming [amazon.co.uk], by Richard Stones and Neil Matthew, covers some similar ground: makefiles, shell scripts, some basic C, Perl and TCL (not really basic - they show you how to use these languages to do some typical linux-y things, rather than explain about structs and scalars), an introduction to GTK and a chapter at the end on writing device drivers. If you're an intermediate-level programmer unfamiliar with Linux as a programming environment, this book offers a good way in; recommended for VB weenies with a conscience.
Re:Alternatively... (Score:3, Informative)
A really great book.
I wonder how their 2nd book Professional Linux Programming is? (Hint hint
system level programming (Score:3, Interesting)
This book actually sounds really good, for advanced and beginner programmers that are new to linux/unix...
Book selling out! (Score:5, Funny)
Re:Book selling out! (Score:1)
Such a cart does not model the real world very well: somebody can take stuff that you already have in your cart?
Perhaps it is based on New York shopping culture.
My Impressions of this book (Score:3, Informative)
On the whole I would say it really deserves a 6.5 or a 7. It's worth getting if you're looking to learn about programming on a POSIX system, but if you already have a book on the topic, you might want to save your money.
Kernighan and Pike also good (Score:3, Informative)
BN, what about Amazon? (Score:3, Interesting)
I started to purchase books from Amazon.com once I realized that BN doesn't post bad reviews. Maybe they do now though.
As much as Amazon may have patented a stupid thing, they don't seem to censor comments. Many books have many bad comments. And, that is why I am happy to buy from them.
Re:BN, what about Amazon? (Score:2)
I submitted a seriously thought through review on "Dekalog" (these are my favourite films I've ever seen) - though no-one could call them "happy!"
Yes buy it. (Score:1)
Bought it back in 2K, definately a good read (and helpfull). Having a chapter on NCurses and screen manipulation was a bonus.
Linux Lacks a Solid API (Score:1, Troll)
One of the hurdles that Linux has been unable to overcome is the fact that the various parts of the OS are kludges together. There is no synergy. X for example isn't well integrated into the rest of the OS. Consequently one winds up with inconsitent behavior: Sometimes right clicking cuts-and-pastes; othertimes it doesn't. There are other examples of this. A quick search of Google can help you find them.
I would like to see Linux succeed. Hopefully the main development team will work on getting a solid API in place so that when I develop for Linux I can spend my time writing my program, not writing code that should already exist.
Thanks,
ET
Solid API? On Windows? (Score:1)
When you talk about Linux's API, you're on fuzzy ground. Do you mean the kernel, or possibly libc6 or some other centrally standardized libraries? Or all of them together? Which libraries, in that case?
If you're worried about reinventing the wheel, don't be. Linux is equipped with pretty standard libraries that do much more than stock Windows libraries do. You just need to know which library contains the functionality you need. Just like in Windows, except you'll need to start making your own code much later, since the libraries provide you with much more ready-made functionality.
Anyway, the library APIs are free (as in speech) for one thing! You can actually look at the source and see that the method the API documentation talked about actually exists, and you can see exactly what it does.
Of the thousands of Windows libraries, only a portion is documented. MS has huffed and puffed this autumn and released several hundred new libraries with press releases to boost. But still parts of Windoze are undocumented to the developers at large. And rare are the people who have actually seen the source code that makes up even a minor part of Windows. And you call this a "solid API"?
Re:Solid API? On Windows? (Score:1)
(Begin obligatory rant)
Why focus on the OS? API's and tools should try to be OS-independent. True, if you are writing device drivers or fast games it matters. However, for most things I think we are at the stage where API's and protocols can *hide* most of the OS guts. File systems, GUI's, etc. should all be OS-neutral protocols. We already have such more or less for HTTP and databases, for example.
Kill Windows by making it irrelavent or invisible, not by adding yet more incompatible features to *nix. That won't work.
Re:Linux Lacks a Solid API (Score:1)
And for a damn good reason too. X should not be integrated into any other part of what makes up most Linux systems as X is an addon. I should not need X to have a working Linux system and X should not need Linux to work itself. They are designed to be seperate.
Sometimes right clicking cuts-and-pastes; othertimes it doesn't.
Hmm ya.. right clicking has never cut os pasted anything for me before... perhaps it has something to do with the fact that the middle mouse button pastes, and the simple act of highlighting copies. This works everywhere too... uncanny how it works eh? If you are speaking of the inconsitancies say between desktop environments such as gnome and kde well... they extend the basic X clipboard in different ways. Gnome and KDE are two different systems, and if you mix them you'll get inconsistant behavior... it's the way these things work. You want consistancy... choose one and stick to it. Besides KDE and Gnome copy and paste are starting to work together lately.
Hopefully the main development team will work on getting a solid API in place..
Who? You mean the kernel developers? The XFree86 developers perhaps? Perhaps GNU (they do make glibc and gcc)? Maybe the KDE/Gnome teams... You're post is kind of awkward... I'm having a hard time telling if you are intentionally trying to be funny or really don't have a clue.
Not even your reveered windows has an all inclusive API. They have GDI, DirectX, etc. etc. Different API's for each job and they usually don't communicate much with eachother either. So I must ask...
What exactly are you talking about?
Re:Linux Lacks a Solid API (Score:3, Informative)
There are problems and the problems are that some API's are not designed well. But this has nothing to do with "comprehensive API" or whatever you are blathering about. Rest assurred that Windows uses a different call for cut/paste than it does to read files, just like Linux.
X is "integrated" in that it actually uses communication calls that exist in the system and are used by other parts of the system. This is why it works remotely. In this area Linux is vastly superior to Windows for "comprehensive API", in Windows there is NOTHING below the graphics interface that is reusable by anything other than graphics. The fact that X has a horrible interface is certainly true but irrelevant to "comprehensive".
Also I don't think right-mouse pastes in ANY program. Middle mouse does, and it works in every X program I have ever seen. The inconsistencies are in what Ctrl+V does, not in what middle-mouse does. The fact that you did not know this indicates that you know little or nothing about Linux.
Re:Linux Lacks a Solid API (Score:2)
There is no X preference for what mouse does paste, so there is no "setup" either (unless you are counting xmodmap, but if you mess with that you will change a lot more than just what key does paste). The programs either get it right or get it wrong. As far as I can tell they all agree.
Re:Linux Lacks a Solid API (Score:2)
An event structure that is passed by reference may be a reasonable change to fltk, but it would break a huge amount of software already written. Also I have not really had the need to think about more than one event at a time, and the static locations greately assist checking the event without having to have an event argument added to every single call.
Where the idea fails is when events vary depending on what widget they are sent to. In fltk2.0 the x/y are being modified so they are relative to the corner of the widget, unfortunately for compatability this is done by changing the static locations back and forth. If it were not for compatability I would make a method on a widget that figures out and returns the x/y from the static global x/y. But this would still allow the x/y to be in static locations.
Re:Linux Lacks a Solid API (Score:2)
I'm not going to suger-coat the situation in "I'm okay, you're okay" crap. The second type of people are right. The first style of API has its uses (for example, it's not a terribly bad idea in Java, which is used for end-user applications rather than systems programming) but is overall a crappy idea for a system-level API. Just note the difference between UNIX and Windows. How many API's has Microsoft had over less than two decades? DOS, Win16, Win32, MFC, ATL, WTL,
Surprising to see a good QUE book (Score:3, Informative)
The problem with QUE books (and other Macmillan Computer Publishing imprints) is attention to detail. Their production processes tend to introduce errors (for example, by loading the text into Word and having it change all the backticks to apostrophes - that happened to me!). Also, they don't usually seem to do reprints correcting errors, they just seem either to produce a new edition ("Special Edition", whatever) with a "Featuring FooMatic 97!" badge on the cover.
Another problem with QUE books is that they just tend to be written and published too fast - no time for doing a good job.
I should emphasise that Macmillan Computer Publishing, who produce QUE books, are as far as I know completely unrelated to the British publisher, Macmillan.
Disclaimer: You should know that I've had a bad experience as a contributing author of several MCP books, and have vowed not to have anything to do with them again. So as you can see I'm very biased against them. I have not read the "Linux Programming by Example" book and indeed haven't made any comments about this book in particular.
its just programming by meta-w (Score:1)
Annoyances with this book (Score:1)
*When they say "by example", they mean it! The discussions are quite brief - most of the book is sample code.
*I could do without the chapter on makefiles. It's not very informative and doesn't mention GNU autotools. You're much better off RFTM.
*Likewise, the RCS chapter is a waste. Does anybody actually use RCS anymore?
*The information on Berkeley DB is very outdated.
The rest of the book is quite useful, but I'd recommend the Linux Programming Bible instead.
QUE?!! (Score:2, Interesting)
Interestingly, you can read online the full versions of the New Riders books I mentioned here [newriders.com].
(If you have trouble with that link, go through the New Riders home page [newriders.com] and search for the titles.)
publisher QUE (InformIT) (Score:1)
Unix Systems Programming for SVR4 (Score:4, Informative)
I have to write C/C++ code daily for Tru64 and Linux. Unix Systems Programming [amazon.com] and Programming with POSIX Threads [amazon.com] are two very good books. They aren't Linux-specific books, but I've used these books on a weekly (or daily) basis for a couple of years despite the USP book being written in '96.
$12.00 at Fry's (Score:1)
Linux Programming Unleashed... (Score:2)
This isn't meant to bash the author. Linux Programming by Example is a very good book for people who know how to program in C, but have never done it for Linux before. I consider it to be the "lite" version of Linux Programming Unleashed. Linux Programming Unleashed contains almost the same information as Linux Programming by Example, in the same accessible, easy-to-understand presentation, plus a good deal more (like how to write man pages for your programs).
If it comes down to whether to buy one or the other, if you can afford Linux Programming Unleashed ($50, whereas Linux Programming by Example is around $30) buy that. If not, go ahead and get Linux Programming by Example.
Re:Why another book? (Score:2, Informative)
Re:Programming by Example? O.K! (Score:2, Funny)
You didn't check the return value of printf.
Your indentation style sucks.
I just thought I'd get that in before the morons come climbing out of the woodwork and start demonstrating their complete inability to code.
Hey, you got First Moron!
Re:Programming by Example? O.K! (Score:1)
even Hungarian Notation isn't as irritating as that.
Re:Outdated?? (Score:3, Informative)
and the changes are small.
The book deals very well with the state of linux programming. The basics of make gcc and the different programming tools available. The changes in the programs since then are easy to pick up. It is more about programming technique, how the tools are organised in Linux and how they generally work. gcc 3.2 hasn't taken light years away from gcc 2.95xxx and I have found references for those differences. This book is now one of my favorite quick references.
This is a starting block and a quick reference for many types of programming but it is not the end all reference.
Re:Outdated?? (Score:1)
C++ has been basically stagnant as a standard... just that everyone else is trying to optimize to that standard.
Of course, to really go with a C++ standard, you have to turn on ANSI in the flags.
Re: Hacking the BMW Series 7 (Score:1, Offtopic)
Re:who would want to program for linux? (Score:5, Interesting)
subject: who would want to program for linux?
you don't get paid..
First, that's a troll if we ever saw one. Because 1) there are millions upon millions who program for linux now. 2) they do it for fun, not money. 3) some do it for money too. 4) some do it just for the money. 5) who ever wrote a program they got rich off of? Careful here, remember that Bill Gates bought his first program to sell, and stole many others (or built on the work of others) after that. Microsoft makes money by SELLING software. Not writing it. There is a significant and subtle difference.
Moving on:
Welcome to America, land of capitalism..Is Microsoft hiring?
If I'm not mistaken, America is the land of the free, not the land of capitalism. Capitalism (in it's purest form) has nothing to do with money. A capitalist form of finance stops being capitalism as soon as any one person or company has the ability to create an artificial barrier to competition (and that's whether or not they do actually create the barrier - it just has to be possible). In short - Capitalism depends on a free market, which you don't have if there are barriers to competition in an industry. So much for America being the land of Capitalism. Indeed, you misunderstand capitalism entirely. Capitalism centers around the individual. The individual has the final say and right in _any_ situation - Microsoft on the other hand is anti-capitalist in that whatever the programmer makes belongs to the company he works for. This is a violation of the programmers right to do what they want their own ideas. For example, if you helped write Microsoft's media-player, and had an ingenious idea on how to do it better, you could not leave the company and create this new player based on the knowledge you gained at Microsoft. You'd get sued into oblivion, even if you didn't use Microsofts IP to do it.
The GPL on the other hand entitles the original author some degree of control over his work - if you wrote the original you (the individual) have the right to use the GPL or not (you can even re-licence _your own_ code to companies who don't want the restrictions of the GPL... just make sure it's ALL your code that your re-licencing), and entitles you (the individual) to place restrictions on how your work is used. Get it? Capitalism depends on the individual having rights that supercede the greater interest. Corporations supercede the right of the individual for the good of the company.
And finally, if Microsoft is hiring, what difference does that make to you? Even Microsoft has standards.