Stories
Slash Boxes
Comments

News for nerds, stuff that matters

Slashdot Log In

Log In

Create Account  |  Retrieve Password

Bjarne Stroustrup On Educating Software Developers

Posted by kdawson on Tue Dec 09, 2008 05:46 PM
from the way-it-spozed-to-be dept.
jammag writes "Bjarne Stroustrup, creator of C++ and a professor at Texas A&M, weighs in on the problems in today's CS programs. In particular, Java (there's too much of it), the quality of graduates (companies aren't happy), and the need to balance the theoretical and the practical (long overdue). Not pulling punches, Stroustrup even talks about high schools — 'High schools could teach students to work hard at something (just about anything), to search out information as needed, and learn to express their ideas in writing and orally.' He finishes by giving advice to working developers: 'Serious programming is a team sport, brush up on your social skills. The sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again.'" Read on for more choice quotes from the quotable professor.

I have even had questions from strangers in airplanes: "You're a professor? In software? Have you got any students? Here's my card."

The US industry could absorb more good developers than there are currently students enrolled in IT-related programs — but not all of those programs and all of those students would qualify as "good" in this context.

The companies are complaining because they are hurting. They can't produce quality products as cheaply, as reliably, and as quickly as they would like. They correctly see a shortage of good developers as a part of the problem. What they generally don't see is that inserting a good developer into a culture designed to constrain semi-skilled programmers from doing harm is pointless because the rules/culture will constrain the new developer from doing anything significantly new and better.

The contemporary Math, Physics, and Biology books I have seen are far, far more conceptually challenging than what we present to CS and engineering students in the area of programming.

I think the ultimate aim is to make programming more of an engineering discipline, more mathematical or scientific; "craft" and "art" are both needed, but there ought to be a scientifically based core on which people can base their craft and art. Software design and implementation is more than a craft; there is more math, science, and engineering to know and apply than is customary for fields we call "crafts." Incidentally, I find it appalling that you can become a programmer with less training than it takes to become a plumber.
+ -
story

Related Stories

This discussion has been archived. No new comments can be posted.
The Fine Print: The following comments are owned by whoever posted them. We are not responsible for them in any way.
 Full
 Abbreviated
 Hidden
More
Loading... please wait.
  • by Culture20 (968837) on Tuesday December 09 2008, @05:48PM (#26052743)
    I am _not_ fat.
  • A direct link... (Score:5, Informative)

    by tcopeland (32225) <[tom] [at] [infoether.com]> on Tuesday December 09 2008, @05:49PM (#26052751) Homepage

    ..is here [earthweb.com].

  • Careful (Score:5, Funny)

    by cjfs (1253208) on Tuesday December 09 2008, @05:52PM (#26052799) Homepage Journal

    The sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again

    Be careful. They're easily frightened, but they'll soon be back, and in greater numbers.

  • Back To Reality (Score:5, Interesting)

    by MightyMartian (840721) on Tuesday December 09 2008, @05:54PM (#26052821) Journal

    This is all well and good, and there's no doubt that an engineering/logical approach is very important in programming, but there is something of an art about development as well. I can slog all day coding away, working from diagrams, notes and even flowcharts (though not formalized ones, I'll admit, like days gone by), but sometimes my best and most productive work are those creative flashes I get, when any kind of formal process is tossed out the door. Sure, I have to go back later and comment the code so that even I can understand it, but there will always be that creative aspect to programming, and that ain't necessarily bad.

    • Re:Back To Reality (Score:5, Insightful)

      by pm_rat_poison (1295589) on Tuesday December 09 2008, @06:18PM (#26053131)
      Yeah, but what Stroustrup is trying to say is that the formal process has to be taught, so that the latter process can work more efficiently. Now matter how much of a flash of insight I get, I'll never even code Hello World if I don't know how to program properly.
    • Re:Back To Reality (Score:5, Interesting)

      by moderatorrater (1095745) on Tuesday December 09 2008, @06:27PM (#26053231)
      I don't think he's arguing against that at all. What he seems to be saying is that programming isn't taught, computer science is, and it's not rooted enough in the practicalities of programming. Style isn't enforced or even talked about all that much. He cites examples of student projects where they sprinkle magic constants throughout because they were never taught otherwise. In my CS courses the labs came every week, dealt with very small, specific problems and then were never looked at again. If Stroustrup had his way, it sounds like there would be style guides for the students (that were actually enforced), bigger projects and maybe some troubleshooting (ie give them 10,000 lines of code and make them find the problem). In other words, there would be things that everyone does on a daily basis as a programmer but were never really taught in school.
      • Re:Back To Reality (Score:5, Interesting)

        by lgw (121541) on Tuesday December 09 2008, @08:30PM (#26054355) Journal

        I'd say, more specifically, that there's a real and serious problem today with CompSci grads who (a) don't know what pointers are, and (b) have never seen a Windows development environment.

        So many schools these days do *evrything* in Java, except for some "survey of languages" class. Pointers and recursion are the two fundamental aspects of CompSci that are hard to get your head around the first time. Almost everything else I can teach a bright young intern, but if he doesn't "get" pointers it's not worth trying to teach. Internships are short, and it usually takes *weeks* to become comfortable with pointers.

        Is a 1-semester course in C++ programming too much to ask? Familiarity with the string, vector, and map classes is another hurdle that a student should really jump while in school. Sure, a lot of concepts are language-independent, but there is more than Java in use out here, and if you haven't done C, C++, and Lisp/Scheme, you might be missing some of those basic concepts.

        And it's really a pain to mentor an inter who clearly has never spent much time on a Windows box, and has neve used Visual Studio. Java programming on a Unix system is nice and all, but there are a great many Windows shops out here in the Real World. Even a 1-semester "survey"-style course that forced students to use Windows and Visual Studio would get them over that hurdle.

        I'm not going to refuse to hire a junior programmer just because he hasn't had Windows experience, but when a new hire can't debug, or even build a program using Visual Studio, or in some cases doesn't even know how to copy/paste a file, they've been dreadfully underprepared for the real world.

        • Re:Back To Reality (Score:5, Insightful)

          by Chandon Seldon (43083) on Tuesday December 09 2008, @10:40PM (#26055235) Homepage

          have never seen a Windows development environment.

          University isn't vocational training, and it certainly isn't vocational training for the specific tool set that you happen to use. If you mean that it would be reasonable to offer a Windows programming elective, great. But mandating a class in operating Visual Studio makes about as much sense as mandating a course in Ruby on Rails or the iPhone SDK.

    • Re:Back To Reality (Score:5, Insightful)

      by amirulbahr (1216502) on Tuesday December 09 2008, @06:51PM (#26053471)
      This is all well and good, and there's no doubt that an engineering/logical approach is very important in engineering, but there is something of an art about engineering as well. I can slog all day designing/building/coding/prototyping away, working from diagrams, notes and even flowcharts (though not formalized ones, I'll admit, like days gone by), but sometimes my best and most productive work are those creative flashes I get, when any kind of formal process is tossed out the door. Sure, I have to go back later and document my work so that even I can understand it, but there will always be that creative aspect to engineering, and that ain't necessarily bad.
    • Re:Back To Reality (Score:4, Insightful)

      by Anonymous Coward on Tuesday December 09 2008, @06:56PM (#26053551)

      What is it exactly that you think an engineering approach actually is? Some sort of formulaic fill in the blank? Engineering is coming up with ways to apply tools (physics, chemistry, math) to solve problems. Engineering curriculums teach engineers to think in such a way that they can do so. Any good engineering is an art form.

    • Re:Back To Reality (Score:4, Interesting)

      by Jeff DeMaagd (2015) on Tuesday December 09 2008, @06:58PM (#26053569) Homepage Journal

      I can't help but think maybe your impression of engineering is a little off.

      The practice of computer science / development and various fields of engineering are very similar in many ways.

      There is or can be an art or even zen to engineering work too. There is plenty of room for creativity that the stereotype or public impression doesn't even hint at.

  • Dreaming... (Score:4, Interesting)

    by Anonymous Coward on Tuesday December 09 2008, @05:55PM (#26052835)

    ... the man is dreaming IMHO. If you look at modern computer languages, hardware design, and operating systems, NO ONE is doing good engineering. It took forever (a decade or more at least) to handle crashes in a microsoft OS which had thousands of talented people working on it. The companies that complain about the lack of "good" developers are the ones paying their developers crap and looking to offshore/cut costs. If you want good developers you're going to have to pay them.

    The modern commercial environment for developers is not conducive to fostering great teams, since the all mighty buck reigns and stupid decisions are made.

    From an engineering standpoint: There is no reason for software to break, and yet it does, a lot of the time. To use a familiar example: We see this all the time with video games on the PC, hardware requirements, etc, etc.

    • Re:Dreaming... (Score:5, Insightful)

      by moderatorrater (1095745) on Tuesday December 09 2008, @06:54PM (#26053511)

      The companies that complain about the lack of "good" developers are the ones paying their developers crap and looking to offshore/cut costs. If you want good developers you're going to have to pay them.

      I work at a company that pays at least 10% more than the going rate at other companies in the state and interviews 2-3 / week. It takes 3 weeks on average to find a developer they're willing to make an offer to. Two of the companies that are complaining are Google and Microsoft, both of whom give good salaries and great benefits when compared with the average job.

      I've worked at several companies that paid decent amounts of money, and between 50% and 75% of the developers are crap. In my experience, good developers are hard to find at any price.

      • Re:Dreaming... (Score:5, Insightful)

        by demachina (71715) on Wednesday December 10 2008, @01:21AM (#26056295)

        There is a reason the programmer stereotype is the geek with poor social skills, because most bright people with strong social skills are going to quickly jump to the business side of the company where they can make more money and climb faster. Its a form of natural selection.

        Developing software is really not that great a career, when compared to the other modern careers in business(though its obviously better than factory worker and ditch digger). It does draw some good people who enjoy developing software or maybe don't have the temperament for other professions(translation: geeks who would suck at business, marketing, law and medicine). There are some geeks that score big in software which are the exception to the rule but that happens at about the same frequency as people scoring big in professional sports or acting at least since the dot com bubble burst.

        Problem #1, software development isn't a career path that will last you until retirement or if it does the entire second half of your career will suck. In most companies programming is a career for 20 somethings, maybe 30 somethings, 40 somethings if you stretch it. You better hope you land hit on a lucrative startup in your prime so you can get your FU money and retire young. Once you hit your 40's and 50's you are either going to be forced to switch to self employment or to management otherwise your career advancement is going level off and you hope it doesn't start going down. Fifty and sixty year old programmers are something of an oddity and usually discriminated against because the stereotype is you need to be young to be a programmer. The exception is maybe if you have a PhD and can jump to research. Jumping to management or self employment mid career is fine for some people but it requires a radically different skill set and temperament to manage people, business, customers, budgets and schedules and not code. A lot of coders wont succeed in the transition.

        Problem #2, most programming jobs don't really pay that well though again its better than factory work :) You will need to be a superstar and create products that you own and control or you aren't going to make big money. If you are a programmer stuck in a large organization the executives, marketing people and salesmen are going to be the ones getting rich and climbing fast. There is a reason so many climbers seek MBA's, even if its dubious MBA's have real value in the world (especially after witnessing the recent meltdown induced largely by MBA's, George W. Bush included in that number).

        As a programmer will probably do OK money wise, but you will probable have an opportunity to work long hours on tough projects, and do some painful death marches to get products out the door. If the product fails then you hope you survive the layoffs that ensue. If it succeeds you discover the people above you in the food chain have taken most of the profits, and throw crumbs to the programmers unless they are superstars. If you are lucky you get a small raise or a few options(since options are accounted now they aren't as widely available as they used to be especially on the lower rungs of the food chain). You then just get to start over on the next product and repeat. It can easily be a treadmill to nowhere unless you get in to a high risk startup that succeeds. If you do you still have to work hard or get lucky to get a big piece of the action which requires some pretty serious social and business skills and a strong ability to watch your back, because everyone else in the startup is trying to get a bigger piece of the action too... probably at your expense.

        Its just a guess but most really bright people, especially ones with good social skills, are going to be smart enough to angle for the business side of the company because they know thats generally where the money is, especially these days, because CxO's and directors almost always rake in millions a year whether they succeeded or not. Most programmers will never see that kind of money.

    • Re:Dreaming... (Score:5, Insightful)

      by poot_rootbeer (188613) on Tuesday December 09 2008, @07:12PM (#26053713)

      From an engineering standpoint: There is no reason for software to break, and yet it does, a lot of the time.

      Nonsense. Software, like any other engineered system, will break when subjected to forces in excess of what it was designed to tolerate.

      Would you argue that a building must NEVER fall down? I hope not.

  • by Lumpy (12016) on Tuesday December 09 2008, @05:55PM (#26052837) Homepage

    Unless you finish that sentence..

    Companies are not happy with the fresh coders because the good ones wont accept the low salaries they offer.

    Sorry but Programming is HARD. you gotta pay a lot for a good programmer. That will not change.

    I am sick of corporations and companies making up this raging BS story about a lack of candidates. RAISE YOUR SALARIES AND THOSE CANDIDATES WILL APPEAR.

    • by localman (111171) on Tuesday December 09 2008, @06:19PM (#26053141) Homepage

      I've never known this to be the case. When I managed developers, I paid market rates which I am sure you would say are low. I never had a single offer turned down for salary considerations. I had a range of programmers from good to excellent. Expectation of higher salaries was not correlated with skills or performance at all.

      You are right: programming _is_ hard. But salary is only useful as a motivator up to a point. Beyond that, what good programmers want is respect, appreciation, and freedom to do great things. They want to work on stuff that they feel good about. They also want to work with other smart people who they can learn from and build great stuff with. Those are decent starting points anyway.

      So your general idea is right: that complaining companies are full of it, but I don't think it's because of money. It's because they have lousy uninspiring development environments.

      Cheers.

      • by scamper_22 (1073470) on Tuesday December 09 2008, @07:42PM (#26053985)

        I agree with you. However, there are also several issues that I think need to be addressed.

        1. Training. My bother left engineering and went into law. He found it 1000x more professional. For one thing, as he joined, he was assigned a mentor and received proper training. Contrast this to many software companies where managers/other developers actually think 'throw them in the fire' is the best way to train. He's in patent law by the way... making about 3x more than the people doing the inventing :P It's genius actually. In this sense, the suggestion of apprenticeship is a great one.

        2. Quality of People. I don't think the top kids in a high school graduating class are going into computer science/engineering anymore. They have learned it is not a good field to be in. At the end, you're most likely going to end up a regular job that pays above average. With the kind of talent it takes to be a good software developer, you're much better doing something else (Doctor, nurse, CA, lawyer...) So naturally the grads are not going to be 'as good.'

        3. No professional organization. This is a huge one. To the outside world, no one knows what a good software developer does. Just as most of us know nothing of what makes a good lawyer. We treat lawyers like a black box. Here's what I need done... now go. This is how businesses treat software. It is professional organizations that mantain the quality of people. They take care of ensuring people are trained properly and things work as follows. You don't need to know anything about accounting. However, if you're a business and need some complex accounting done, you get a CA not just some guy with a few accounting degrees. It is also why most professional organizations employ themselves. CAs join firms like PWC, KPMG... Lawyers do their own thing. Software developers work for a business. Which yes... makes you just another worker bee.

        But anywhose. I don't the situation improving much in North America at least. Worst of all, all the new investment in new grads is being done in India/China. So it's not like young people in Western Companies are getting the grooming they need. It's a viscious cycle that is only going to make it worse.

  • Good point (Score:4, Insightful)

    by some_guy_88 (1306769) on Tuesday December 09 2008, @05:55PM (#26052843) Homepage
    I think he has a good point. One we already knew, but good none the less. I have just completed two years of a Software Engineering degree and it really was an easy two years with nothing all that challenging presented. I have friends getting good marks which really aren't that good (hope you guys aren't reading..) Software Engineering has apparently been said to be the hardest form of Engineering around because it's so hard to wright a program of significant size which is bug free. If structural engineers building bridges had as many bugs in their work as software engineers have in theirs, the world would be a very unsafe place.
      • by JaredOfEuropa (526365) on Tuesday December 09 2008, @06:09PM (#26053015) Journal
        Indeed. Besides, the whole "building vs. programming" analogy is silly. If designing buildings was like programming, architects would have to deal with all new materials every few months (can't use the old ones), they'd have customers insisting that walls are best placed leaning 10 degrees out of true, and the foundation under the building would (magically) be changed every few years, with the building having to remain upright on whatever it was standing on. And if the construction crews put a doorknop on wrong, the whole building might come crashing down when someone opened the wrong window.
  • by Aussie (10167) on Tuesday December 09 2008, @05:56PM (#26052853) Journal

    The sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again.

    But RMS isn't going anywhere !

  • Lies!! (Score:5, Funny)

    by ookabooka (731013) on Tuesday December 09 2008, @05:58PM (#26052877)

    The sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again.

    While probably safe for work, I don't actually want anyone to see this, but I found one! [king-mag.com]

  • by Anonymous Coward on Tuesday December 09 2008, @06:00PM (#26052899)

    Bjarne Stroustrup, creator of C++ [...] weighs in on [...] Java (there's too much of it)

    Oh, gee, now THAT is a surprise!

  • by tristanreid (182859) on Tuesday December 09 2008, @06:03PM (#26052937)

    I know about extreme programming, and I've really enjoyed some team programming sessions, but when it comes down to it, I think one reason some people hold a much deeper level of knowledge than their peers is that they spend extreme amounts of time alone.

    Some people:
    --get really good at coding
    --get really good at math
    --get really good at video games
    --read large numbers of books
    and finally some people watch a lot of television

    The people who read a lot of books sometimes gain a better understanding of other people, the people who watch a lot of TV have an increased repertoire of small talk, and in today's world, video games are increasingly a team sport. All of those things facilitate increased human contact.

    People who are fascinated with math and coding tend to have fewer peers who can understand what they are doing. Is this a bad thing? I don't think so. Maybe I grew up as more of an introvert in some regards, but in other ways I'm socially adjusted. I guess the challenge is to guide young people to seek out their peers (those who are fascinated with the same things), and to make friends without making everything into a competition. It's hard for young nerdlings to recognize a peer intellect without wanting to prove themselves better. There is a place for ambition, but that instinct can be a hinderance.

    My two cents,

    -t.

    • by Shados (741919) on Tuesday December 09 2008, @06:09PM (#26053009)

      Coding can be a hobby, in which case sure, you can do it alone (though for significant project, it gets rough, with all of the cross cutting concerns... someone who's extremely good at algorythms may totally suck at designing a public API... fairly common in CS-heavy companies that do a lot of backend stuff).

      I'm guessing though, they were referring to coding in the real world (for a living), in which case, for anything significant (no, the ecommerce website someone makes as a freelance isn't significant), you'll need to be a good teamplayer. People who are good at making functional GUIs often suck at backend programming, and vice sera. People good in architectures often miss the details. Computer scientists often cannot understand project managers and architects. Thus, it becomes a team sport (like you'd have goalers, offense, defense, etc). Being able to work as part of that team is almost as possible (sometimes moreso) than just being good at your specialty.

    • by Americano (920576) on Tuesday December 09 2008, @06:38PM (#26053341)

      Some people: --get really good at coding --get really good at math --get really good at video games --read large numbers of books and finally some people watch a lot of television

      The problem is, you're lumping all development into some generic activity called "coding." That ignores the simple fact that being an expert in C++ does not make you expert at UI design. Being an expert at UI design doesn't make you a SQL whiz. Being a SQL whiz does not make you an expert at designing flexible & scalable application systems with many moving parts.

      See the pattern? To make any practically-useful system today, you MUST work with other people who are expert in areas you're very likely not an expert in. You can create the best data model in existence for your company's payroll system, but if you don't have a clear understanding of the business rules, a good architecture, and a solid UI (and I've seen very few people in software engineering who are experts at all of the pieces that go into creating a good piece of software), the resulting product will be an unusable piece of crap that doesn't meet requirements.

      Stroustrop's point of the single genius programmer is valid. The model you describe supposes that a single person can possibly learn and be expert in all of the disparate knowledge areas that are required to make a working piece of software, and in any group, the people who are capable of that level of insight & knowledge will *always* be the statistical outliers. Instead of punishing the majority of people for not being born with genius-level intellect, teach them how to be good at their chosen area of expertise, and how to relate to the people they have to work with to get things done. You don't have to engage in XP or some other "pair programming" methodology to realize value from being able to communicate clearly and work with your architect, QA / Reliability engineers, your customers, your project manager, and other developers who are working on separate subsystems.

    • by MagikSlinger (259969) on Tuesday December 09 2008, @07:20PM (#26053779) Homepage Journal

      I know about extreme programming, and I've really enjoyed some team programming sessions, but when it comes down to it, I think one reason some people hold a much deeper level of knowledge than their peers is that they spend extreme amounts of time alone.

      ...

      People who are fascinated with math and coding tend to have fewer peers who can understand what they are doing. Is this a bad thing? ... I guess the challenge is to guide young people to seek out their peers (those who are fascinated with the same things), and to make friends without making everything into a competition. ... There is a place for ambition, but that instinct can be a hinderance.

      I think you've misunderstood was Bjarne was talking about. Most software projects have a dozen or more developers requiring close collaboration and the ability to cope with egos and positive/negative emotions. Also, just the ability to communicate your information to someone who needs it. Damn straight modern programming is a team sport! Are you working on tiny apps in a small closet hidden somewhere inside a small company? 'Cause for the rest of us, our day is filled with interacting with people. I'm very introverted, but I do need social skills to deal with the people I work with every day -- which causes me extra stress, but I digress. Software development in big companies and FOSS projects is a team effort, and for successful projects, the humans working on those teams need to work together smoothly.

      Eventually, you start talking about what Bjarne was talking about at AT&T: social skills doesn't mean your hosting dinner parties and chatting up girls. It means being able to share and communicate your idea to another very smart person, and then being able to listen and learn from that other very smart person. I think you shifted into that point at the end of your post: the idea that introverted smart people need to find other smart people they can talk with.

      Social skills in this context doesn't mean being the life of the party or tossing a football with non-geeks. Social skills means being able to tell the prima donna that his code has a bug in it. It means being able to explain to others why a design or architecture is bad. It's coping with hurt feelings: yours and theirs. The basic social skills of working in a modern business environment.

      Programming has evolved waaaay beyond the lone programmer in his little corner office working his own hours. A programmer is expected to talk to end users and tease out their real requirements; it requires them to be able to stand up and argue for something in a room full of managers; it requires having the ability to tell another programmer his coding style is awful, but you want to help him to get better.

      That's what Bjarne meant by social skills and team programming.

  • Ha! (Score:5, Funny)

    by isaac338 (705434) on Tuesday December 09 2008, @06:04PM (#26052945)

    The sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again.

    As a pizza delivery driver, I have to take exception to this. I see all kinds of folks but one guy in particular stands out. He always orders at least a large pizza and two lasagnas, usually with 2 or 3 2L bottles of pop and a couple (or three!) slices of cheesecake.

    He weighs a good 400lbs, has 3 monitors and a laptop on the go at all times (one monitor for CSI or whatever show, one for a terminal, one for IM), with WoW on the go on the laptop. His desk has a path cleared to it amongst piles and piles of garbage - empty pizza boxes, empty takeout containers, half-eaten food..

    Such a sight to behold.

    So no, they're not extinct.

  • he sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again.

    But, where then would Slashdot get its readers?

  • Conflicting goals (Score:5, Insightful)

    by internerdj (1319281) on Tuesday December 09 2008, @06:10PM (#26053027)
    They can't produce quality products as cheaply, as reliably, and as quickly as they would like...
    I think the ultimate aim is to make programming more of an engineering discipline, more mathematical or scientific; "craft" and "art" are both needed, but there ought to be a scientifically based core on which people can base their craft and art.


    We all know that we get to choose two of the three, problem is companies want all three without any consessions.
    Also, imposing rigor on software design increases time and in certain situations cost, while increasing reliability. While we are definitely heading in the right direction as a field; there is a long way to go before we ever get to any kind of discipline that is both as rigorous as other science or engineering disciplines and usable on the scale that people currently expect software to be at. Real customers by and large can't (although some cases won't) pay for rigorous development. Hell, the mentality has been creeping into consumer electronics as long as I've been alive. The current market drives us towards fast and cheap and only towards reliable if the customer is pissed.
  • What they generally don't see is that inserting a good developer into a culture designed to constrain semi-skilled programmers from doing harm is pointless because the rules/culture will constrain the new developer from doing anything significantly new and better.

    I almost stood up and cheered when I read this, until I realized that nobody who can change things is reading, and besides I would have disturbed the other cubicle rats.

  • The article starts off by claiming Stroustrup created C++. Fair enough, but then, in the same paragraph, the author claims that C++ is used in "google search" and the iphone. Doesn't the iphone platform stress objective-C ( like all current Apple platforms )? Objective-C != C++. It could be a minor thing since I dont do either, I am just saying something, maybe. Maybe like he does not know his subject matter, or assumes his readers do not.

    The rest of the article was mostly about the Stroustrup history, not what he said in the presentation. Its almost like the author cherry picked a few damning things his subject said in a presentation totaling ~42 words and then gave it a provocative title, and a bunch of interpretation.
    Like I give a shit what the author thinks.

    NOTE: I would apologize for the way my brain works but I am held captive by it. Its not my fault. I think.

  • by CrazyJim1 (809850) on Tuesday December 09 2008, @06:44PM (#26053405) Journal
    Bad programmers are why companies don't take a chance on good programmers. Many good programmers can't get a job because the HR department thinks you actually need experience in a specific set of software in order to be good at the job. Good programmers know they can pick up most any language and get cracking within a week or so. For me its:"Yeah I've coded since I've been able to type so over 10 years of basic followed by over 10 years of C/C++. A Carnegie Mellon degree in Scientific Computing. No experience, but I have coded several large projects at home." I applied to thousands of jobs on job boards, and I never cracked into the industry.
  • by Animats (122034) on Tuesday December 09 2008, @08:15PM (#26054249) Homepage

    It's amusing seeing Strostrup whining that schools are teaching Java instead of his C++. The problem with C++ is Strostrup. He's in denial about many of the fundamental problems of C++. He's publicly stated that there's nothing major wrong with C++. If that was the case, we wouldn't need Java and C#, which are, after all, attempts to improve on C++.

    Down at the bottom, the fundamental problem with C and C++ is the "pointer=array" concept. That was OK for 1978, but it didn't scale well. It's the cause of most of the buffer overflows in the world. C and C++ don't even have syntax for properly talking about the size of an array parameter. That's just broken. C and C++ need something like conformant array syntax for parameters and in other contexts where one needs to talk about the size of an array.

    The second fundamental problem with C and C++ is that the programmer must obsess on "who owns what", and the language not only doesn't provide help with this, it doesn't even have syntax for talking about it. There's no distinction between a pointer that "owns" an object and one that just "uses" it. Yet if the programmer doesn't carefully make that distinction, the program will have either memory leaks or dangling pointers.

    The trend in C++, since templates went in, is to try to wallpaper over the problems with the underlying model. It never quite works; the mold always seeps through the wallpaper. Container classes almost, but not quite, succeed at encapsulation. There's almost always some place where a raw pointer has to be allowed to leak out. The standards committee has gone off on a "generic programming" tangent, with emphasis on weird template features used by few and used correctly by fewer. Just because you can abuse the C++ template system as a term-rewriting engine doesn't mean you should do that in production code. This results in a whole new class of incredibly obscure compile-time bugs. The standards committee has been thrashing for over a decade in this area; in the 1990s, the new version was to be "C++9x"; now it's "C++0x", and since we're close to 2009 already, "C++1x" looks like the reality.

    C++ is the only major language to have hiding ("abstraction") without memory safety. No previous language had it, and no later language repeats that mistake.

    Back around 2001, I made an effort [animats.com] to do something about it, but the political hassle was more than I had time for.

  • by FoboldFKY (785255) on Tuesday December 09 2008, @08:35PM (#26054379)

    The sloppy fat geek computer genius semi-buried in a pile of pizza boxes and cola cans is a mythical creature, best buried deep, never to be seen again.

    Oh yeah?! Well, I don't believe in you, either!

  • Too damn bad.... (Score:5, Insightful)

    by stonewolf (234392) on Tuesday December 09 2008, @08:55PM (#26054505) Homepage

    That the companies that are complaining about the poor training that new students are getting are not willing to hire older programmers who got exactly the kind training Bjarne is pushing for. Yeah, got exactly what he wants to put back into schools today, then we have tested it and developed it over decades of developing and shipping products. And there are hundreds of thousands of us out of work in the US.

    I've taught programming classes and have had the experience of having companies call asking for the names of students who did well in my classes. I have also had the experience of trying to apply for those jobs. I have told the companies that I will work for an entry level salary and since they trust me to do the training and evaluation of the students you would think was qualified...

    The best response was to be ignored, the worst was being laughed at.

    Fuck 'em all,

    Stonewolf

  • Such a tool... (Score:5, Insightful)

    by javabandit (464204) on Wednesday December 10 2008, @12:35AM (#26055989)

    I have to say after reading this article -- Stroustrup is a tool. It is just that simple. Nothing more than a pundit at this point. He had a stroke of genius in programming and now is an expert in everything related to programming.

    He thinks companies aren't happy with their graduates? Well, I say companies have terrible hiring practices, terrible mentorship programs, and ridiculous expectations.

    Balance the theoretical and the practical? Wow. Brilliant observation. Great, Bjarne. Please give us more sweeping Karate-Kid style one-liners.

    High schools should teach students to work hard? Great, Bjarne. Thanks again for that. Search out information as needed? Another stroke of brilliance. Express ideas in writing and verbally? WOW. PINCH ME. Such genius can only be dreamed of.

    Then, the article closes with him trying to be edgy and go out "with a bang". Sloppy, fat geeks. Nice. This guy is a douchebag. Pure and simple.

    Here is my own contribution to douchbaggery... I think we should take aging, isolated, self-important pundits out into a remote area and bury them neck deep in the dirt.

    • by truthsearch (249536) on Tuesday December 09 2008, @06:08PM (#26052989) Homepage Journal

      Someone can learn the basics of a lot of programming languages, but not know the fundamentals well. What a university should provide is a solid foundation. My education included chip design, compiler design, assembler, and other low-level topics that I never use on a daily basis. But studying them at the university level definitely makes me a better programmer.

        • by phyreskull (1275388) on Tuesday December 09 2008, @06:26PM (#26053223) Homepage

          Most of these topics can easily be researched and learned without a university.

          Yes, they can be researched - but, let's face it: most people either think it's beyond them, think they'll never need to know it, or are just too lazy. The ones who would research it themselves are likely to be the ones who are good anyway.

    • by internerdj (1319281) on Tuesday December 09 2008, @06:17PM (#26053115)
      First Stroustrup complains Java is a major ill of CS curiculum, and then Sun says that Java solves all the problems of people who have C++ implementations. And for my next feat I will find an article with the Democrats blaming Bush for something. :-\
      • by Culture20 (968837) on Tuesday December 09 2008, @06:26PM (#26053221)

        /pedant
        Quotes is a verb. I'm sure you meant to say "Read on for more choice quotations from the quotable professor."

        /unpedant
        Quote is also a noun. I'm sure you meant to say, "Read on for more choice quotes from the professor."

        /gollum
        Quoteses is also a plural noun. We're sure hobbitses meant to say, "Rrread... ON! for more choice quoteses... fromtheprofessor. My precious."

    • by east coast (590680) on Tuesday December 09 2008, @07:02PM (#26053609)
      Lack of funding? Young man, I learned Pascal on a TRS-80 Model II. The cellphone that is likely in your pocket is probably more powerful in just about every aspect. The book we learned from was probably close to a decade old at the time and was sad in the shadow of what you can get at Borders for 25 bucks. I learned programming just fine.

      You don't need the latest and greatest to learn how to code. Infact, the more I see of computers and teenagers the more I think I had it better being limited to machines that didn't have a 1/10th of a meg of RAM and no Internet. Today there are just far too many distractions on a PC to get kids away from the task at hand. To be honest, if I were teaching coding I would go with the 2004 text about whatever language that normally can be found in the bargin bin for 5 bucks, a bunch of P-II 350s, a 10 dollar flash drive for each student and whatever freeware IDE I could find for the chosen language. No other software on the PC and no network connections either, thankyouverymuch.

      This would keep the students mind on the task in front of him. When I first got my Vic 20 with no media storage and no game cartridges I had to sit down and learn how to make the machine do what I want it to. I found that it was a very gratifying thing to do. If I would have had MySpace and EverQuest I doubt I would have ever have gotten as far.

      BTW: Get off my lawn!
    • by andhow (1128023) on Tuesday December 09 2008, @07:39PM (#26053953)

      I know it can still be used that way, but it seems to be more and more difficult to only code that way using C++, because you're going to have to use libraries at some point or another.

      Yeah, those damned templated libraries with their: performance [stanford.edu], type safety [psu.edu], design patterns [wikipedia.org], generic programming principles [stepanovpapers.com]. I can't imagine why Java wasn't happy with containers of Objects and added Generics. C# definitely shouldn't have followed suit. All you need is void*, size_t, and int (*)(void *, void *), right?