Saurav Banerjee On 'DMR'

DENNIS RITCHIE :BELL LABS:

DENNIS RITCHIE :BELL LABS:
The author of the C programming language. (Image taken during the 1990 UKUUG Summer Conference, London.)
________________________________________
Kernighan & Ritchie: The C Programming Language, Second Edition (errata)
From: http://www.lysator.liu.se/c/c-errata.html#dmr
Mark Brader on B ,also in 1969, the system that Brian Kernighan would later name Unix was being developed by Ken Thompson "with some assistance from" Dennis Ritchie.
Tom Duff on Duff's Device.
Dennis Ritchie: BCPL to B to C
From: dmr@alice.att.com (Dennis Ritchie)
Brian W. Kernighan (1974): Programming in C: A Tutorial
Although it has lost little of its didactic value, it describes a language that C compilers today do no longer understand: the C of 1974, four years before Kernighan and Ritchie published the first edition of ``The C Programming Language''.
The ANSI C Rationale
The vast majority of the language defined by the Standard is precisely the same as is defined in Appendix A of The C Programming Language by Brian Kernighan and Dennis Ritchie, and as is implemented in almost all C translators.

Top Websites and Resources for Developers

Top Websites and Resources for Developers
Open Source
• Sourceforge.net - THE Open Source repository with over 100,000 projects.
• Code.Google.com - Pushing the Open Source movement forward.
• Gnu.org - Pioneering the Free Software Movement for nearly 25 years.
• MySQL.com - The most popular Open Source database.
Code Search Engines
These websites let you search through code.
• Koders.com - The Open Source search Engine.
• Google Code Search - The web's biggest search engine.
• Krugle.com - Searching 2.5 Billions lines of code.
• csourcesearch.net A search engine for C and C++ code.
Top Websites for C++ Programming
• Boost.org - The place to go after you've learnt the STL.
• Bjarne Stroustrup's Website - He invented C++.
• Mindview.net - Home to Bruce Eckel, Famous for "Thinking in C++" and other books.
Top Websites for C# Programming
• CodeProject.com - Speaks for itself!
• MSDN List of C# Tools and Resources Even includes a link to Mono!
Top Websites for Linux Programming
• Freshmeat.net - The sourceforge of Linux.
Top Websites for Windows Programming
• Msdn.com - If you develop for Windows, this is the place to start.
Miscellaneous
• bug.gd - Search for errors and report how you fixed them to help others.
• Tiobe Community Programming Index Tracking the popularity of Programming Languages.

List of Free C Compilers

If you're interested in learning to program in C you'll find this list of C Compilers handy. Most of these compilers do C++ and C. Just rename the files to have .C extensions.
• Microsoft Visual C++ 2008 Express. Not everyone likes Microsoft but there's no denying that they do provide very good code with an excellent IDE. It needs .NET though you can compile for win 32 (but no MFC). We've already produced Instructions on downloading and installing it. it requires free registration.
• Linkfrm. This is more of a computer science project developed at the IPD at the Universität Karlsruhe to improve the quality of software with visualization of of program structures. It includes cparser, a C compiler, which can parse C89 and C99 as well as many GCC and some MSVC extensions. The handled GCC extensions include __attribute__, inline assembler, computed goto and statement expressions. See this post for more about the project.
• Turbo Explorer for C++. Originally Borland then Codegear and now Embarcadero, this is a fast and poewerful C++ (which includes C like Microsoft's does). Also like Microsoft's compiler it requires free registration. It includes a great IDE, a great debugger features, Code Insight, templates, and easy database explorer and connectivity. There is support for databases as well. This needs Windows.
• Open Watcom. Getting a bit long in the tooth and the IDE isn't great but runs on Windows 2000 (probably 98) as well as newer Windows.
• GCC. The classic open source C compiler for Linux and many other operating systems (and Windows under Cygwin or Ming). A project that has been around forever. Excellent open source quality software. It doesn't come with an IDE (which are generally platform dependent) but there are loads out there eg MonoDevelop on Linux.
• Digital Mars C/C++ Compiler. Their IDE costs ($42.55) but the Basic C/C++ Win 32 compiler is free. You should also download the free STLPort as well as it contains the standard library including . You'd probably also find the free STLSoft and Garbage Collection downloads useful.
• Xcode. This is for Apple Macs and is their version of GCC but purely for Apple's own Mac OS Operating System. It has excellent documentation and SDKs for Mac and iPhone. If you have a Mac this is what you use.
• Tiny C - Compiler. TinyCC (aka TCC) is a small fast C compiler that is meant to be self-relying: you do not need an external assembler or linker because TCC does that for you. With the aid of another library it can be used as a backend code generator. TCC compiles so fast that even for big projects Makefiles may not be necessary.
• Portable C Compiler. This was developed from one of the earliest C Compilers and at the start of the 80s most c compilers were based on it. Portability was designed into it from the start in contrast to Dennis Ritchie's C compiler which was very hardware dependent. It's now being developed to be C99 compatible.
• Failsafe C. A Japanese project from the Research Team for Software Security at the Research Center for Information Security (RCIS), National Institute of Advanced Industrial Science and Technology (AIST), JAPAN, this version of C for Linux supports over 500 functions (not C99 or Widechar). It provides complete protection against memory block over-boundary accesses making it as safe as Java and C#.
• Pelles C is a free development kit for Windows and Windows Mobile containing an optimizing C compiler, a macro assembler, a linker, a resource compiler, a message compiler, a make utility and install builders for both Windows and Windows Mobile. It also has an IDE with project management, debugger, source code editor and resource editors for dialogs, menus, string tables, accelerator tables, bitmaps, icons, cursors, animated cursors, animation videos (AVI's without sound), versions and XP manifests.
• CC65 is an open source cross development package for 65(C)02 systems, including a powerful macro assembler, a C compiler, linker, librarian and several other tools. It includes support for Commodore C64, the GEOS operating system for the Commodore C64, the Commodore C128, the Commodore C16, C116 and Plus/4, the Commodore P500, the Commodore 600/700 family of computers, the Apple ][, the Atari 8bit machines, the Oric Atmos, the Nintendo Entertainment System (NES), the Supervision Game Console and the Atari Lynx Console

A List of Programming Contests and Challenges

There is a list of programming contests. Most are annual but some are continuous and you can enter at any time.Studying how others solved the problem can also be educational.Most important of all you can use C, C++ or C# in these.
http://www.ioccc.org/index.html

Annual Contests
• International Conference on Functional Programming (ICFP). This has been running for a decade and happens in June or July each year. Though it's based in Germany, anyone can enter using any programming language, from any location. It's free to enter and your team isn't limited by size.
• The BME International is an intense free to enter contest that takes place in Europe once a year for teams of three, and you have to bring your own computers and software. This year, the 7th took place in Budapest. This has had some interesting challenges in the past- how about driving a car over a virtual terrain? Other past tasks included controlling an oil-company, driving an assembly line robot and programming for secret communication. All programs were written in one 24 hour intense period!
• International Collegiate Programming Contest. One of the longest running- this started in 1970 at Texas A&M and has been run by the ACM since 1989 and has IBM's involvement since 1997. One of the bigger contests it has thousands of teams from universities and colleges competing locally, regionally and ultimately in the a world final. The contest pits teams of three university students against eight or more complex, real-world problems, with a gruelling five-hour deadline.
• The Obfuscated C contest has been running for nearly 20 years. This is done on the internet, with email submissions. All you have to do is write the most obscure or obfuscated Ansi C program in under 4096 characters length according to the rules. The 19th contest took place back in January/February 2007.
• The Loebner Prize is not a general programming contest but an AI challenge to enter a computer program that can do the Turing test, ie talk to a human sufficiently well to make the judges believe they are talking to a human. The Judge program, written in Perl will ask questions like "What time is it?", or "What is a hammer?" as well as comparisons and memory. The prize for the best entrant is $2,000 and a Gold Medal.

• Similar to the Loebner Prize is the Chatterbox Challenge. This is to write the best chatter bot- a web based (or downloadable) application written in any language that can carry on text conversations. If it has an animated display that syncs with text then that is even better- you get more points!

• International Problem Solving Contest (IPSC). This is more for fun, with teams of three entering via the web. There are 6 programming problems over a 5 hour period. Any programming language is allowed.

• The Rad Race - Competitors in teams of two have to complete a working business program using any language over two days. This is another contest where you have to bring along equipment, including a router, computer(s), cables, a printer etc. The next one will be in Hasselt, Belgium in October 2007.

• The ImagineCup - Students at school or college compete by writing software applicable to the set theme which for 2008 is "Imagine a world where technology enables a sustainable environment." Entries started August 25th 2007.

• ORTS Competition. ORTS (open real time strategy game) is a programming environment for studying real-time AI problems such as path-finding, dealing with imperfect information, scheduling, and planning in the domain of RTS games. These games are fast-paced and very popular. Using the ORTS software once every year there is a series of battles to see whose AI is best.

• Innovation Challenge. A new challenge that lets you create innovative apps on any platform ( e.g. client application, web-based application, Java application, Facebook App, iPhone App, Android etc in any programming language.

• Google AI Contest 2010. You can enter a C++ or C# Bot to play in a two-player Snake, where your objective is to box in your opponent and make him crash into a wall or his own tail before you do! It's based on the film Tron from the 1980s.
Continuous or Ongoing Contests
• Project Euler. This is an ongoing series of challenging mathematical/computer programming problems that will require more than just mathematical insights to solve. computationally the problems should be solvable in less than a minute. A typical problem is "Find the first ten digits of the sum of one-hundred 50-digit numbers."

• Sphere Online Judge. Run at Gdansk University of Technology in Poland, they have regular programming contests - with over 125 completed. Solutions are submitted to an automatic online judge that can deal with C, C++ and C# 1.0 and many other languages.

• Intel's Threading Programming Problems. Running from September 2007 until the end of September 2008 Intel have their own Programming Challenge with 12 programming tasks, one per month that can be solved by threading. You get awarded points for solving a problem, coding elegance, code execution timing, use of the Intel Threading Building Blocks and bonus points for posting in their problem set discussion forum. Any language but C++ is probably the preferred language.

• Codechef is India's first, non-commercial, multi-platform online coding competition, with monthly contests in more than 35 different programming languages including C, C++ and C#. Winners of each contest get prizes, peer recognition and an invitation to compete at the CodeChef Cup, an annual live event.

No prizes but you get fame!
http://cplus.about.com/od/glossary/a/ten-contests.htm

C - C++ - Programming URls

http://blogs.blackberry.com/

http://cplus.about.com/od/glossar1/Glossary_of_Programming_Terms.htm

http://www.preseps.com/shell-programming.html

www.codeguru.com



Videos on C ++

http://code.google.com/intl/ja/edu/languages/index.html



http://www.wlap.org/cern/lectures/tech/c/00/

http://www.wlap.org/cern/lectures/tech/c/00/

http://www.wlap.org/cern/lectures/tech/c/02

http://www.wlap.org/cern/lectures/tech/c/02b

http://www.wlap.org/cern/lectures/tech/c/03

http://www.wlap.org/cern/lectures/tech/c/04/

http://www.wlap.org/cern/lectures/tech/c/05b

http://www.wlap.org/cern/lectures/tech/c/06

http://www.wlap.org/cern/lectures/tech/c/06b

http://www.wlap.org/cern/lectures/tech/c/07

http://www.wlap.org/cern/lectures/tech/c/07b


more to come , so kindly keep visiting !

Saurav Banerjee ,Ranchi

C Language :

http://cyclone.thelanguage.org/wiki/Download
http://cyclone.thelanguage.org/wiki/User%20Manual
http://www.mhprofessional.com/downloads/products/0072226803/0072226803_ch01.pdf
http://www.exciton.cs.rice.edu/CppResources/syntax/AppendixA.pdf
http://upload.wikimedia.org/wikibooks/en/f/f8/C_programming.pdf
http://www.fujitsu.com/downloads/MICRO/fme/displaycontrollers/sm-api-rev1-30.pdf
http://ftp.sas.com/techsup/download/SASC/share5958-59/S5959v2.pdf
http://www.dei.isep.ipp.pt/~jsantos/Disciplinas/EstInf/Docs/cplusplus-tutorial.pdf
http://www.cs.uiowa.edu/~rus/Courses/SysSoft/tutorC.pdf
http://www.atmel.com/dyn/resources/Prod_documents/avr_3_04.pdf
http://www.ericlindsay.com/applix/ctutor.pdf
http://www2.research.att.com/~bs/crc.pdf
http://developer.apple.com/mac/library/documentation/Cocoa/Conceptual/ObjectiveC/ObjC.pdf
http://nrg.cs.ucl.ac.uk/mjh/3005/c-intro.pdf
http://www.fujitsu.com/downloads/MICRO/fme/displaycontrollers/sm-api-rev1-30.pdf
http://www.chris-lott.org/resources/cstyle/Peter_CStyleGuide.pdf
http://faculty.tp.devry.edu/~schen/technical/pic1618/MPLAB_IDE_Tutorial.pdf
http://www.literateprogramming.com/dssguide.pdf
http://www.intelitekdownloads.com/easyCPRO/tutorial.pdf
http://www.cgl.uwaterloo.ca/~wmcowan/teaching/cs349/w05/tutorials/s1.pdf
http://www.literateprogramming.com/ftsguide.pdf
http://www.swig.org/papers/PyTutorial98/PyTutorial98.pdf
http://www.openmp.org/mp-documents/cspec20.pdf
http://www.openmp.org/mp-documents/cspec20.pdf
http://www.4shared.com/file/156960502/a82488a2/01Introducing_C-C_Language_Video_Tutorials_.html/ on http://www.4shared.com/file/156961871/ce08bbe9/02First_Steps-C_Language_Video_Tutorials_.html/
http://www.4shared.com/file/156962444/8ee04a2f/03Types_-_Operators__Expressions-C_Language_Video_Tutorials_.html
http://www.4shared.com/file/156963016/a22c10ff/04Control_Flow-C_Language_Video_Tutorials_.html
http://www.4shared.com/file/156964129/85ab0c23/05Functions__Program_Structure-C_Language_Video_Tutorials_.html
http://www.4shared.com/file/156965141/659644f2/06Pointers__Arrays-C_Language_Video_Tutorials_.html

DENNIS RITCHIE

OBSD

DEVELOPING

MICROSOFT TEAM


THE MICROSOFT TEAM

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS"S CONTRIBUTIONS

DENNIS RITCHIE AND OTHERS

EXpert Opinions : by Dennis Ritchie, James Gosling and Bjaurn Stroustrup

The C Family of Languages:

The C family of languages--C, C++, and Java--has dominated commercial programming for over 30 years. Today, all three languages are at a turning point:
o The second ISO/ANSI C standard has just been published (C99 was officially released in December 1999). C continues to be one of the most influential languages in the world, particularly in the field of embedded systems.
o The first official update to the ISO/ANSI C++ standard will be completed in October 2000. C++ is one of the most widely used commercial programming languages in the world, with unparalleled support for both object-oriented and generic programming, and continues to experience steady growth.
o Java popularity continues to grow in various areas, from client-side to server-side programming. Sun has recently decided that Java can best flourish as a de facto standard, instead of as a formal ISO/ANSI or ECMA standard, and has abandoned formal standardization efforts.
What has made the C family of languages so dominant?


Q: Why has the C family of languages become so successful and so widely used?

The use of C, was during early times (meaning the '70s and much of the '80s) considerably encouraged by its use as the lingua franca of Unix during the period that Unix was growing in the research and academic community, and then when Unix was taken up as the software basis for the workstation industry of the '80s. There were also technical and semi-technical aspects: the language turned out to be well-placed both for describing things at a high enough level so that portability across hardware was feasible, but simple enough in its requirements to make it cheap to implement.
C and C++ became popular because they were flexible, cheap, and more efficient than alternatives. C++ owes much of its initial popularity to its high degree of compatibility with C.
It was very important success of C and C++ that AT&T didn't try to monopolize these languages, but allowed its researchers to support the creation of alternative implementations. Also, AT&T fully supported ANSI and ISO standardization of C and C++ as soon as these efforts started.
Java is a very different design from the other two languages and appears to have a very different philosophy.
Just to remind people: Both C and C++ were invented in the Computer Science Research Center of Bell Labs in Murray Hill and found their initial serious use within Bell Labs and AT&T.
Among technical factors, C and C++ benefited from their closeness to machine and absence of artificial restrictions on what can be expressed. That allows low-level systems work to be done in these languages and for the full performance of a machine to be delivered to its users. Java benefited from running in its own virtual machine and from coming with a large set of libraries that decrease the time needed for a programmer to become productive. Unix gave a similar boost to C. In contrast, the C++ world suffers from fragmentation of its huge base of libraries, many of which are proprietary and supplied by competing vendors.
C++ was a language where I could write programs that were as elegant as Simula programs, yet as efficient as C programs.
The object-oriented facilities from Simula helped with the former, and the systems-programming facilities of C with the latter.
Like C, Java's goals were really around being able to build relatively specific kinds of software.
For example, one of the differences between Java and C is that Java has real arrays and the arrays get bounds-checked, and that turns out to be important for both reliability and security. If you look at the history of security breaches on the Internet, some really large fraction of them are exploiting buffer overflows, statically allocated arrays that people just go over the end of. If you look at logs of bug-fixing that people go through, it ends up being that memory integrity issues are a huge fraction of where the problems come from.
C haven't changed much in many years, and I haven't been a central player in the changes in either the 1989 or 1999 standards.
C++ haven’t changed much, still good for serious systems programming -- including work at the machine level and on resource-constrained systems .
The major shift in emphasis/style comes from finally having templates and exceptions available.
where everything is flexible and everything is dynamic, and static languages like C, where everything is statically precompiled. Java is kind of in this netherworld in between them, and given the way the world has evolved to become even more networked than before, even more conscious of security issues.
Probably the oddest aspect of C compared with other languages outside its immediate family is the declaration syntax, in which (in a way coming from Fortran) a type is mentioned, then variables decorated in a way that reflects their use in expressions.
A closely related aspect is the treatment of arrays and pointers.
C and C++ communities benefit from a genuine degree of compatibility. Also, much of work on the non-abstraction areas of C++ has been fed back into Standard C. Examples are function declarations/prototypes, const (Dennis also had a hand in their design), declarations wherever statements can appear, and the // comments.
A lot of the design of interfaces was borrowed pretty straightforwardly from Objective C, and it's got some pluses and minuses and it was a real tough balancing act.


Q: Did you ever add features that your users didn't appreciate as much as you did, and then have to deprecate or remove them later? What did you learn from the experience?


Ritchie: I added some things under some pressure from users that I don't think were done well. Enumeration types are a bit odd, bitfields are odder. The "static" keyword is very strange, expressing both a storage lifetime and what the standard calls "linkage" (external visibility). There are many odd bits here and there.
I can't remember features I added that I had to remove except for some tiny bits, like the "entry" keyword. I clearly wish I could have done something about the C declaratory syntax.
In addition, Having had templates integral to the language early on would have helped many use C++ better.
Stroustrup: When I designed C with Classes and C++, I was very keen on the idea that a class defined the environment in which the code of its member functions operate (I still am). This led to the notion of constructors that establish that environment (invariant) and acquire the resources needed. Destructors reverse that process (releasing resources).
Based on that line of thinking, C with Classes also allowed you to define a call() function that was called before entry into a member function and a return() function that was called after exit from a member function. The call()/return() mechanism was meant to allow a programmer to manage resources needed for an individual member function invocation. This allowed me to implement monitors for the first task library. A task's call() grabbed a lock and its matching return() released the lock. The idea came partly from Lisp's :before and :after methods. However, the notion wasn't perfectly general -- for example, you couldn't access arguments for a member function call from call(). Worse, I completely failed to convince people of the usefulness of this notion, so I removed call() and return() when I defined C++.
I recently revisited this issue and I wrote a template -- in Standard C++ -- that wraps calls to an object by arbitrary prefix and suffix.

There are some things that I kind of feel torn about, like operator overloading. I left out operator overloading as a fairly personal choice because I had seen too many people abuse it in C++.

Q: In your experience, what are the most common mistakes developers make in [C/C++/Java]?

Ritchie: I don't really know the answer to this question. I would suppose that the low-level mistakes have to do with type errors, and especially with array subscript and pointer references
C itself does very little to help you here; you have to design a scheme.
Stroustrup: Using C++ just as if it was C or Smalltalk. That leads to seriously suboptimal C++. To use C++ well, you have to adopt some native C++ styles. These tend to be distinguished by small concrete classes and templates. A programming style that is overly influenced by C tends to use a lot of arrays, clever pointer manipulation, casts, and macros rather than standard library facilities (such as vectors, strings, and maps). A programming style that is overly influenced by Smalltalk tries to cram every class into a hierarchy and to overuse casts (and often macros). In either case, key abstractions tend to disappear in a mess of implementation details and people get themselves (unnecessarily) tied in knots with allocation, pointers, casts, and macros.
One common mistake that particularly annoys me is the use of complicated base classes with lots of data members as part of interfaces offered to application builders (users). Abstract base classes make much better interfaces to services. I have tried to root out such misuses for well over ten years: I added abstract classes in 1989 after failing to get the idea across without the support of an explicit language feature.


The idea is really simple:
class interface { // seen by users
// pure virtual functions
};
class my_implementation : public interface {
// data
// functions
// overriding functions
};
When user code sees only "interface," it is immune to changes to "my_implementation."
If common data structures or operations are needed for implementations they can be added in a base class that is visible only to implementers:
class common { // seen by implementers
// data
// functions
};
class my_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
class your_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
This is one of the simplest and most fundamental uses of multiple inheritance.
What many people need to get much more out of C++ is not new features, it is simply a more appropriate design and programming style.
Gosling: Probably the most pervasive mistake is not doing a tasteful job of object-oriented programming. There are these people who don't understand it at all, who just do some procedural kind of stuff and write their program as one huge class with a lot of methods in it; they try to do it in a C style. Then there are the people who go, "Ooo, objects! They're cool! Let's make gazillions of them!"

Q: In your experience, how long does it take for a novice programmer to become a reasonably proficient [C/C++/Java] developer ?

Ritchie: I don't know the answer to this question either--my stock joke on similar ones is, "Well, I never had to learn C...."
Stroustrup: That depends critically on the background of the novice, on the complexity of the task first attempted with C++, and on the teaching/learning approach.
For a novice programmer, a year and a half seems appropriate; for a programmer who is a novice to C++ and the techniques it supports half a year seems more likely.
I consider good libraries essential to provide a smooth learning curve and to properly sequence the learning of C++ concepts. For example, having the C++ standard library available makes it possible to learn the basic type, scope, and control structure concepts without having to deal with arrays, pointers, and memory management at the same time. Such fundamental, yet low-level concepts are best learned a bit later.
This is dangerous. In this context, it is a strength C++ (and of C) that the standard libraries usually are implemented in the language itself using only the facilities available to every programmer.
Gosling: The language itself tends to be a snap to learn; it's all the library stuff that takes the time, and there the best way to do it is to just start writing and using it, and when you need something, look for it.
C didn't come until later just because it's so easy to do goofy things in C; it's so easy to have an array and write "for( i = 1; i <= length; ... )" and you have to explain, "no, it's not less than or equal to length and it's not 1, it's 0 and it's less than." But of course your loop runs just fine, only maybe sometimes you'll discover that you smack the malloc header of the block immediately following the array and nobody's ever told you about that.
That's just so incredibly common in C and C++ or any language that doesn't have a really strict memory model.

Q: Are there any important features missing from the C family of languages? From [C/C++/Java]?

Stroustrup: In which sense do C, C++, and Java constitute a family of languages? C and C++ has a large common subset, and over the years serious efforts have been made to minimize the inevitable tendency of the two languages to drift apart because they are controlled by separate standards bodies. Java, however, provides no real compatibility, and similar syntactic constructs have semantics different from the C and C++ versions. Clearly, Java borrows from C and C++, but under the skin, the similarities to Modula-3 seem greater.
Undoubtedly, all three languages could be significantly improved by addition. However, I see little reason to believe that there is a single major feature that would help all three languages.
Gosling: One of the things that always bugged me about C was the weak memory model, the fact that you could cast a pointer to a character into a pointer to an integer; it just did weird things. But then you change that and it's not C any more, it's basically Java.
The other is type polymorphism, something like templates, and Java actually has something like a poor man's template system right now in that the type hierarchy has a common root for anything and everything, namely Object, but there's also a group working on doing a proper job of type polymorphism in Java. It turns out to be a really hard problem. Other issues are clearer: garbage collection is a good idea; goto is a bad idea.


Q: What things would you like to see become a part of [C/C++/Java] in the next 2-5 years? In the next 10 years? Why?

Ritchie: For C, the new 1999 standard exists but has not become readily available, and it has quite a few changes from the earlier one, though not revolutionary ones.
Stroustrup: I think that the emphasis for C++ evolution should be in library building.
Clearly, many people worry about concurrency and about interfaces to various systems (e.g. GUI, databases, operating systems, other languages, component models). This is [the] most likely area of work and creating and maintaining consistency will be the major challenge. For example, it will be important to provide a consistent view of text from C++. Having some interfaces use C-style strings, others the standard library string, and yet others notions of strings derived from the systems being interfaced to is a recipe for chaos.

Q: Is there room and/or market demand for a new language in the C family?

Ritchie: It's a little hard to imagine a language that's almost like C but enough better to displace it.
Stroustrup: I think the user community would be best served by a single language providing low level support for systems programming. I think C++ would serve well there and I see no technical problems merging C and C++.
Java doesn't provide support for low-level systems programming so it must rely on other languages (such as assembler, C, or C++). Conversely, for C or C++ to be useful for safe downloading into another machine, we need either hardware support (my preferred long-term solution for all languages), a C++ virtual machine.
So, is there room for another language beyond C, C++, and Java? There is certainly room for more languages.


Q: Which types of applications are well suited for [C/C++/Java]? Which are not?


Stroustrup: C++ has inherent strength in applications with a systems component, especially where there are constraints on resources (such as run time and memory). From that base, C++ provides significant support for organizing larger programs for easier maintenance and evolution.
Gosling: Java is certainly well-suited for anything that involves networks and in places where security is a concern. There are some things that it really was never targeted for, although people are certainly doing them. Writing device drivers tends to be kind of awkward, although it's surprising how many people have gone and done a number of fairly obvious things to make device driver writing in Java more straightforward.


Q: Are languages getting easier or more difficult to learn and use? Do you see any progressive usability trends among C, C++, and Java as those languages have appeared and/or added features over time?

Stroustrup: Languages are getting easier to use. For example, C++ with standard-library facilities (such as string, vector, and algorithms) is far easier to use than C++ using C-style strings, arrays, and C standard library functions to solve the same problems.
Java attempts to restrict programmers to a single style of programming. This makes Java easier to use within that domain, but leads to ugly workarounds when the edges of that style are approached. The need for casting when using Java containers is an obvious example.



Personal Preferences
Q: We all have different reasons why we've chosen to be in the software industry. What was it that drew you to the software field? What makes it cool?


Ritchie: I started out interested in physics, and still maintain an amateur interest in keeping up with what's happening at its edges. Sometime in college and early grad school, I spent a lot of time in theoretical computer science (Turing machines, complexity theory). Meanwhile I also became more fascinated with real computers and, I suppose, the immediacy of the experience they provided: when you write a program, you can see what it does right away. All of these things connect with each other in interesting ways. Being involved with this sort of activity was what motivated me. Somehow I didn't think of what I was doing as joining the Software Industry, although, even in 1968, I guess it was.
Stroustrup: I'm not sure exactly what brought me to computers. I saw computers as a practical and useful outlet for scientific interests. I really like building things. When you build you get feedback from the tools, from the program/system, and from users. That's what pushes the imagination beyond what is obvious and beyond the preconceptions and doctrine of an individual, an academic field, or an organization. I like Kristen Nygaard's notion of programming as a means of understanding something.
Gosling: I don't know what it is about my genetic structure, but I just like to build stuff. In some sense whether I'm building software or building a chair or building dinner -- also known as cooking -- I get a kick out of just creating stuff. One of the things that's nice about software is that you can create just about the most amazingly sophisticated complex things and you can do it fairly quickly. If I was a watchmaker, I'm sure I'd get frustrated with how hard it was to create things with lots of gears and pulleys; and yet, just looking at a good watch, you take off the back and it's just so cool. I don't know why it's cool, it just feels really cool to me. With software you can put as many as gears and cams and whatever in there as you want, and things just get complex. In some sense the thing I like most about software is the thing I end up spending most of my time fighting against, which is complexity.


Q: What was the first programming language you ever used?

Ritchie:Around 1962, I went to a non-course talk about Cobol (by Jean Sammet), and took a course that involved programming both analog computers using a plugboard and writing Univac I machine language (no assembler). Also about this time, I visited the IBM office in Cambridge (MA) and they gave me manuals about Fortran, which I read avidly.
Stroustrup: My first programming language was Algol60 on a GIER computer. The GIER was a 1960s Danish computer with 1K 42 bit (I think, plus a few extra bits for hardware testing) words.
Gosling: The first programming language I ever used was a language called Focal 5. Focal stood for "formula calculi." It was a scripting language for PDP-8's. I wrote most of my earliest programs using Focal 5. It's a language whose complete compiler and runtime system can be implemented in under 24 hours. It's actually a nice little language, way simpler than Basic.

Q: What languages, or features of languages, inspired you?


Stroustrup: In addition to Simula67, my favorite language at the time was Algol68. I think that "Algol68 with Classes" would have been a better language than "C with Classes."
Gosling: Lisp, the thing that influenced me the most was the incredible difference garbage collection made. Using Simula and being a local maintainer of the Simula compiler was really what introduced me to objects and got me thinking about objects. Using languages like Pascal got me really thinking about modeling. Languages like Modula-3 really pushed things like exception mechanisms. I've used a lot of languages, and a lot of them have been influential. You can go through everything in Java and say, "this came from there, and this came from there."

Q: What was the first program you ever wrote? On what hardware?


Ritchie:The first on a real computer was the Univac I program. (As I learned a year or so later, the exercise was in fact to implement some of the APL operators--Iverson was around then).
Stroustrup: I don't recall, but it must have been some computer science 101 exercise in Algol60 on a GIER computer. The first programs that I did for real -- that is, for others to use -- were business programs written in assembler for Burroughs office computers. I financed most of my Danish masters degree that way.

Q: Is there a programming language that is the best choice for all (or nearly all) application development? If yes, which language is it, and what makes it best? If not, what would it take to create such a language?


Ritchie: No, this is silly.

Stroustrup: No. People differ too much for that and their applications differ too much. The notion of a perfect and almost perfect language is the dream of immature programmers and marketeers. Naturally, every language designer tries both to strengthen his language to better serve its core community and to broaden its appeal, but being everything to everybody is not a reasonable ideal. There are genuine design choices and tradeoffs that must be made.

Q: Programmers often talk about the advantages and disadvantages of programming in a "simple language." What does that phrase mean to you, and is [C/C++/Java] a simple language in your view?


Ritchie: C (and the others for that matter) are simple in some ways, though they are also subtle; other, somewhat similar languages like Pascal are arguably simpler. What has become clear is that aspects of the environment like libraries that aren't part of the core language are much bigger and more complicated.
The 1999 C standard grew hugely more in the library part than in the language; the C++ STL and other things are big; AWT and other things associated with Java are too.
Stroustrup: Notions of "simple:" to be easy to learn, to make it easy to express ideas, and to have a one-to-one correspondence to some form of math. In those terms, none of the three languages is simple. However, once mastered, C and C++ make it easy to express quite complex and advanced ideas.


Q: What topics do you feel are missing from university computer science and engineering programs around the world that would help to improve the quality of software?

Stroustrup: In some well-respected computer science departments, you can graduate without having written any code. That ought not be possible. Nobody should graduate with a degree in computer science or computer engineering without having completed a significant programming project. Code is the base of computing and people without a "feel" for code tend to seriously misjudge what skills, tools, and time are needed to build good systems.


I think reading and writing code should be a significant part of the training of every computer professional. However much we talk about "Computer Science" and "Software Engineering", building systems still has a large practical component relating to reading, writing, and maintaining code.


No, I'm not arguing that we should just teach hacking
I argue for a balance between theoretical and practical skills.
Gosling: People have been getting a pretty good education in the technology; what they tend to not get is a good view of what goes on in an actual engineering organization:

Q: Outside the C family of languages, what language(s) do you like the best? What in particular makes them interesting to you?

Ritchie: I have to admire languages like Lisp. But, just as in the earlier question about a "simple" language, an astonishingly simple language grows in practice into something that can be fearsome.



Stroustrup: Algol68, CLOS, and ML springs to mind. In each case, what attracts me is flexibility and some very elegant code examples.


Q: What are your favorite software-related books?

Ritchie: The works of Kernighan and Pike (separately or collectively) are nice. The software book I enjoyed most is Ben Ross Schneider's Travels in Computerland.
Stroustrup: Brooks' The Mythical Man Month Booch's Object-Oriented Design, and Gamma et.al.'s Design Patterns.


Programming Language Standards
Q: Is it important to have a formal (e.g., ISO/ANSI) standard for a programming language? What are the advantages? The disadvantages?



Ritchie: At some point a formal standard tends to become necessary, particularly for language that evolved informally (certainly C, but also C++ and Java
At the same time, there are disadvantages, in that whatever clear (or cloudy) vision that the original designers might have had ends up colored by whatever strange proposals the participants in the process bring forth. Complication invariably results as a result of the compromises.
Stroustrup: In today's overheated commercial atmosphere it is essential to have a formal standard. Naturally, an ISO standard is not a complete defense, and not all of our languages, libraries, or tools can be standardized. However, without a standard, users are completely at the mercy/whim of their suppliers.
Conformance suites are widely used for ISO C and ISO C++.


Q: Is it important to have a de facto standard for a programming language? What are the advantages? The disadvantages?

Stroustrup: A de facto standard is a major advantage to its owner and its owner's friends/allies. It can also benefit third parties, such as professors, students, and small companies
Gosling: I think that in a strong sense de facto standards are the ones that really matter. It hardly matters what's actually written down in anybody's standards document; what actually matters is what people have actually implemented.

I'm a real fan of Linux; the problem is that there are so many flavors of Linux and they're all just different enough that life is really hard.


The "Century 21" Software Industry
Q: Prognostication is hard, but valuable even if it can never be 100% accurate. In your view, what are the major forces driving the kinds of software we will be writing in the future? and the way we will be writing that software?


Ritchie: The most obvious change that has occurred recently is the increase in use of "scripting languages" that are generally interpreted. These range from the basic ones like HTML to Perl, Tcl/Tk, and Javascript, and then to presentation-graphics packages for making WWW pages or slides.
Stroustrup: The future? these days it is close to impossible to even describe the present.
We have to see more emphasis on correctness, quality, and security.
I really hope 2050s software and systems will be too advanced for me to imagine today, just as a 1950s expert had little chance of predicting today's systems with any accuracy or in any detail.

Notes :

1. B. Kernighan and D. Ritchie. The C Programming Language, 2nd edition (Prentice Hall, 1998) ISBN 0131103709.
2. B. Stroustrup. The Design and Evolution of C++ (Addison-Wesley, 1994) ISBN 0201543303.
3. B. Stroustrup. The C++ Programming Language, Special Edition (Addison-Wesley, 2000) ISBN 0201700735.
4. http://www.research.att.com/~bs.
5. B. Stroustrup. "Wrapping C++ Member Function Calls" (C++ Report, 12(6), June 2000).
6. B. Stroustrup. "Learning Standard C++ as a New Language" (C/C++ Users Journal, May 1999; also in CVu 12(1) January 2000).
7. B. Kernighan and R. Pike. The Practice of Programming (Addison-Wesley, 1999) ISBN 020161586X.
8. B. Kernighan and R. Pike. The UNIX Programming Environment (Prentice Hall, 1984) ISBN 013937681X.
9. B. Kernighan and P.J. Plauger. The Elements of Programming Style (McGraw-Hill, 1988) ISBN 0070342075.
10. B. Schneider. Travels in Computerland: Or, Incompatibilities and Interfaces: A Full and True Account of the Implementation of the London Stage Information Bank, ASIN 0201067374.
11. F. Brooks. The Mythical Man-Month: Essays on Software Engineering (Addison-Wesley, 1995) ISBN 0201835959.
12. G. Booch. Object-Oriented Analysis and Design With Applications (Addison-Wesley, 1994) ISBN 0805353402.
13. E. Gamma, R. Helm, R. Johnson, and J. Vlissides. Design Patterns : Elements of Reusable Object-Oriented Software (Addison-Wesley, 1995) ISBN 0201633612.
14. J. Bentley. Programming Pearls, Second Edition (Addison-Wesley, 1999) ISBN 0201657880.
15. R. Sedgewick. Algorithms in C, 3rd edition (Addison-Wesley, 2000) ISBN 0201849372. (There are at least ten "Algorithms" books by Sedgewick, covering different scopes or specialized for different programming languages. This is one of the most recently written/updated.)
16. A. Koenig and B. Moo. Ruminations on C++ (Addison-Wesley, 1996) ISBN 0201423391.

(Source : Internet )
N.B: This article was trimmed to fit for the theoretical enhancement of various professionals , students and others.



Saurav Banerjee, Ranchi , INFI-NITE .

techinfiniteonline@gmail.com

The C Family of Languages: Experts Opinions by Dennis Ritchie ,Bjaurn Stroustrup ,James Gosling :

The C Family of Languages:

The C family of languages--C, C++, and Java--has dominated commercial programming for over 30 years. Today, all three languages are at a turning point:
o The second ISO/ANSI C standard has just been published (C99 was officially released in December 1999). C continues to be one of the most influential languages in the world, particularly in the field of embedded systems.
o The first official update to the ISO/ANSI C++ standard will be completed in October 2000. C++ is one of the most widely used commercial programming languages in the world, with unparalleled support for both object-oriented and generic programming, and continues to experience steady growth.
o Java popularity continues to grow in various areas, from client-side to server-side programming. Sun has recently decided that Java can best flourish as a de facto standard, instead of as a formal ISO/ANSI or ECMA standard, and has abandoned formal standardization efforts.
What has made the C family of languages so dominant?


Q: Why has the C family of languages become so successful and so widely used?

The use of C, was during early times (meaning the '70s and much of the '80s) considerably encouraged by its use as the lingua franca of Unix during the period that Unix was growing in the research and academic community, and then when Unix was taken up as the software basis for the workstation industry of the '80s. There were also technical and semi-technical aspects: the language turned out to be well-placed both for describing things at a high enough level so that portability across hardware was feasible, but simple enough in its requirements to make it cheap to implement.
C and C++ became popular because they were flexible, cheap, and more efficient than alternatives. C++ owes much of its initial popularity to its high degree of compatibility with C.
It was very important success of C and C++ that AT&T didn't try to monopolize these languages, but allowed its researchers to support the creation of alternative implementations. Also, AT&T fully supported ANSI and ISO standardization of C and C++ as soon as these efforts started.
Java is a very different design from the other two languages and appears to have a very different philosophy.
Just to remind people: Both C and C++ were invented in the Computer Science Research Center of Bell Labs in Murray Hill and found their initial serious use within Bell Labs and AT&T.
Among technical factors, C and C++ benefited from their closeness to machine and absence of artificial restrictions on what can be expressed. That allows low-level systems work to be done in these languages and for the full performance of a machine to be delivered to its users. Java benefited from running in its own virtual machine and from coming with a large set of libraries that decrease the time needed for a programmer to become productive. Unix gave a similar boost to C. In contrast, the C++ world suffers from fragmentation of its huge base of libraries, many of which are proprietary and supplied by competing vendors.
C++ was a language where I could write programs that were as elegant as Simula programs, yet as efficient as C programs.
The object-oriented facilities from Simula helped with the former, and the systems-programming facilities of C with the latter.
Like C, Java's goals were really around being able to build relatively specific kinds of software.
For example, one of the differences between Java and C is that Java has real arrays and the arrays get bounds-checked, and that turns out to be important for both reliability and security. If you look at the history of security breaches on the Internet, some really large fraction of them are exploiting buffer overflows, statically allocated arrays that people just go over the end of. If you look at logs of bug-fixing that people go through, it ends up being that memory integrity issues are a huge fraction of where the problems come from.
C haven't changed much in many years, and I haven't been a central player in the changes in either the 1989 or 1999 standards.
C++ haven’t changed much, still good for serious systems programming -- including work at the machine level and on resource-constrained systems .
The major shift in emphasis/style comes from finally having templates and exceptions available.
where everything is flexible and everything is dynamic, and static languages like C, where everything is statically precompiled. Java is kind of in this netherworld in between them, and given the way the world has evolved to become even more networked than before, even more conscious of security issues.
Probably the oddest aspect of C compared with other languages outside its immediate family is the declaration syntax, in which (in a way coming from Fortran) a type is mentioned, then variables decorated in a way that reflects their use in expressions.
A closely related aspect is the treatment of arrays and pointers.
C and C++ communities benefit from a genuine degree of compatibility. Also, much of work on the non-abstraction areas of C++ has been fed back into Standard C. Examples are function declarations/prototypes, const (Dennis also had a hand in their design), declarations wherever statements can appear, and the // comments.
A lot of the design of interfaces was borrowed pretty straightforwardly from Objective C, and it's got some pluses and minuses and it was a real tough balancing act.


Q: Did you ever add features that your users didn't appreciate as much as you did, and then have to deprecate or remove them later? What did you learn from the experience?


Ritchie: I added some things under some pressure from users that I don't think were done well. Enumeration types are a bit odd, bitfields are odder. The "static" keyword is very strange, expressing both a storage lifetime and what the standard calls "linkage" (external visibility). There are many odd bits here and there.
I can't remember features I added that I had to remove except for some tiny bits, like the "entry" keyword. I clearly wish I could have done something about the C declaratory syntax.
In addition, Having had templates integral to the language early on would have helped many use C++ better.
Stroustrup: When I designed C with Classes and C++, I was very keen on the idea that a class defined the environment in which the code of its member functions operate (I still am). This led to the notion of constructors that establish that environment (invariant) and acquire the resources needed. Destructors reverse that process (releasing resources).
Based on that line of thinking, C with Classes also allowed you to define a call() function that was called before entry into a member function and a return() function that was called after exit from a member function. The call()/return() mechanism was meant to allow a programmer to manage resources needed for an individual member function invocation. This allowed me to implement monitors for the first task library. A task's call() grabbed a lock and its matching return() released the lock. The idea came partly from Lisp's :before and :after methods. However, the notion wasn't perfectly general -- for example, you couldn't access arguments for a member function call from call(). Worse, I completely failed to convince people of the usefulness of this notion, so I removed call() and return() when I defined C++.
I recently revisited this issue and I wrote a template -- in Standard C++ -- that wraps calls to an object by arbitrary prefix and suffix.

There are some things that I kind of feel torn about, like operator overloading. I left out operator overloading as a fairly personal choice because I had seen too many people abuse it in C++.

Q: In your experience, what are the most common mistakes developers make in [C/C++/Java]?

Ritchie: I don't really know the answer to this question. I would suppose that the low-level mistakes have to do with type errors, and especially with array subscript and pointer references
C itself does very little to help you here; you have to design a scheme.
Stroustrup: Using C++ just as if it was C or Smalltalk. That leads to seriously suboptimal C++. To use C++ well, you have to adopt some native C++ styles. These tend to be distinguished by small concrete classes and templates. A programming style that is overly influenced by C tends to use a lot of arrays, clever pointer manipulation, casts, and macros rather than standard library facilities (such as vectors, strings, and maps). A programming style that is overly influenced by Smalltalk tries to cram every class into a hierarchy and to overuse casts (and often macros). In either case, key abstractions tend to disappear in a mess of implementation details and people get themselves (unnecessarily) tied in knots with allocation, pointers, casts, and macros.
One common mistake that particularly annoys me is the use of complicated base classes with lots of data members as part of interfaces offered to application builders (users). Abstract base classes make much better interfaces to services. I have tried to root out such misuses for well over ten years: I added abstract classes in 1989 after failing to get the idea across without the support of an explicit language feature.


The idea is really simple:
class interface { // seen by users
// pure virtual functions
};
class my_implementation : public interface {
// data
// functions
// overriding functions
};
When user code sees only "interface," it is immune to changes to "my_implementation."
If common data structures or operations are needed for implementations they can be added in a base class that is visible only to implementers:
class common { // seen by implementers
// data
// functions
};
class my_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
class your_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
This is one of the simplest and most fundamental uses of multiple inheritance.
What many people need to get much more out of C++ is not new features, it is simply a more appropriate design and programming style.
Gosling: Probably the most pervasive mistake is not doing a tasteful job of object-oriented programming. There are these people who don't understand it at all, who just do some procedural kind of stuff and write their program as one huge class with a lot of methods in it; they try to do it in a C style. Then there are the people who go, "Ooo, objects! They're cool! Let's make gazillions of them!"

Q: In your experience, how long does it take for a novice programmer to become a reasonably proficient [C/C++/Java] developer ?

Ritchie: I don't know the answer to this question either--my stock joke on similar ones is, "Well, I never had to learn C...."
Stroustrup: That depends critically on the background of the novice, on the complexity of the task first attempted with C++, and on the teaching/learning approach.
For a novice programmer, a year and a half seems appropriate; for a programmer who is a novice to C++ and the techniques it supports half a year seems more likely.
I consider good libraries essential to provide a smooth learning curve and to properly sequence the learning of C++ concepts. For example, having the C++ standard library available makes it possible to learn the basic type, scope, and control structure concepts without having to deal with arrays, pointers, and memory management at the same time. Such fundamental, yet low-level concepts are best learned a bit later.
This is dangerous. In this context, it is a strength C++ (and of C) that the standard libraries usually are implemented in the language itself using only the facilities available to every programmer.
Gosling: The language itself tends to be a snap to learn; it's all the library stuff that takes the time, and there the best way to do it is to just start writing and using it, and when you need something, look for it.
C didn't come until later just because it's so easy to do goofy things in C; it's so easy to have an array and write "for( i = 1; i <= length; ... )" and you have to explain, "no, it's not less than or equal to length and it's not 1, it's 0 and it's less than." But of course your loop runs just fine, only maybe sometimes you'll discover that you smack the malloc header of the block immediately following the array and nobody's ever told you about that.
That's just so incredibly common in C and C++ or any language that doesn't have a really strict memory model.

Q: Are there any important features missing from the C family of languages? From [C/C++/Java]?

Stroustrup: In which sense do C, C++, and Java constitute a family of languages? C and C++ has a large common subset, and over the years serious efforts have been made to minimize the inevitable tendency of the two languages to drift apart because they are controlled by separate standards bodies. Java, however, provides no real compatibility, and similar syntactic constructs have semantics different from the C and C++ versions. Clearly, Java borrows from C and C++, but under the skin, the similarities to Modula-3 seem greater.
Undoubtedly, all three languages could be significantly improved by addition. However, I see little reason to believe that there is a single major feature that would help all three languages.
Gosling: One of the things that always bugged me about C was the weak memory model, the fact that you could cast a pointer to a character into a pointer to an integer; it just did weird things. But then you change that and it's not C any more, it's basically Java.
The other is type polymorphism, something like templates, and Java actually has something like a poor man's template system right now in that the type hierarchy has a common root for anything and everything, namely Object, but there's also a group working on doing a proper job of type polymorphism in Java. It turns out to be a really hard problem. Other issues are clearer: garbage collection is a good idea; goto is a bad idea.


Q: What things would you like to see become a part of [C/C++/Java] in the next 2-5 years? In the next 10 years? Why?

Ritchie: For C, the new 1999 standard exists but has not become readily available, and it has quite a few changes from the earlier one, though not revolutionary ones.
Stroustrup: I think that the emphasis for C++ evolution should be in library building.
Clearly, many people worry about concurrency and about interfaces to various systems (e.g. GUI, databases, operating systems, other languages, component models). This is [the] most likely area of work and creating and maintaining consistency will be the major challenge. For example, it will be important to provide a consistent view of text from C++. Having some interfaces use C-style strings, others the standard library string, and yet others notions of strings derived from the systems being interfaced to is a recipe for chaos.

Q: Is there room and/or market demand for a new language in the C family?

Ritchie: It's a little hard to imagine a language that's almost like C but enough better to displace it.
Stroustrup: I think the user community would be best served by a single language providing low level support for systems programming. I think C++ would serve well there and I see no technical problems merging C and C++.
Java doesn't provide support for low-level systems programming so it must rely on other languages (such as assembler, C, or C++). Conversely, for C or C++ to be useful for safe downloading into another machine, we need either hardware support (my preferred long-term solution for all languages), a C++ virtual machine.
So, is there room for another language beyond C, C++, and Java? There is certainly room for more languages.


Q: Which types of applications are well suited for [C/C++/Java]? Which are not?


Stroustrup: C++ has inherent strength in applications with a systems component, especially where there are constraints on resources (such as run time and memory). From that base, C++ provides significant support for organizing larger programs for easier maintenance and evolution.
Gosling: Java is certainly well-suited for anything that involves networks and in places where security is a concern. There are some things that it really was never targeted for, although people are certainly doing them. Writing device drivers tends to be kind of awkward, although it's surprising how many people have gone and done a number of fairly obvious things to make device driver writing in Java more straightforward.


Q: Are languages getting easier or more difficult to learn and use? Do you see any progressive usability trends among C, C++, and Java as those languages have appeared and/or added features over time?

Stroustrup: Languages are getting easier to use. For example, C++ with standard-library facilities (such as string, vector, and algorithms) is far easier to use than C++ using C-style strings, arrays, and C standard library functions to solve the same problems.
Java attempts to restrict programmers to a single style of programming. This makes Java easier to use within that domain, but leads to ugly workarounds when the edges of that style are approached. The need for casting when using Java containers is an obvious example.



Personal Preferences
Q: We all have different reasons why we've chosen to be in the software industry. What was it that drew you to the software field? What makes it cool?


Ritchie: I started out interested in physics, and still maintain an amateur interest in keeping up with what's happening at its edges. Sometime in college and early grad school, I spent a lot of time in theoretical computer science (Turing machines, complexity theory). Meanwhile I also became more fascinated with real computers and, I suppose, the immediacy of the experience they provided: when you write a program, you can see what it does right away. All of these things connect with each other in interesting ways. Being involved with this sort of activity was what motivated me. Somehow I didn't think of what I was doing as joining the Software Industry, although, even in 1968, I guess it was.
Stroustrup: I'm not sure exactly what brought me to computers. I saw computers as a practical and useful outlet for scientific interests. I really like building things. When you build you get feedback from the tools, from the program/system, and from users. That's what pushes the imagination beyond what is obvious and beyond the preconceptions and doctrine of an individual, an academic field, or an organization. I like Kristen Nygaard's notion of programming as a means of understanding something.
Gosling: I don't know what it is about my genetic structure, but I just like to build stuff. In some sense whether I'm building software or building a chair or building dinner -- also known as cooking -- I get a kick out of just creating stuff. One of the things that's nice about software is that you can create just about the most amazingly sophisticated complex things and you can do it fairly quickly. If I was a watchmaker, I'm sure I'd get frustrated with how hard it was to create things with lots of gears and pulleys; and yet, just looking at a good watch, you take off the back and it's just so cool. I don't know why it's cool, it just feels really cool to me. With software you can put as many as gears and cams and whatever in there as you want, and things just get complex. In some sense the thing I like most about software is the thing I end up spending most of my time fighting against, which is complexity.


Q: What was the first programming language you ever used?

Ritchie:Around 1962, I went to a non-course talk about Cobol (by Jean Sammet), and took a course that involved programming both analog computers using a plugboard and writing Univac I machine language (no assembler). Also about this time, I visited the IBM office in Cambridge (MA) and they gave me manuals about Fortran, which I read avidly.
Stroustrup: My first programming language was Algol60 on a GIER computer. The GIER was a 1960s Danish computer with 1K 42 bit (I think, plus a few extra bits for hardware testing) words.
Gosling: The first programming language I ever used was a language called Focal 5. Focal stood for "formula calculi." It was a scripting language for PDP-8's. I wrote most of my earliest programs using Focal 5. It's a language whose complete compiler and runtime system can be implemented in under 24 hours. It's actually a nice little language, way simpler than Basic.

Q: What languages, or features of languages, inspired you?


Stroustrup: In addition to Simula67, my favorite language at the time was Algol68. I think that "Algol68 with Classes" would have been a better language than "C with Classes."
Gosling: Lisp, the thing that influenced me the most was the incredible difference garbage collection made. Using Simula and being a local maintainer of the Simula compiler was really what introduced me to objects and got me thinking about objects. Using languages like Pascal got me really thinking about modeling. Languages like Modula-3 really pushed things like exception mechanisms. I've used a lot of languages, and a lot of them have been influential. You can go through everything in Java and say, "this came from there, and this came from there."

Q: What was the first program you ever wrote? On what hardware?


Ritchie:The first on a real computer was the Univac I program. (As I learned a year or so later, the exercise was in fact to implement some of the APL operators--Iverson was around then).
Stroustrup: I don't recall, but it must have been some computer science 101 exercise in Algol60 on a GIER computer. The first programs that I did for real -- that is, for others to use -- were business programs written in assembler for Burroughs office computers. I financed most of my Danish masters degree that way.

Q: Is there a programming language that is the best choice for all (or nearly all) application development? If yes, which language is it, and what makes it best? If not, what would it take to create such a language?


Ritchie: No, this is silly.

Stroustrup: No. People differ too much for that and their applications differ too much. The notion of a perfect and almost perfect language is the dream of immature programmers and marketeers. Naturally, every language designer tries both to strengthen his language to better serve its core community and to broaden its appeal, but being everything to everybody is not a reasonable ideal. There are genuine design choices and tradeoffs that must be made.

Q: Programmers often talk about the advantages and disadvantages of programming in a "simple language." What does that phrase mean to you, and is [C/C++/Java] a simple language in your view?


Ritchie: C (and the others for that matter) are simple in some ways, though they are also subtle; other, somewhat similar languages like Pascal are arguably simpler. What has become clear is that aspects of the environment like libraries that aren't part of the core language are much bigger and more complicated.
The 1999 C standard grew hugely more in the library part than in the language; the C++ STL and other things are big; AWT and other things associated with Java are too.
Stroustrup: Notions of "simple:" to be easy to learn, to make it easy to express ideas, and to have a one-to-one correspondence to some form of math. In those terms, none of the three languages is simple. However, once mastered, C and C++ make it easy to express quite complex and advanced ideas.


Q: What topics do you feel are missing from university computer science and engineering programs around the world that would help to improve the quality of software?

Stroustrup: In some well-respected computer science departments, you can graduate without having written any code. That ought not be possible. Nobody should graduate with a degree in computer science or computer engineering without having completed a significant programming project. Code is the base of computing and people without a "feel" for code tend to seriously misjudge what skills, tools, and time are needed to build good systems.


I think reading and writing code should be a significant part of the training of every computer professional. However much we talk about "Computer Science" and "Software Engineering", building systems still has a large practical component relating to reading, writing, and maintaining code.


No, I'm not arguing that we should just teach hacking
I argue for a balance between theoretical and practical skills.
Gosling: People have been getting a pretty good education in the technology; what they tend to not get is a good view of what goes on in an actual engineering organization:

Q: Outside the C family of languages, what language(s) do you like the best? What in particular makes them interesting to you?

Ritchie: I have to admire languages like Lisp. But, just as in the earlier question about a "simple" language, an astonishingly simple language grows in practice into something that can be fearsome.



Stroustrup: Algol68, CLOS, and ML springs to mind. In each case, what attracts me is flexibility and some very elegant code examples.


Q: What are your favorite software-related books?

Ritchie: The works of Kernighan and Pike (separately or collectively) are nice. The software book I enjoyed most is Ben Ross Schneider's Travels in Computerland.
Stroustrup: Brooks' The Mythical Man Month Booch's Object-Oriented Design, and Gamma et.al.'s Design Patterns.


Programming Language Standards
Q: Is it important to have a formal (e.g., ISO/ANSI) standard for a programming language? What are the advantages? The disadvantages?



Ritchie: At some point a formal standard tends to become necessary, particularly for language that evolved informally (certainly C, but also C++ and Java
At the same time, there are disadvantages, in that whatever clear (or cloudy) vision that the original designers might have had ends up colored by whatever strange proposals the participants in the process bring forth. Complication invariably results as a result of the compromises.
Stroustrup: In today's overheated commercial atmosphere it is essential to have a formal standard. Naturally, an ISO standard is not a complete defense, and not all of our languages, libraries, or tools can be standardized. However, without a standard, users are completely at the mercy/whim of their suppliers.
Conformance suites are widely used for ISO C and ISO C++.


Q: Is it important to have a de facto standard for a programming language? What are the advantages? The disadvantages?

Stroustrup: A de facto standard is a major advantage to its owner and its owner's friends/allies. It can also benefit third parties, such as professors, students, and small companies
Gosling: I think that in a strong sense de facto standards are the ones that really matter. It hardly matters what's actually written down in anybody's standards document; what actually matters is what people have actually implemented.

I'm a real fan of Linux; the problem is that there are so many flavors of Linux and they're all just different enough that life is really hard.


The "Century 21" Software Industry
Q: Prognostication is hard, but valuable even if it can never be 100% accurate. In your view, what are the major forces driving the kinds of software we will be writing in the future? and the way we will be writing that software?


Ritchie: The most obvious change that has occurred recently is the increase in use of "scripting languages" that are generally interpreted. These range from the basic ones like HTML to Perl, Tcl/Tk, and Javascript, and then to presentation-graphics packages for making WWW pages or slides.
Stroustrup: The future? these days it is close to impossible to even describe the present.
We have to see more emphasis on correctness, quality, and security.
I really hope 2050s software and systems will be too advanced for me to imagine today, just as a 1950s expert had little chance of predicting today's systems with any accuracy or in any detail.

Notes :

1. B. Kernighan and D. Ritchie. The C Programming Language, 2nd edition (Prentice Hall, 1998) ISBN 0131103709.
2. B. Stroustrup. The Design and Evolution of C++ (Addison-Wesley, 1994) ISBN 0201543303.
3. B. Stroustrup. The C++ Programming Language, Special Edition (Addison-Wesley, 2000) ISBN 0201700735.
4. http://www.research.att.com/~bs.
5. B. Stroustrup. "Wrapping C++ Member Function Calls" (C++ Report, 12(6), June 2000).
6. B. Stroustrup. "Learning Standard C++ as a New Language" (C/C++ Users Journal, May 1999; also in CVu 12(1) January 2000).
7. B. Kernighan and R. Pike. The Practice of Programming (Addison-Wesley, 1999) ISBN 020161586X.
8. B. Kernighan and R. Pike. The UNIX Programming Environment (Prentice Hall, 1984) ISBN 013937681X.
9. B. Kernighan and P.J. Plauger. The Elements of Programming Style (McGraw-Hill, 1988) ISBN 0070342075.
10. B. Schneider. Travels in Computerland: Or, Incompatibilities and Interfaces: A Full and True Account of the Implementation of the London Stage Information Bank, ASIN 0201067374.
11. F. Brooks. The Mythical Man-Month: Essays on Software Engineering (Addison-Wesley, 1995) ISBN 0201835959.
12. G. Booch. Object-Oriented Analysis and Design With Applications (Addison-Wesley, 1994) ISBN 0805353402.
13. E. Gamma, R. Helm, R. Johnson, and J. Vlissides. Design Patterns : Elements of Reusable Object-Oriented Software (Addison-Wesley, 1995) ISBN 0201633612.
14. J. Bentley. Programming Pearls, Second Edition (Addison-Wesley, 1999) ISBN 0201657880.
15. R. Sedgewick. Algorithms in C, 3rd edition (Addison-Wesley, 2000) ISBN 0201849372. (There are at least ten "Algorithms" books by Sedgewick, covering different scopes or specialized for different programming languages. This is one of the most recently written/updated.)
16. A. Koenig and B. Moo. Ruminations on C++ (Addison-Wesley, 1996) ISBN 0201423391.

(Source : Internet )
N.B: This article was trimmed to fit for the theoretical enhancement of various professionals , students and others.



Saurav Banerjee, Ranchi , INFI-NITE .

techinfiniteonline@gmail.com

1985


THE FAMILY OF GENIUSES :

DMR


DMR : DENNIS RITCHIE

KEN THOMPSON

DENNIS RITCHIE

Bell Labs Early Contributions to Computer Science

1937
G.R. Stibitz designs the first binary relay calculator.
1939
G. R. Stibitz and E.G. Andrews build the first electric computer for routine use, the Bell Labs Model I relay computer.
1939
S. B. Wright and E. R. Taylor develop an analog adder that used the algebraic sum of the route-mean-square values of several wave forms to control transatlantic radiotelephone facilities.
1940
C.A. Lovell and D.B. Parkinson develop an analog computer to control aircraft guns.
1941-42
A.W. Horton invents the AND gate diode logic circuit, and the next year W.H.T. Holden invents the OR gate.
1942
Based on Lovell and Parkinson's work, Bell Labs develops the analog M-9 gun director for the U.S. Army.
1943-45
Each year saw the introduction of the Bell Labs Model II, Model III and Model IV relay computers, respectively, that remained in service for 13-15 years.
1943
G.R. Stibitz first uses error-correcting codes in his Bell Labs Model II computer.
1946
The first of the Model Vs is delivered to the U.S. National Advisory Committee for Aeronautics at Langley Field, Va.
1947
J. Bardeen, W.H. Brattain and W. Shockley invent the transistor.
1948
R.W. Hamming shows a systematic and optimal way to make correctable any single-bit error in a block of data.
1948
Claude Shannon develops his Information Theory, which determines how much information can be sent per unit of time in a system with a given, limited amount of transmission power.
1959
D.W. Hagelbarger develops error-correcting codes to cope with bursts of errors.
1949
E. Lakatos develops the general purpose analog computer (GPAC), nicknamed Gypsy.
1949
W.H. MacWilliams Jr. is probably the first to use transistor circuits as part of a simulated warfare computer.
1950
Bell Labs Model VI relay computer is used for in-house computing. It ran for 15 years.
1950
Develops error-correcting codes for digital transmission over data lines
1952
Develops the general-purpose, all solid-state Transistor Digital Computer.
1956
V.M. Wolontis and D.C. Leagus develop the higher L1 language, later called Bell 1 interpreter. Later R.W. Hamming and R.A. Weiss develop L2. Both were predecessors to a succession of Bell Labs programming languages to make computers easier to use, more productive, and better matched to applications.
1956
Though not using computers, Bell Labs demonstrates that low-speed (600 baud) computer-generated data could be transmitted over normal long distance telephone lines dialed at random.
1959
D. McIlroy and D.E. Eastwood describe how macros can be used to extend any programming language to meet a user's specific needs, anticipating the later use of "pipes" in UNIX.*.
1960
200 Series data modems are developed to support 2,000 b/s on the public switched voice network and 2,400 b/s on private lines networks
1963
Develops ALTRAN, an algebra translator computer language used to drive a package of subroutines for symbolic algebra.
1964
Bell Labs, MIT and General Electric try to develop the Multiplexed Information and Computing Service (Multics), as a successor to BESYS (Bell Operating System) and the Compatible Time-Sharing Service (CTSS) system of MIT. V.A. Vyssotksy coins the term "process" for Multics.
1965
Bell Labs develops the No. 1 Processor for the 1ESS® central office switch, which later evolved into the No. 1A processor for the 1AESS switch.
1966
Develops L6 language, permitting programmers to write in a language closer to machine language.
1968
W.D. Farmer and E.E. Newhall demonstrate an experimental loop system for interconnecting digital devices.
1969
Bell Labs disassociates itself from the Multics project and Kenneth Thompson develops the UNIX operating system.
1970
J.R. Pierce proposes a hierarchical interconnecting loop network for high-speed data communications, with users responsible for their own signaling and error control.
1970
A.G. Fraser begins the construction of Spider, an experimental high-speed packet-switched network of interconnected computers and terminals.
1970
GROOVE composes, stores and edits synthesized music.
1972
UNIX system is supporting word processing in Bell Labs Patent Division and a long distance test room in Charlotte, S.C.; and is handling trouble reports for Pacific Telephone.
1972
One of the early computer-based network maintenance tools, the CAROT (Centralized Reporting on Telephone Trunks) system, is field trialed in the San Francisco Bay area. LMOS (Loop Management Operations System), SARTS (Switched Access Remote Test System) and CMS (Circuit Maintenance System) soon follow.
1973
Dennis M. Ritchie writes the C programming language.
1974
Digital data service (DDS) is introduced, offering end-to-end digital data transport at rates of up to 56 Kb/s, using end user and private line network equipment developed by Bell Labs. The synchronous baseband data network supports point-to-point and multi-point transmission.
1975
UNIX version 6 released to universities.
1975
Western Electric, the predecessor organization to Lucent Technologies, begins external licensing of UNIX.
1975
B.W. Kernighan and L.L. Cherry use YACC (yet another complier-compiler) to write eqn, a natural language for setting mathematics.
1976
B.W. Kernighan and P.J. Plauger popularize the UNIX philosophy of design in their book Software Tools.
1976
BOS11 real-time database management operating system developed for PDP-11.
1976
Bell Labs Interlocation Computing Network permits a user at one site to run a job at a second site, and direct the results to a third site.
1970s
The DATAKIT(TM) virtual circuit switch is developed, based on A.G. Fraser's perfect scheduling algorithm, followed by the ISN packet switch for business applications.
1970s
The StarLAN local area network is developed to provide LAN connectivity over twisted pair wiring at 1 Mb/s and later 10 Mb/s, eliminating the need for coaxial cable connections.
1978
UNIX version 7 released commercially.
1980s
Bell Labs develops the synchronous 6500 series computers; the 3B family of multi-tasking computers; and the asynchronous 615 Business Communications Terminal, the 630 and 730 Multitasking Graphics Terminals, and the 705 Multitasking Terminal.
1981
UNIX System III released commercially.

Bjarne Stroustrup.
1983
Bjarne Stroustrup develops the first version of C++, which combines the expressive power of object-oriented programming (OOP) with the speed, compactness, and flexibility of C, its systems programming language predecessor.
1983
David Korn develops the Korn Shell scripting language for systems experts. It is the basis for large-scale systems.
1983
UNIX System V, Release 1 released commercially.
1984
UNIX System V, Release 2 released commercially.
1984
Narendra Karmarkar invents a software algorithm based on linear programming, known as the Karmarkar algorithm, that is used as an optimization tool for solving complex business and research problems that have a huge number of possible solutions.
1985
The 1PSS packet switch is developed to support virtual circuit or permanent virtual circuit switching at speeds from 4.8 kb/s to 56 kb/s in packets of 1024 bits or 2048 bits.



Rob Pike and Luca Cardelli.
1985
Rob Pike and Luca Cardelli develop a computer language, Squeak, that can be used to program computer mice and other interface devices.
1985
Access equipment and signaling procedures are developed by Bell Labs to permit switched 56 kb/s data through the 4ESS® toll switch, permitting customers to transmit data on a dial-up, as-needed basis to multiple locations without dedicated private lines between those locations.
1992
Bell Labs develops fault tolerant software, an alternative to large mainframe backups, allowing a telecommunications system to "tolerate" hardware faults, and some of the design and coding faults built into them.
1995
Bell Labs introduces Plan 9, a new distributed computer operating system and associated utilities built by the Computing Science Research Center.
1996
Bell Labs then-parent company, AT&T, creates independent Lucent Technologies with Bell Labs as its R&D arm, and removes itself from the computer business by divesting itself of NCR.
Bell Labs contributions to computer communications continues with the emergence of Lucent Technologies in 1996.

DENNIS RITCHIE :BELL LABS:

DENNIS RITCHIE :BELL LABS:
The author of the C programming language. (Image taken during the 1990 UKUUG Summer Conference, London.)
________________________________________
Kernighan & Ritchie: The C Programming Language, Second Edition (errata)
From: http://www.lysator.liu.se/c/c-errata.html#dmr
Mark Brader on B ,also in 1969, the system that Brian Kernighan would later name Unix was being developed by Ken Thompson "with some assistance from" Dennis Ritchie.
Tom Duff on Duff's Device.
Dennis Ritchie: BCPL to B to C
From: dmr@alice.att.com (Dennis Ritchie)
Brian W. Kernighan (1974): Programming in C: A Tutorial
Although it has lost little of its didactic value, it describes a language that C compilers today do no longer understand: the C of 1974, four years before Kernighan and Ritchie published the first edition of ``The C Programming Language''.
The ANSI C Rationale
The vast majority of the language defined by the Standard is precisely the same as is defined in Appendix A of The C Programming Language by Brian Kernighan and Dennis Ritchie, and as is implemented in almost all C translators.

Top Websites and Resources for Developers

Top Websites and Resources for Developers
Open Source
• Sourceforge.net - THE Open Source repository with over 100,000 projects.
• Code.Google.com - Pushing the Open Source movement forward.
• Gnu.org - Pioneering the Free Software Movement for nearly 25 years.
• MySQL.com - The most popular Open Source database.
Code Search Engines
These websites let you search through code.
• Koders.com - The Open Source search Engine.
• Google Code Search - The web's biggest search engine.
• Krugle.com - Searching 2.5 Billions lines of code.
• csourcesearch.net A search engine for C and C++ code.
Top Websites for C++ Programming
• Boost.org - The place to go after you've learnt the STL.
• Bjarne Stroustrup's Website - He invented C++.
• Mindview.net - Home to Bruce Eckel, Famous for "Thinking in C++" and other books.
Top Websites for C# Programming
• CodeProject.com - Speaks for itself!
• MSDN List of C# Tools and Resources Even includes a link to Mono!
Top Websites for Linux Programming
• Freshmeat.net - The sourceforge of Linux.
Top Websites for Windows Programming
• Msdn.com - If you develop for Windows, this is the place to start.
Miscellaneous
• bug.gd - Search for errors and report how you fixed them to help others.
• Tiobe Community Programming Index Tracking the popularity of Programming Languages.

List of Free C Compilers

If you're interested in learning to program in C you'll find this list of C Compilers handy. Most of these compilers do C++ and C. Just rename the files to have .C extensions.
• Microsoft Visual C++ 2008 Express. Not everyone likes Microsoft but there's no denying that they do provide very good code with an excellent IDE. It needs .NET though you can compile for win 32 (but no MFC). We've already produced Instructions on downloading and installing it. it requires free registration.
• Linkfrm. This is more of a computer science project developed at the IPD at the Universität Karlsruhe to improve the quality of software with visualization of of program structures. It includes cparser, a C compiler, which can parse C89 and C99 as well as many GCC and some MSVC extensions. The handled GCC extensions include __attribute__, inline assembler, computed goto and statement expressions. See this post for more about the project.
• Turbo Explorer for C++. Originally Borland then Codegear and now Embarcadero, this is a fast and poewerful C++ (which includes C like Microsoft's does). Also like Microsoft's compiler it requires free registration. It includes a great IDE, a great debugger features, Code Insight, templates, and easy database explorer and connectivity. There is support for databases as well. This needs Windows.
• Open Watcom. Getting a bit long in the tooth and the IDE isn't great but runs on Windows 2000 (probably 98) as well as newer Windows.
• GCC. The classic open source C compiler for Linux and many other operating systems (and Windows under Cygwin or Ming). A project that has been around forever. Excellent open source quality software. It doesn't come with an IDE (which are generally platform dependent) but there are loads out there eg MonoDevelop on Linux.
• Digital Mars C/C++ Compiler. Their IDE costs ($42.55) but the Basic C/C++ Win 32 compiler is free. You should also download the free STLPort as well as it contains the standard library including . You'd probably also find the free STLSoft and Garbage Collection downloads useful.
• Xcode. This is for Apple Macs and is their version of GCC but purely for Apple's own Mac OS Operating System. It has excellent documentation and SDKs for Mac and iPhone. If you have a Mac this is what you use.
• Tiny C - Compiler. TinyCC (aka TCC) is a small fast C compiler that is meant to be self-relying: you do not need an external assembler or linker because TCC does that for you. With the aid of another library it can be used as a backend code generator. TCC compiles so fast that even for big projects Makefiles may not be necessary.
• Portable C Compiler. This was developed from one of the earliest C Compilers and at the start of the 80s most c compilers were based on it. Portability was designed into it from the start in contrast to Dennis Ritchie's C compiler which was very hardware dependent. It's now being developed to be C99 compatible.
• Failsafe C. A Japanese project from the Research Team for Software Security at the Research Center for Information Security (RCIS), National Institute of Advanced Industrial Science and Technology (AIST), JAPAN, this version of C for Linux supports over 500 functions (not C99 or Widechar). It provides complete protection against memory block over-boundary accesses making it as safe as Java and C#.
• Pelles C is a free development kit for Windows and Windows Mobile containing an optimizing C compiler, a macro assembler, a linker, a resource compiler, a message compiler, a make utility and install builders for both Windows and Windows Mobile. It also has an IDE with project management, debugger, source code editor and resource editors for dialogs, menus, string tables, accelerator tables, bitmaps, icons, cursors, animated cursors, animation videos (AVI's without sound), versions and XP manifests.
• CC65 is an open source cross development package for 65(C)02 systems, including a powerful macro assembler, a C compiler, linker, librarian and several other tools. It includes support for Commodore C64, the GEOS operating system for the Commodore C64, the Commodore C128, the Commodore C16, C116 and Plus/4, the Commodore P500, the Commodore 600/700 family of computers, the Apple ][, the Atari 8bit machines, the Oric Atmos, the Nintendo Entertainment System (NES), the Supervision Game Console and the Atari Lynx Console

A List of Programming Contests and Challenges

There is a list of programming contests. Most are annual but some are continuous and you can enter at any time.Studying how others solved the problem can also be educational.Most important of all you can use C, C++ or C# in these.
http://www.ioccc.org/index.html

Annual Contests
• International Conference on Functional Programming (ICFP). This has been running for a decade and happens in June or July each year. Though it's based in Germany, anyone can enter using any programming language, from any location. It's free to enter and your team isn't limited by size.
• The BME International is an intense free to enter contest that takes place in Europe once a year for teams of three, and you have to bring your own computers and software. This year, the 7th took place in Budapest. This has had some interesting challenges in the past- how about driving a car over a virtual terrain? Other past tasks included controlling an oil-company, driving an assembly line robot and programming for secret communication. All programs were written in one 24 hour intense period!
• International Collegiate Programming Contest. One of the longest running- this started in 1970 at Texas A&M and has been run by the ACM since 1989 and has IBM's involvement since 1997. One of the bigger contests it has thousands of teams from universities and colleges competing locally, regionally and ultimately in the a world final. The contest pits teams of three university students against eight or more complex, real-world problems, with a gruelling five-hour deadline.
• The Obfuscated C contest has been running for nearly 20 years. This is done on the internet, with email submissions. All you have to do is write the most obscure or obfuscated Ansi C program in under 4096 characters length according to the rules. The 19th contest took place back in January/February 2007.
• The Loebner Prize is not a general programming contest but an AI challenge to enter a computer program that can do the Turing test, ie talk to a human sufficiently well to make the judges believe they are talking to a human. The Judge program, written in Perl will ask questions like "What time is it?", or "What is a hammer?" as well as comparisons and memory. The prize for the best entrant is $2,000 and a Gold Medal.

• Similar to the Loebner Prize is the Chatterbox Challenge. This is to write the best chatter bot- a web based (or downloadable) application written in any language that can carry on text conversations. If it has an animated display that syncs with text then that is even better- you get more points!

• International Problem Solving Contest (IPSC). This is more for fun, with teams of three entering via the web. There are 6 programming problems over a 5 hour period. Any programming language is allowed.

• The Rad Race - Competitors in teams of two have to complete a working business program using any language over two days. This is another contest where you have to bring along equipment, including a router, computer(s), cables, a printer etc. The next one will be in Hasselt, Belgium in October 2007.

• The ImagineCup - Students at school or college compete by writing software applicable to the set theme which for 2008 is "Imagine a world where technology enables a sustainable environment." Entries started August 25th 2007.

• ORTS Competition. ORTS (open real time strategy game) is a programming environment for studying real-time AI problems such as path-finding, dealing with imperfect information, scheduling, and planning in the domain of RTS games. These games are fast-paced and very popular. Using the ORTS software once every year there is a series of battles to see whose AI is best.

• Innovation Challenge. A new challenge that lets you create innovative apps on any platform ( e.g. client application, web-based application, Java application, Facebook App, iPhone App, Android etc in any programming language.

• Google AI Contest 2010. You can enter a C++ or C# Bot to play in a two-player Snake, where your objective is to box in your opponent and make him crash into a wall or his own tail before you do! It's based on the film Tron from the 1980s.
Continuous or Ongoing Contests
• Project Euler. This is an ongoing series of challenging mathematical/computer programming problems that will require more than just mathematical insights to solve. computationally the problems should be solvable in less than a minute. A typical problem is "Find the first ten digits of the sum of one-hundred 50-digit numbers."

• Sphere Online Judge. Run at Gdansk University of Technology in Poland, they have regular programming contests - with over 125 completed. Solutions are submitted to an automatic online judge that can deal with C, C++ and C# 1.0 and many other languages.

• Intel's Threading Programming Problems. Running from September 2007 until the end of September 2008 Intel have their own Programming Challenge with 12 programming tasks, one per month that can be solved by threading. You get awarded points for solving a problem, coding elegance, code execution timing, use of the Intel Threading Building Blocks and bonus points for posting in their problem set discussion forum. Any language but C++ is probably the preferred language.

• Codechef is India's first, non-commercial, multi-platform online coding competition, with monthly contests in more than 35 different programming languages including C, C++ and C#. Winners of each contest get prizes, peer recognition and an invitation to compete at the CodeChef Cup, an annual live event.

No prizes but you get fame!
http://cplus.about.com/od/glossary/a/ten-contests.htm

C - C++ - Programming URls

http://blogs.blackberry.com/

http://cplus.about.com/od/glossar1/Glossary_of_Programming_Terms.htm

http://www.preseps.com/shell-programming.html

www.codeguru.com



Videos on C ++

http://code.google.com/intl/ja/edu/languages/index.html



http://www.wlap.org/cern/lectures/tech/c/00/

http://www.wlap.org/cern/lectures/tech/c/00/

http://www.wlap.org/cern/lectures/tech/c/02

http://www.wlap.org/cern/lectures/tech/c/02b

http://www.wlap.org/cern/lectures/tech/c/03

http://www.wlap.org/cern/lectures/tech/c/04/

http://www.wlap.org/cern/lectures/tech/c/05b

http://www.wlap.org/cern/lectures/tech/c/06

http://www.wlap.org/cern/lectures/tech/c/06b

http://www.wlap.org/cern/lectures/tech/c/07

http://www.wlap.org/cern/lectures/tech/c/07b


more to come , so kindly keep visiting !

Saurav Banerjee ,Ranchi

C Language :

http://cyclone.thelanguage.org/wiki/Download
http://cyclone.thelanguage.org/wiki/User%20Manual
http://www.mhprofessional.com/downloads/products/0072226803/0072226803_ch01.pdf
http://www.exciton.cs.rice.edu/CppResources/syntax/AppendixA.pdf
http://upload.wikimedia.org/wikibooks/en/f/f8/C_programming.pdf
http://www.fujitsu.com/downloads/MICRO/fme/displaycontrollers/sm-api-rev1-30.pdf
http://ftp.sas.com/techsup/download/SASC/share5958-59/S5959v2.pdf
http://www.dei.isep.ipp.pt/~jsantos/Disciplinas/EstInf/Docs/cplusplus-tutorial.pdf
http://www.cs.uiowa.edu/~rus/Courses/SysSoft/tutorC.pdf
http://www.atmel.com/dyn/resources/Prod_documents/avr_3_04.pdf
http://www.ericlindsay.com/applix/ctutor.pdf
http://www2.research.att.com/~bs/crc.pdf
http://developer.apple.com/mac/library/documentation/Cocoa/Conceptual/ObjectiveC/ObjC.pdf
http://nrg.cs.ucl.ac.uk/mjh/3005/c-intro.pdf
http://www.fujitsu.com/downloads/MICRO/fme/displaycontrollers/sm-api-rev1-30.pdf
http://www.chris-lott.org/resources/cstyle/Peter_CStyleGuide.pdf
http://faculty.tp.devry.edu/~schen/technical/pic1618/MPLAB_IDE_Tutorial.pdf
http://www.literateprogramming.com/dssguide.pdf
http://www.intelitekdownloads.com/easyCPRO/tutorial.pdf
http://www.cgl.uwaterloo.ca/~wmcowan/teaching/cs349/w05/tutorials/s1.pdf
http://www.literateprogramming.com/ftsguide.pdf
http://www.swig.org/papers/PyTutorial98/PyTutorial98.pdf
http://www.openmp.org/mp-documents/cspec20.pdf
http://www.openmp.org/mp-documents/cspec20.pdf
http://www.4shared.com/file/156960502/a82488a2/01Introducing_C-C_Language_Video_Tutorials_.html/ on http://www.4shared.com/file/156961871/ce08bbe9/02First_Steps-C_Language_Video_Tutorials_.html/
http://www.4shared.com/file/156962444/8ee04a2f/03Types_-_Operators__Expressions-C_Language_Video_Tutorials_.html
http://www.4shared.com/file/156963016/a22c10ff/04Control_Flow-C_Language_Video_Tutorials_.html
http://www.4shared.com/file/156964129/85ab0c23/05Functions__Program_Structure-C_Language_Video_Tutorials_.html
http://www.4shared.com/file/156965141/659644f2/06Pointers__Arrays-C_Language_Video_Tutorials_.html

DENNIS RITCHIE

OBSD

DEVELOPING

MICROSOFT TEAM


THE MICROSOFT TEAM

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS RITCHIE

DENNIS"S CONTRIBUTIONS

DENNIS RITCHIE AND OTHERS

EXpert Opinions : by Dennis Ritchie, James Gosling and Bjaurn Stroustrup

The C Family of Languages:

The C family of languages--C, C++, and Java--has dominated commercial programming for over 30 years. Today, all three languages are at a turning point:
o The second ISO/ANSI C standard has just been published (C99 was officially released in December 1999). C continues to be one of the most influential languages in the world, particularly in the field of embedded systems.
o The first official update to the ISO/ANSI C++ standard will be completed in October 2000. C++ is one of the most widely used commercial programming languages in the world, with unparalleled support for both object-oriented and generic programming, and continues to experience steady growth.
o Java popularity continues to grow in various areas, from client-side to server-side programming. Sun has recently decided that Java can best flourish as a de facto standard, instead of as a formal ISO/ANSI or ECMA standard, and has abandoned formal standardization efforts.
What has made the C family of languages so dominant?


Q: Why has the C family of languages become so successful and so widely used?

The use of C, was during early times (meaning the '70s and much of the '80s) considerably encouraged by its use as the lingua franca of Unix during the period that Unix was growing in the research and academic community, and then when Unix was taken up as the software basis for the workstation industry of the '80s. There were also technical and semi-technical aspects: the language turned out to be well-placed both for describing things at a high enough level so that portability across hardware was feasible, but simple enough in its requirements to make it cheap to implement.
C and C++ became popular because they were flexible, cheap, and more efficient than alternatives. C++ owes much of its initial popularity to its high degree of compatibility with C.
It was very important success of C and C++ that AT&T didn't try to monopolize these languages, but allowed its researchers to support the creation of alternative implementations. Also, AT&T fully supported ANSI and ISO standardization of C and C++ as soon as these efforts started.
Java is a very different design from the other two languages and appears to have a very different philosophy.
Just to remind people: Both C and C++ were invented in the Computer Science Research Center of Bell Labs in Murray Hill and found their initial serious use within Bell Labs and AT&T.
Among technical factors, C and C++ benefited from their closeness to machine and absence of artificial restrictions on what can be expressed. That allows low-level systems work to be done in these languages and for the full performance of a machine to be delivered to its users. Java benefited from running in its own virtual machine and from coming with a large set of libraries that decrease the time needed for a programmer to become productive. Unix gave a similar boost to C. In contrast, the C++ world suffers from fragmentation of its huge base of libraries, many of which are proprietary and supplied by competing vendors.
C++ was a language where I could write programs that were as elegant as Simula programs, yet as efficient as C programs.
The object-oriented facilities from Simula helped with the former, and the systems-programming facilities of C with the latter.
Like C, Java's goals were really around being able to build relatively specific kinds of software.
For example, one of the differences between Java and C is that Java has real arrays and the arrays get bounds-checked, and that turns out to be important for both reliability and security. If you look at the history of security breaches on the Internet, some really large fraction of them are exploiting buffer overflows, statically allocated arrays that people just go over the end of. If you look at logs of bug-fixing that people go through, it ends up being that memory integrity issues are a huge fraction of where the problems come from.
C haven't changed much in many years, and I haven't been a central player in the changes in either the 1989 or 1999 standards.
C++ haven’t changed much, still good for serious systems programming -- including work at the machine level and on resource-constrained systems .
The major shift in emphasis/style comes from finally having templates and exceptions available.
where everything is flexible and everything is dynamic, and static languages like C, where everything is statically precompiled. Java is kind of in this netherworld in between them, and given the way the world has evolved to become even more networked than before, even more conscious of security issues.
Probably the oddest aspect of C compared with other languages outside its immediate family is the declaration syntax, in which (in a way coming from Fortran) a type is mentioned, then variables decorated in a way that reflects their use in expressions.
A closely related aspect is the treatment of arrays and pointers.
C and C++ communities benefit from a genuine degree of compatibility. Also, much of work on the non-abstraction areas of C++ has been fed back into Standard C. Examples are function declarations/prototypes, const (Dennis also had a hand in their design), declarations wherever statements can appear, and the // comments.
A lot of the design of interfaces was borrowed pretty straightforwardly from Objective C, and it's got some pluses and minuses and it was a real tough balancing act.


Q: Did you ever add features that your users didn't appreciate as much as you did, and then have to deprecate or remove them later? What did you learn from the experience?


Ritchie: I added some things under some pressure from users that I don't think were done well. Enumeration types are a bit odd, bitfields are odder. The "static" keyword is very strange, expressing both a storage lifetime and what the standard calls "linkage" (external visibility). There are many odd bits here and there.
I can't remember features I added that I had to remove except for some tiny bits, like the "entry" keyword. I clearly wish I could have done something about the C declaratory syntax.
In addition, Having had templates integral to the language early on would have helped many use C++ better.
Stroustrup: When I designed C with Classes and C++, I was very keen on the idea that a class defined the environment in which the code of its member functions operate (I still am). This led to the notion of constructors that establish that environment (invariant) and acquire the resources needed. Destructors reverse that process (releasing resources).
Based on that line of thinking, C with Classes also allowed you to define a call() function that was called before entry into a member function and a return() function that was called after exit from a member function. The call()/return() mechanism was meant to allow a programmer to manage resources needed for an individual member function invocation. This allowed me to implement monitors for the first task library. A task's call() grabbed a lock and its matching return() released the lock. The idea came partly from Lisp's :before and :after methods. However, the notion wasn't perfectly general -- for example, you couldn't access arguments for a member function call from call(). Worse, I completely failed to convince people of the usefulness of this notion, so I removed call() and return() when I defined C++.
I recently revisited this issue and I wrote a template -- in Standard C++ -- that wraps calls to an object by arbitrary prefix and suffix.

There are some things that I kind of feel torn about, like operator overloading. I left out operator overloading as a fairly personal choice because I had seen too many people abuse it in C++.

Q: In your experience, what are the most common mistakes developers make in [C/C++/Java]?

Ritchie: I don't really know the answer to this question. I would suppose that the low-level mistakes have to do with type errors, and especially with array subscript and pointer references
C itself does very little to help you here; you have to design a scheme.
Stroustrup: Using C++ just as if it was C or Smalltalk. That leads to seriously suboptimal C++. To use C++ well, you have to adopt some native C++ styles. These tend to be distinguished by small concrete classes and templates. A programming style that is overly influenced by C tends to use a lot of arrays, clever pointer manipulation, casts, and macros rather than standard library facilities (such as vectors, strings, and maps). A programming style that is overly influenced by Smalltalk tries to cram every class into a hierarchy and to overuse casts (and often macros). In either case, key abstractions tend to disappear in a mess of implementation details and people get themselves (unnecessarily) tied in knots with allocation, pointers, casts, and macros.
One common mistake that particularly annoys me is the use of complicated base classes with lots of data members as part of interfaces offered to application builders (users). Abstract base classes make much better interfaces to services. I have tried to root out such misuses for well over ten years: I added abstract classes in 1989 after failing to get the idea across without the support of an explicit language feature.


The idea is really simple:
class interface { // seen by users
// pure virtual functions
};
class my_implementation : public interface {
// data
// functions
// overriding functions
};
When user code sees only "interface," it is immune to changes to "my_implementation."
If common data structures or operations are needed for implementations they can be added in a base class that is visible only to implementers:
class common { // seen by implementers
// data
// functions
};
class my_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
class your_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
This is one of the simplest and most fundamental uses of multiple inheritance.
What many people need to get much more out of C++ is not new features, it is simply a more appropriate design and programming style.
Gosling: Probably the most pervasive mistake is not doing a tasteful job of object-oriented programming. There are these people who don't understand it at all, who just do some procedural kind of stuff and write their program as one huge class with a lot of methods in it; they try to do it in a C style. Then there are the people who go, "Ooo, objects! They're cool! Let's make gazillions of them!"

Q: In your experience, how long does it take for a novice programmer to become a reasonably proficient [C/C++/Java] developer ?

Ritchie: I don't know the answer to this question either--my stock joke on similar ones is, "Well, I never had to learn C...."
Stroustrup: That depends critically on the background of the novice, on the complexity of the task first attempted with C++, and on the teaching/learning approach.
For a novice programmer, a year and a half seems appropriate; for a programmer who is a novice to C++ and the techniques it supports half a year seems more likely.
I consider good libraries essential to provide a smooth learning curve and to properly sequence the learning of C++ concepts. For example, having the C++ standard library available makes it possible to learn the basic type, scope, and control structure concepts without having to deal with arrays, pointers, and memory management at the same time. Such fundamental, yet low-level concepts are best learned a bit later.
This is dangerous. In this context, it is a strength C++ (and of C) that the standard libraries usually are implemented in the language itself using only the facilities available to every programmer.
Gosling: The language itself tends to be a snap to learn; it's all the library stuff that takes the time, and there the best way to do it is to just start writing and using it, and when you need something, look for it.
C didn't come until later just because it's so easy to do goofy things in C; it's so easy to have an array and write "for( i = 1; i <= length; ... )" and you have to explain, "no, it's not less than or equal to length and it's not 1, it's 0 and it's less than." But of course your loop runs just fine, only maybe sometimes you'll discover that you smack the malloc header of the block immediately following the array and nobody's ever told you about that.
That's just so incredibly common in C and C++ or any language that doesn't have a really strict memory model.

Q: Are there any important features missing from the C family of languages? From [C/C++/Java]?

Stroustrup: In which sense do C, C++, and Java constitute a family of languages? C and C++ has a large common subset, and over the years serious efforts have been made to minimize the inevitable tendency of the two languages to drift apart because they are controlled by separate standards bodies. Java, however, provides no real compatibility, and similar syntactic constructs have semantics different from the C and C++ versions. Clearly, Java borrows from C and C++, but under the skin, the similarities to Modula-3 seem greater.
Undoubtedly, all three languages could be significantly improved by addition. However, I see little reason to believe that there is a single major feature that would help all three languages.
Gosling: One of the things that always bugged me about C was the weak memory model, the fact that you could cast a pointer to a character into a pointer to an integer; it just did weird things. But then you change that and it's not C any more, it's basically Java.
The other is type polymorphism, something like templates, and Java actually has something like a poor man's template system right now in that the type hierarchy has a common root for anything and everything, namely Object, but there's also a group working on doing a proper job of type polymorphism in Java. It turns out to be a really hard problem. Other issues are clearer: garbage collection is a good idea; goto is a bad idea.


Q: What things would you like to see become a part of [C/C++/Java] in the next 2-5 years? In the next 10 years? Why?

Ritchie: For C, the new 1999 standard exists but has not become readily available, and it has quite a few changes from the earlier one, though not revolutionary ones.
Stroustrup: I think that the emphasis for C++ evolution should be in library building.
Clearly, many people worry about concurrency and about interfaces to various systems (e.g. GUI, databases, operating systems, other languages, component models). This is [the] most likely area of work and creating and maintaining consistency will be the major challenge. For example, it will be important to provide a consistent view of text from C++. Having some interfaces use C-style strings, others the standard library string, and yet others notions of strings derived from the systems being interfaced to is a recipe for chaos.

Q: Is there room and/or market demand for a new language in the C family?

Ritchie: It's a little hard to imagine a language that's almost like C but enough better to displace it.
Stroustrup: I think the user community would be best served by a single language providing low level support for systems programming. I think C++ would serve well there and I see no technical problems merging C and C++.
Java doesn't provide support for low-level systems programming so it must rely on other languages (such as assembler, C, or C++). Conversely, for C or C++ to be useful for safe downloading into another machine, we need either hardware support (my preferred long-term solution for all languages), a C++ virtual machine.
So, is there room for another language beyond C, C++, and Java? There is certainly room for more languages.


Q: Which types of applications are well suited for [C/C++/Java]? Which are not?


Stroustrup: C++ has inherent strength in applications with a systems component, especially where there are constraints on resources (such as run time and memory). From that base, C++ provides significant support for organizing larger programs for easier maintenance and evolution.
Gosling: Java is certainly well-suited for anything that involves networks and in places where security is a concern. There are some things that it really was never targeted for, although people are certainly doing them. Writing device drivers tends to be kind of awkward, although it's surprising how many people have gone and done a number of fairly obvious things to make device driver writing in Java more straightforward.


Q: Are languages getting easier or more difficult to learn and use? Do you see any progressive usability trends among C, C++, and Java as those languages have appeared and/or added features over time?

Stroustrup: Languages are getting easier to use. For example, C++ with standard-library facilities (such as string, vector, and algorithms) is far easier to use than C++ using C-style strings, arrays, and C standard library functions to solve the same problems.
Java attempts to restrict programmers to a single style of programming. This makes Java easier to use within that domain, but leads to ugly workarounds when the edges of that style are approached. The need for casting when using Java containers is an obvious example.



Personal Preferences
Q: We all have different reasons why we've chosen to be in the software industry. What was it that drew you to the software field? What makes it cool?


Ritchie: I started out interested in physics, and still maintain an amateur interest in keeping up with what's happening at its edges. Sometime in college and early grad school, I spent a lot of time in theoretical computer science (Turing machines, complexity theory). Meanwhile I also became more fascinated with real computers and, I suppose, the immediacy of the experience they provided: when you write a program, you can see what it does right away. All of these things connect with each other in interesting ways. Being involved with this sort of activity was what motivated me. Somehow I didn't think of what I was doing as joining the Software Industry, although, even in 1968, I guess it was.
Stroustrup: I'm not sure exactly what brought me to computers. I saw computers as a practical and useful outlet for scientific interests. I really like building things. When you build you get feedback from the tools, from the program/system, and from users. That's what pushes the imagination beyond what is obvious and beyond the preconceptions and doctrine of an individual, an academic field, or an organization. I like Kristen Nygaard's notion of programming as a means of understanding something.
Gosling: I don't know what it is about my genetic structure, but I just like to build stuff. In some sense whether I'm building software or building a chair or building dinner -- also known as cooking -- I get a kick out of just creating stuff. One of the things that's nice about software is that you can create just about the most amazingly sophisticated complex things and you can do it fairly quickly. If I was a watchmaker, I'm sure I'd get frustrated with how hard it was to create things with lots of gears and pulleys; and yet, just looking at a good watch, you take off the back and it's just so cool. I don't know why it's cool, it just feels really cool to me. With software you can put as many as gears and cams and whatever in there as you want, and things just get complex. In some sense the thing I like most about software is the thing I end up spending most of my time fighting against, which is complexity.


Q: What was the first programming language you ever used?

Ritchie:Around 1962, I went to a non-course talk about Cobol (by Jean Sammet), and took a course that involved programming both analog computers using a plugboard and writing Univac I machine language (no assembler). Also about this time, I visited the IBM office in Cambridge (MA) and they gave me manuals about Fortran, which I read avidly.
Stroustrup: My first programming language was Algol60 on a GIER computer. The GIER was a 1960s Danish computer with 1K 42 bit (I think, plus a few extra bits for hardware testing) words.
Gosling: The first programming language I ever used was a language called Focal 5. Focal stood for "formula calculi." It was a scripting language for PDP-8's. I wrote most of my earliest programs using Focal 5. It's a language whose complete compiler and runtime system can be implemented in under 24 hours. It's actually a nice little language, way simpler than Basic.

Q: What languages, or features of languages, inspired you?


Stroustrup: In addition to Simula67, my favorite language at the time was Algol68. I think that "Algol68 with Classes" would have been a better language than "C with Classes."
Gosling: Lisp, the thing that influenced me the most was the incredible difference garbage collection made. Using Simula and being a local maintainer of the Simula compiler was really what introduced me to objects and got me thinking about objects. Using languages like Pascal got me really thinking about modeling. Languages like Modula-3 really pushed things like exception mechanisms. I've used a lot of languages, and a lot of them have been influential. You can go through everything in Java and say, "this came from there, and this came from there."

Q: What was the first program you ever wrote? On what hardware?


Ritchie:The first on a real computer was the Univac I program. (As I learned a year or so later, the exercise was in fact to implement some of the APL operators--Iverson was around then).
Stroustrup: I don't recall, but it must have been some computer science 101 exercise in Algol60 on a GIER computer. The first programs that I did for real -- that is, for others to use -- were business programs written in assembler for Burroughs office computers. I financed most of my Danish masters degree that way.

Q: Is there a programming language that is the best choice for all (or nearly all) application development? If yes, which language is it, and what makes it best? If not, what would it take to create such a language?


Ritchie: No, this is silly.

Stroustrup: No. People differ too much for that and their applications differ too much. The notion of a perfect and almost perfect language is the dream of immature programmers and marketeers. Naturally, every language designer tries both to strengthen his language to better serve its core community and to broaden its appeal, but being everything to everybody is not a reasonable ideal. There are genuine design choices and tradeoffs that must be made.

Q: Programmers often talk about the advantages and disadvantages of programming in a "simple language." What does that phrase mean to you, and is [C/C++/Java] a simple language in your view?


Ritchie: C (and the others for that matter) are simple in some ways, though they are also subtle; other, somewhat similar languages like Pascal are arguably simpler. What has become clear is that aspects of the environment like libraries that aren't part of the core language are much bigger and more complicated.
The 1999 C standard grew hugely more in the library part than in the language; the C++ STL and other things are big; AWT and other things associated with Java are too.
Stroustrup: Notions of "simple:" to be easy to learn, to make it easy to express ideas, and to have a one-to-one correspondence to some form of math. In those terms, none of the three languages is simple. However, once mastered, C and C++ make it easy to express quite complex and advanced ideas.


Q: What topics do you feel are missing from university computer science and engineering programs around the world that would help to improve the quality of software?

Stroustrup: In some well-respected computer science departments, you can graduate without having written any code. That ought not be possible. Nobody should graduate with a degree in computer science or computer engineering without having completed a significant programming project. Code is the base of computing and people without a "feel" for code tend to seriously misjudge what skills, tools, and time are needed to build good systems.


I think reading and writing code should be a significant part of the training of every computer professional. However much we talk about "Computer Science" and "Software Engineering", building systems still has a large practical component relating to reading, writing, and maintaining code.


No, I'm not arguing that we should just teach hacking
I argue for a balance between theoretical and practical skills.
Gosling: People have been getting a pretty good education in the technology; what they tend to not get is a good view of what goes on in an actual engineering organization:

Q: Outside the C family of languages, what language(s) do you like the best? What in particular makes them interesting to you?

Ritchie: I have to admire languages like Lisp. But, just as in the earlier question about a "simple" language, an astonishingly simple language grows in practice into something that can be fearsome.



Stroustrup: Algol68, CLOS, and ML springs to mind. In each case, what attracts me is flexibility and some very elegant code examples.


Q: What are your favorite software-related books?

Ritchie: The works of Kernighan and Pike (separately or collectively) are nice. The software book I enjoyed most is Ben Ross Schneider's Travels in Computerland.
Stroustrup: Brooks' The Mythical Man Month Booch's Object-Oriented Design, and Gamma et.al.'s Design Patterns.


Programming Language Standards
Q: Is it important to have a formal (e.g., ISO/ANSI) standard for a programming language? What are the advantages? The disadvantages?



Ritchie: At some point a formal standard tends to become necessary, particularly for language that evolved informally (certainly C, but also C++ and Java
At the same time, there are disadvantages, in that whatever clear (or cloudy) vision that the original designers might have had ends up colored by whatever strange proposals the participants in the process bring forth. Complication invariably results as a result of the compromises.
Stroustrup: In today's overheated commercial atmosphere it is essential to have a formal standard. Naturally, an ISO standard is not a complete defense, and not all of our languages, libraries, or tools can be standardized. However, without a standard, users are completely at the mercy/whim of their suppliers.
Conformance suites are widely used for ISO C and ISO C++.


Q: Is it important to have a de facto standard for a programming language? What are the advantages? The disadvantages?

Stroustrup: A de facto standard is a major advantage to its owner and its owner's friends/allies. It can also benefit third parties, such as professors, students, and small companies
Gosling: I think that in a strong sense de facto standards are the ones that really matter. It hardly matters what's actually written down in anybody's standards document; what actually matters is what people have actually implemented.

I'm a real fan of Linux; the problem is that there are so many flavors of Linux and they're all just different enough that life is really hard.


The "Century 21" Software Industry
Q: Prognostication is hard, but valuable even if it can never be 100% accurate. In your view, what are the major forces driving the kinds of software we will be writing in the future? and the way we will be writing that software?


Ritchie: The most obvious change that has occurred recently is the increase in use of "scripting languages" that are generally interpreted. These range from the basic ones like HTML to Perl, Tcl/Tk, and Javascript, and then to presentation-graphics packages for making WWW pages or slides.
Stroustrup: The future? these days it is close to impossible to even describe the present.
We have to see more emphasis on correctness, quality, and security.
I really hope 2050s software and systems will be too advanced for me to imagine today, just as a 1950s expert had little chance of predicting today's systems with any accuracy or in any detail.

Notes :

1. B. Kernighan and D. Ritchie. The C Programming Language, 2nd edition (Prentice Hall, 1998) ISBN 0131103709.
2. B. Stroustrup. The Design and Evolution of C++ (Addison-Wesley, 1994) ISBN 0201543303.
3. B. Stroustrup. The C++ Programming Language, Special Edition (Addison-Wesley, 2000) ISBN 0201700735.
4. http://www.research.att.com/~bs.
5. B. Stroustrup. "Wrapping C++ Member Function Calls" (C++ Report, 12(6), June 2000).
6. B. Stroustrup. "Learning Standard C++ as a New Language" (C/C++ Users Journal, May 1999; also in CVu 12(1) January 2000).
7. B. Kernighan and R. Pike. The Practice of Programming (Addison-Wesley, 1999) ISBN 020161586X.
8. B. Kernighan and R. Pike. The UNIX Programming Environment (Prentice Hall, 1984) ISBN 013937681X.
9. B. Kernighan and P.J. Plauger. The Elements of Programming Style (McGraw-Hill, 1988) ISBN 0070342075.
10. B. Schneider. Travels in Computerland: Or, Incompatibilities and Interfaces: A Full and True Account of the Implementation of the London Stage Information Bank, ASIN 0201067374.
11. F. Brooks. The Mythical Man-Month: Essays on Software Engineering (Addison-Wesley, 1995) ISBN 0201835959.
12. G. Booch. Object-Oriented Analysis and Design With Applications (Addison-Wesley, 1994) ISBN 0805353402.
13. E. Gamma, R. Helm, R. Johnson, and J. Vlissides. Design Patterns : Elements of Reusable Object-Oriented Software (Addison-Wesley, 1995) ISBN 0201633612.
14. J. Bentley. Programming Pearls, Second Edition (Addison-Wesley, 1999) ISBN 0201657880.
15. R. Sedgewick. Algorithms in C, 3rd edition (Addison-Wesley, 2000) ISBN 0201849372. (There are at least ten "Algorithms" books by Sedgewick, covering different scopes or specialized for different programming languages. This is one of the most recently written/updated.)
16. A. Koenig and B. Moo. Ruminations on C++ (Addison-Wesley, 1996) ISBN 0201423391.

(Source : Internet )
N.B: This article was trimmed to fit for the theoretical enhancement of various professionals , students and others.



Saurav Banerjee, Ranchi , INFI-NITE .

techinfiniteonline@gmail.com

The C Family of Languages: Experts Opinions by Dennis Ritchie ,Bjaurn Stroustrup ,James Gosling :

The C Family of Languages:

The C family of languages--C, C++, and Java--has dominated commercial programming for over 30 years. Today, all three languages are at a turning point:
o The second ISO/ANSI C standard has just been published (C99 was officially released in December 1999). C continues to be one of the most influential languages in the world, particularly in the field of embedded systems.
o The first official update to the ISO/ANSI C++ standard will be completed in October 2000. C++ is one of the most widely used commercial programming languages in the world, with unparalleled support for both object-oriented and generic programming, and continues to experience steady growth.
o Java popularity continues to grow in various areas, from client-side to server-side programming. Sun has recently decided that Java can best flourish as a de facto standard, instead of as a formal ISO/ANSI or ECMA standard, and has abandoned formal standardization efforts.
What has made the C family of languages so dominant?


Q: Why has the C family of languages become so successful and so widely used?

The use of C, was during early times (meaning the '70s and much of the '80s) considerably encouraged by its use as the lingua franca of Unix during the period that Unix was growing in the research and academic community, and then when Unix was taken up as the software basis for the workstation industry of the '80s. There were also technical and semi-technical aspects: the language turned out to be well-placed both for describing things at a high enough level so that portability across hardware was feasible, but simple enough in its requirements to make it cheap to implement.
C and C++ became popular because they were flexible, cheap, and more efficient than alternatives. C++ owes much of its initial popularity to its high degree of compatibility with C.
It was very important success of C and C++ that AT&T didn't try to monopolize these languages, but allowed its researchers to support the creation of alternative implementations. Also, AT&T fully supported ANSI and ISO standardization of C and C++ as soon as these efforts started.
Java is a very different design from the other two languages and appears to have a very different philosophy.
Just to remind people: Both C and C++ were invented in the Computer Science Research Center of Bell Labs in Murray Hill and found their initial serious use within Bell Labs and AT&T.
Among technical factors, C and C++ benefited from their closeness to machine and absence of artificial restrictions on what can be expressed. That allows low-level systems work to be done in these languages and for the full performance of a machine to be delivered to its users. Java benefited from running in its own virtual machine and from coming with a large set of libraries that decrease the time needed for a programmer to become productive. Unix gave a similar boost to C. In contrast, the C++ world suffers from fragmentation of its huge base of libraries, many of which are proprietary and supplied by competing vendors.
C++ was a language where I could write programs that were as elegant as Simula programs, yet as efficient as C programs.
The object-oriented facilities from Simula helped with the former, and the systems-programming facilities of C with the latter.
Like C, Java's goals were really around being able to build relatively specific kinds of software.
For example, one of the differences between Java and C is that Java has real arrays and the arrays get bounds-checked, and that turns out to be important for both reliability and security. If you look at the history of security breaches on the Internet, some really large fraction of them are exploiting buffer overflows, statically allocated arrays that people just go over the end of. If you look at logs of bug-fixing that people go through, it ends up being that memory integrity issues are a huge fraction of where the problems come from.
C haven't changed much in many years, and I haven't been a central player in the changes in either the 1989 or 1999 standards.
C++ haven’t changed much, still good for serious systems programming -- including work at the machine level and on resource-constrained systems .
The major shift in emphasis/style comes from finally having templates and exceptions available.
where everything is flexible and everything is dynamic, and static languages like C, where everything is statically precompiled. Java is kind of in this netherworld in between them, and given the way the world has evolved to become even more networked than before, even more conscious of security issues.
Probably the oddest aspect of C compared with other languages outside its immediate family is the declaration syntax, in which (in a way coming from Fortran) a type is mentioned, then variables decorated in a way that reflects their use in expressions.
A closely related aspect is the treatment of arrays and pointers.
C and C++ communities benefit from a genuine degree of compatibility. Also, much of work on the non-abstraction areas of C++ has been fed back into Standard C. Examples are function declarations/prototypes, const (Dennis also had a hand in their design), declarations wherever statements can appear, and the // comments.
A lot of the design of interfaces was borrowed pretty straightforwardly from Objective C, and it's got some pluses and minuses and it was a real tough balancing act.


Q: Did you ever add features that your users didn't appreciate as much as you did, and then have to deprecate or remove them later? What did you learn from the experience?


Ritchie: I added some things under some pressure from users that I don't think were done well. Enumeration types are a bit odd, bitfields are odder. The "static" keyword is very strange, expressing both a storage lifetime and what the standard calls "linkage" (external visibility). There are many odd bits here and there.
I can't remember features I added that I had to remove except for some tiny bits, like the "entry" keyword. I clearly wish I could have done something about the C declaratory syntax.
In addition, Having had templates integral to the language early on would have helped many use C++ better.
Stroustrup: When I designed C with Classes and C++, I was very keen on the idea that a class defined the environment in which the code of its member functions operate (I still am). This led to the notion of constructors that establish that environment (invariant) and acquire the resources needed. Destructors reverse that process (releasing resources).
Based on that line of thinking, C with Classes also allowed you to define a call() function that was called before entry into a member function and a return() function that was called after exit from a member function. The call()/return() mechanism was meant to allow a programmer to manage resources needed for an individual member function invocation. This allowed me to implement monitors for the first task library. A task's call() grabbed a lock and its matching return() released the lock. The idea came partly from Lisp's :before and :after methods. However, the notion wasn't perfectly general -- for example, you couldn't access arguments for a member function call from call(). Worse, I completely failed to convince people of the usefulness of this notion, so I removed call() and return() when I defined C++.
I recently revisited this issue and I wrote a template -- in Standard C++ -- that wraps calls to an object by arbitrary prefix and suffix.

There are some things that I kind of feel torn about, like operator overloading. I left out operator overloading as a fairly personal choice because I had seen too many people abuse it in C++.

Q: In your experience, what are the most common mistakes developers make in [C/C++/Java]?

Ritchie: I don't really know the answer to this question. I would suppose that the low-level mistakes have to do with type errors, and especially with array subscript and pointer references
C itself does very little to help you here; you have to design a scheme.
Stroustrup: Using C++ just as if it was C or Smalltalk. That leads to seriously suboptimal C++. To use C++ well, you have to adopt some native C++ styles. These tend to be distinguished by small concrete classes and templates. A programming style that is overly influenced by C tends to use a lot of arrays, clever pointer manipulation, casts, and macros rather than standard library facilities (such as vectors, strings, and maps). A programming style that is overly influenced by Smalltalk tries to cram every class into a hierarchy and to overuse casts (and often macros). In either case, key abstractions tend to disappear in a mess of implementation details and people get themselves (unnecessarily) tied in knots with allocation, pointers, casts, and macros.
One common mistake that particularly annoys me is the use of complicated base classes with lots of data members as part of interfaces offered to application builders (users). Abstract base classes make much better interfaces to services. I have tried to root out such misuses for well over ten years: I added abstract classes in 1989 after failing to get the idea across without the support of an explicit language feature.


The idea is really simple:
class interface { // seen by users
// pure virtual functions
};
class my_implementation : public interface {
// data
// functions
// overriding functions
};
When user code sees only "interface," it is immune to changes to "my_implementation."
If common data structures or operations are needed for implementations they can be added in a base class that is visible only to implementers:
class common { // seen by implementers
// data
// functions
};
class my_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
class your_implementation : public interface, protected common {
// data
// functions
// overriding functions
};
This is one of the simplest and most fundamental uses of multiple inheritance.
What many people need to get much more out of C++ is not new features, it is simply a more appropriate design and programming style.
Gosling: Probably the most pervasive mistake is not doing a tasteful job of object-oriented programming. There are these people who don't understand it at all, who just do some procedural kind of stuff and write their program as one huge class with a lot of methods in it; they try to do it in a C style. Then there are the people who go, "Ooo, objects! They're cool! Let's make gazillions of them!"

Q: In your experience, how long does it take for a novice programmer to become a reasonably proficient [C/C++/Java] developer ?

Ritchie: I don't know the answer to this question either--my stock joke on similar ones is, "Well, I never had to learn C...."
Stroustrup: That depends critically on the background of the novice, on the complexity of the task first attempted with C++, and on the teaching/learning approach.
For a novice programmer, a year and a half seems appropriate; for a programmer who is a novice to C++ and the techniques it supports half a year seems more likely.
I consider good libraries essential to provide a smooth learning curve and to properly sequence the learning of C++ concepts. For example, having the C++ standard library available makes it possible to learn the basic type, scope, and control structure concepts without having to deal with arrays, pointers, and memory management at the same time. Such fundamental, yet low-level concepts are best learned a bit later.
This is dangerous. In this context, it is a strength C++ (and of C) that the standard libraries usually are implemented in the language itself using only the facilities available to every programmer.
Gosling: The language itself tends to be a snap to learn; it's all the library stuff that takes the time, and there the best way to do it is to just start writing and using it, and when you need something, look for it.
C didn't come until later just because it's so easy to do goofy things in C; it's so easy to have an array and write "for( i = 1; i <= length; ... )" and you have to explain, "no, it's not less than or equal to length and it's not 1, it's 0 and it's less than." But of course your loop runs just fine, only maybe sometimes you'll discover that you smack the malloc header of the block immediately following the array and nobody's ever told you about that.
That's just so incredibly common in C and C++ or any language that doesn't have a really strict memory model.

Q: Are there any important features missing from the C family of languages? From [C/C++/Java]?

Stroustrup: In which sense do C, C++, and Java constitute a family of languages? C and C++ has a large common subset, and over the years serious efforts have been made to minimize the inevitable tendency of the two languages to drift apart because they are controlled by separate standards bodies. Java, however, provides no real compatibility, and similar syntactic constructs have semantics different from the C and C++ versions. Clearly, Java borrows from C and C++, but under the skin, the similarities to Modula-3 seem greater.
Undoubtedly, all three languages could be significantly improved by addition. However, I see little reason to believe that there is a single major feature that would help all three languages.
Gosling: One of the things that always bugged me about C was the weak memory model, the fact that you could cast a pointer to a character into a pointer to an integer; it just did weird things. But then you change that and it's not C any more, it's basically Java.
The other is type polymorphism, something like templates, and Java actually has something like a poor man's template system right now in that the type hierarchy has a common root for anything and everything, namely Object, but there's also a group working on doing a proper job of type polymorphism in Java. It turns out to be a really hard problem. Other issues are clearer: garbage collection is a good idea; goto is a bad idea.


Q: What things would you like to see become a part of [C/C++/Java] in the next 2-5 years? In the next 10 years? Why?

Ritchie: For C, the new 1999 standard exists but has not become readily available, and it has quite a few changes from the earlier one, though not revolutionary ones.
Stroustrup: I think that the emphasis for C++ evolution should be in library building.
Clearly, many people worry about concurrency and about interfaces to various systems (e.g. GUI, databases, operating systems, other languages, component models). This is [the] most likely area of work and creating and maintaining consistency will be the major challenge. For example, it will be important to provide a consistent view of text from C++. Having some interfaces use C-style strings, others the standard library string, and yet others notions of strings derived from the systems being interfaced to is a recipe for chaos.

Q: Is there room and/or market demand for a new language in the C family?

Ritchie: It's a little hard to imagine a language that's almost like C but enough better to displace it.
Stroustrup: I think the user community would be best served by a single language providing low level support for systems programming. I think C++ would serve well there and I see no technical problems merging C and C++.
Java doesn't provide support for low-level systems programming so it must rely on other languages (such as assembler, C, or C++). Conversely, for C or C++ to be useful for safe downloading into another machine, we need either hardware support (my preferred long-term solution for all languages), a C++ virtual machine.
So, is there room for another language beyond C, C++, and Java? There is certainly room for more languages.


Q: Which types of applications are well suited for [C/C++/Java]? Which are not?


Stroustrup: C++ has inherent strength in applications with a systems component, especially where there are constraints on resources (such as run time and memory). From that base, C++ provides significant support for organizing larger programs for easier maintenance and evolution.
Gosling: Java is certainly well-suited for anything that involves networks and in places where security is a concern. There are some things that it really was never targeted for, although people are certainly doing them. Writing device drivers tends to be kind of awkward, although it's surprising how many people have gone and done a number of fairly obvious things to make device driver writing in Java more straightforward.


Q: Are languages getting easier or more difficult to learn and use? Do you see any progressive usability trends among C, C++, and Java as those languages have appeared and/or added features over time?

Stroustrup: Languages are getting easier to use. For example, C++ with standard-library facilities (such as string, vector, and algorithms) is far easier to use than C++ using C-style strings, arrays, and C standard library functions to solve the same problems.
Java attempts to restrict programmers to a single style of programming. This makes Java easier to use within that domain, but leads to ugly workarounds when the edges of that style are approached. The need for casting when using Java containers is an obvious example.



Personal Preferences
Q: We all have different reasons why we've chosen to be in the software industry. What was it that drew you to the software field? What makes it cool?


Ritchie: I started out interested in physics, and still maintain an amateur interest in keeping up with what's happening at its edges. Sometime in college and early grad school, I spent a lot of time in theoretical computer science (Turing machines, complexity theory). Meanwhile I also became more fascinated with real computers and, I suppose, the immediacy of the experience they provided: when you write a program, you can see what it does right away. All of these things connect with each other in interesting ways. Being involved with this sort of activity was what motivated me. Somehow I didn't think of what I was doing as joining the Software Industry, although, even in 1968, I guess it was.
Stroustrup: I'm not sure exactly what brought me to computers. I saw computers as a practical and useful outlet for scientific interests. I really like building things. When you build you get feedback from the tools, from the program/system, and from users. That's what pushes the imagination beyond what is obvious and beyond the preconceptions and doctrine of an individual, an academic field, or an organization. I like Kristen Nygaard's notion of programming as a means of understanding something.
Gosling: I don't know what it is about my genetic structure, but I just like to build stuff. In some sense whether I'm building software or building a chair or building dinner -- also known as cooking -- I get a kick out of just creating stuff. One of the things that's nice about software is that you can create just about the most amazingly sophisticated complex things and you can do it fairly quickly. If I was a watchmaker, I'm sure I'd get frustrated with how hard it was to create things with lots of gears and pulleys; and yet, just looking at a good watch, you take off the back and it's just so cool. I don't know why it's cool, it just feels really cool to me. With software you can put as many as gears and cams and whatever in there as you want, and things just get complex. In some sense the thing I like most about software is the thing I end up spending most of my time fighting against, which is complexity.


Q: What was the first programming language you ever used?

Ritchie:Around 1962, I went to a non-course talk about Cobol (by Jean Sammet), and took a course that involved programming both analog computers using a plugboard and writing Univac I machine language (no assembler). Also about this time, I visited the IBM office in Cambridge (MA) and they gave me manuals about Fortran, which I read avidly.
Stroustrup: My first programming language was Algol60 on a GIER computer. The GIER was a 1960s Danish computer with 1K 42 bit (I think, plus a few extra bits for hardware testing) words.
Gosling: The first programming language I ever used was a language called Focal 5. Focal stood for "formula calculi." It was a scripting language for PDP-8's. I wrote most of my earliest programs using Focal 5. It's a language whose complete compiler and runtime system can be implemented in under 24 hours. It's actually a nice little language, way simpler than Basic.

Q: What languages, or features of languages, inspired you?


Stroustrup: In addition to Simula67, my favorite language at the time was Algol68. I think that "Algol68 with Classes" would have been a better language than "C with Classes."
Gosling: Lisp, the thing that influenced me the most was the incredible difference garbage collection made. Using Simula and being a local maintainer of the Simula compiler was really what introduced me to objects and got me thinking about objects. Using languages like Pascal got me really thinking about modeling. Languages like Modula-3 really pushed things like exception mechanisms. I've used a lot of languages, and a lot of them have been influential. You can go through everything in Java and say, "this came from there, and this came from there."

Q: What was the first program you ever wrote? On what hardware?


Ritchie:The first on a real computer was the Univac I program. (As I learned a year or so later, the exercise was in fact to implement some of the APL operators--Iverson was around then).
Stroustrup: I don't recall, but it must have been some computer science 101 exercise in Algol60 on a GIER computer. The first programs that I did for real -- that is, for others to use -- were business programs written in assembler for Burroughs office computers. I financed most of my Danish masters degree that way.

Q: Is there a programming language that is the best choice for all (or nearly all) application development? If yes, which language is it, and what makes it best? If not, what would it take to create such a language?


Ritchie: No, this is silly.

Stroustrup: No. People differ too much for that and their applications differ too much. The notion of a perfect and almost perfect language is the dream of immature programmers and marketeers. Naturally, every language designer tries both to strengthen his language to better serve its core community and to broaden its appeal, but being everything to everybody is not a reasonable ideal. There are genuine design choices and tradeoffs that must be made.

Q: Programmers often talk about the advantages and disadvantages of programming in a "simple language." What does that phrase mean to you, and is [C/C++/Java] a simple language in your view?


Ritchie: C (and the others for that matter) are simple in some ways, though they are also subtle; other, somewhat similar languages like Pascal are arguably simpler. What has become clear is that aspects of the environment like libraries that aren't part of the core language are much bigger and more complicated.
The 1999 C standard grew hugely more in the library part than in the language; the C++ STL and other things are big; AWT and other things associated with Java are too.
Stroustrup: Notions of "simple:" to be easy to learn, to make it easy to express ideas, and to have a one-to-one correspondence to some form of math. In those terms, none of the three languages is simple. However, once mastered, C and C++ make it easy to express quite complex and advanced ideas.


Q: What topics do you feel are missing from university computer science and engineering programs around the world that would help to improve the quality of software?

Stroustrup: In some well-respected computer science departments, you can graduate without having written any code. That ought not be possible. Nobody should graduate with a degree in computer science or computer engineering without having completed a significant programming project. Code is the base of computing and people without a "feel" for code tend to seriously misjudge what skills, tools, and time are needed to build good systems.


I think reading and writing code should be a significant part of the training of every computer professional. However much we talk about "Computer Science" and "Software Engineering", building systems still has a large practical component relating to reading, writing, and maintaining code.


No, I'm not arguing that we should just teach hacking
I argue for a balance between theoretical and practical skills.
Gosling: People have been getting a pretty good education in the technology; what they tend to not get is a good view of what goes on in an actual engineering organization:

Q: Outside the C family of languages, what language(s) do you like the best? What in particular makes them interesting to you?

Ritchie: I have to admire languages like Lisp. But, just as in the earlier question about a "simple" language, an astonishingly simple language grows in practice into something that can be fearsome.



Stroustrup: Algol68, CLOS, and ML springs to mind. In each case, what attracts me is flexibility and some very elegant code examples.


Q: What are your favorite software-related books?

Ritchie: The works of Kernighan and Pike (separately or collectively) are nice. The software book I enjoyed most is Ben Ross Schneider's Travels in Computerland.
Stroustrup: Brooks' The Mythical Man Month Booch's Object-Oriented Design, and Gamma et.al.'s Design Patterns.


Programming Language Standards
Q: Is it important to have a formal (e.g., ISO/ANSI) standard for a programming language? What are the advantages? The disadvantages?



Ritchie: At some point a formal standard tends to become necessary, particularly for language that evolved informally (certainly C, but also C++ and Java
At the same time, there are disadvantages, in that whatever clear (or cloudy) vision that the original designers might have had ends up colored by whatever strange proposals the participants in the process bring forth. Complication invariably results as a result of the compromises.
Stroustrup: In today's overheated commercial atmosphere it is essential to have a formal standard. Naturally, an ISO standard is not a complete defense, and not all of our languages, libraries, or tools can be standardized. However, without a standard, users are completely at the mercy/whim of their suppliers.
Conformance suites are widely used for ISO C and ISO C++.


Q: Is it important to have a de facto standard for a programming language? What are the advantages? The disadvantages?

Stroustrup: A de facto standard is a major advantage to its owner and its owner's friends/allies. It can also benefit third parties, such as professors, students, and small companies
Gosling: I think that in a strong sense de facto standards are the ones that really matter. It hardly matters what's actually written down in anybody's standards document; what actually matters is what people have actually implemented.

I'm a real fan of Linux; the problem is that there are so many flavors of Linux and they're all just different enough that life is really hard.


The "Century 21" Software Industry
Q: Prognostication is hard, but valuable even if it can never be 100% accurate. In your view, what are the major forces driving the kinds of software we will be writing in the future? and the way we will be writing that software?


Ritchie: The most obvious change that has occurred recently is the increase in use of "scripting languages" that are generally interpreted. These range from the basic ones like HTML to Perl, Tcl/Tk, and Javascript, and then to presentation-graphics packages for making WWW pages or slides.
Stroustrup: The future? these days it is close to impossible to even describe the present.
We have to see more emphasis on correctness, quality, and security.
I really hope 2050s software and systems will be too advanced for me to imagine today, just as a 1950s expert had little chance of predicting today's systems with any accuracy or in any detail.

Notes :

1. B. Kernighan and D. Ritchie. The C Programming Language, 2nd edition (Prentice Hall, 1998) ISBN 0131103709.
2. B. Stroustrup. The Design and Evolution of C++ (Addison-Wesley, 1994) ISBN 0201543303.
3. B. Stroustrup. The C++ Programming Language, Special Edition (Addison-Wesley, 2000) ISBN 0201700735.
4. http://www.research.att.com/~bs.
5. B. Stroustrup. "Wrapping C++ Member Function Calls" (C++ Report, 12(6), June 2000).
6. B. Stroustrup. "Learning Standard C++ as a New Language" (C/C++ Users Journal, May 1999; also in CVu 12(1) January 2000).
7. B. Kernighan and R. Pike. The Practice of Programming (Addison-Wesley, 1999) ISBN 020161586X.
8. B. Kernighan and R. Pike. The UNIX Programming Environment (Prentice Hall, 1984) ISBN 013937681X.
9. B. Kernighan and P.J. Plauger. The Elements of Programming Style (McGraw-Hill, 1988) ISBN 0070342075.
10. B. Schneider. Travels in Computerland: Or, Incompatibilities and Interfaces: A Full and True Account of the Implementation of the London Stage Information Bank, ASIN 0201067374.
11. F. Brooks. The Mythical Man-Month: Essays on Software Engineering (Addison-Wesley, 1995) ISBN 0201835959.
12. G. Booch. Object-Oriented Analysis and Design With Applications (Addison-Wesley, 1994) ISBN 0805353402.
13. E. Gamma, R. Helm, R. Johnson, and J. Vlissides. Design Patterns : Elements of Reusable Object-Oriented Software (Addison-Wesley, 1995) ISBN 0201633612.
14. J. Bentley. Programming Pearls, Second Edition (Addison-Wesley, 1999) ISBN 0201657880.
15. R. Sedgewick. Algorithms in C, 3rd edition (Addison-Wesley, 2000) ISBN 0201849372. (There are at least ten "Algorithms" books by Sedgewick, covering different scopes or specialized for different programming languages. This is one of the most recently written/updated.)
16. A. Koenig and B. Moo. Ruminations on C++ (Addison-Wesley, 1996) ISBN 0201423391.

(Source : Internet )
N.B: This article was trimmed to fit for the theoretical enhancement of various professionals , students and others.



Saurav Banerjee, Ranchi , INFI-NITE .

techinfiniteonline@gmail.com

1985


THE FAMILY OF GENIUSES :

DMR


DMR : DENNIS RITCHIE

KEN THOMPSON

DENNIS RITCHIE

Bell Labs Early Contributions to Computer Science

1937
G.R. Stibitz designs the first binary relay calculator.
1939
G. R. Stibitz and E.G. Andrews build the first electric computer for routine use, the Bell Labs Model I relay computer.
1939
S. B. Wright and E. R. Taylor develop an analog adder that used the algebraic sum of the route-mean-square values of several wave forms to control transatlantic radiotelephone facilities.
1940
C.A. Lovell and D.B. Parkinson develop an analog computer to control aircraft guns.
1941-42
A.W. Horton invents the AND gate diode logic circuit, and the next year W.H.T. Holden invents the OR gate.
1942
Based on Lovell and Parkinson's work, Bell Labs develops the analog M-9 gun director for the U.S. Army.
1943-45
Each year saw the introduction of the Bell Labs Model II, Model III and Model IV relay computers, respectively, that remained in service for 13-15 years.
1943
G.R. Stibitz first uses error-correcting codes in his Bell Labs Model II computer.
1946
The first of the Model Vs is delivered to the U.S. National Advisory Committee for Aeronautics at Langley Field, Va.
1947
J. Bardeen, W.H. Brattain and W. Shockley invent the transistor.
1948
R.W. Hamming shows a systematic and optimal way to make correctable any single-bit error in a block of data.
1948
Claude Shannon develops his Information Theory, which determines how much information can be sent per unit of time in a system with a given, limited amount of transmission power.
1959
D.W. Hagelbarger develops error-correcting codes to cope with bursts of errors.
1949
E. Lakatos develops the general purpose analog computer (GPAC), nicknamed Gypsy.
1949
W.H. MacWilliams Jr. is probably the first to use transistor circuits as part of a simulated warfare computer.
1950
Bell Labs Model VI relay computer is used for in-house computing. It ran for 15 years.
1950
Develops error-correcting codes for digital transmission over data lines
1952
Develops the general-purpose, all solid-state Transistor Digital Computer.
1956
V.M. Wolontis and D.C. Leagus develop the higher L1 language, later called Bell 1 interpreter. Later R.W. Hamming and R.A. Weiss develop L2. Both were predecessors to a succession of Bell Labs programming languages to make computers easier to use, more productive, and better matched to applications.
1956
Though not using computers, Bell Labs demonstrates that low-speed (600 baud) computer-generated data could be transmitted over normal long distance telephone lines dialed at random.
1959
D. McIlroy and D.E. Eastwood describe how macros can be used to extend any programming language to meet a user's specific needs, anticipating the later use of "pipes" in UNIX.*.
1960
200 Series data modems are developed to support 2,000 b/s on the public switched voice network and 2,400 b/s on private lines networks
1963
Develops ALTRAN, an algebra translator computer language used to drive a package of subroutines for symbolic algebra.
1964
Bell Labs, MIT and General Electric try to develop the Multiplexed Information and Computing Service (Multics), as a successor to BESYS (Bell Operating System) and the Compatible Time-Sharing Service (CTSS) system of MIT. V.A. Vyssotksy coins the term "process" for Multics.
1965
Bell Labs develops the No. 1 Processor for the 1ESS® central office switch, which later evolved into the No. 1A processor for the 1AESS switch.
1966
Develops L6 language, permitting programmers to write in a language closer to machine language.
1968
W.D. Farmer and E.E. Newhall demonstrate an experimental loop system for interconnecting digital devices.
1969
Bell Labs disassociates itself from the Multics project and Kenneth Thompson develops the UNIX operating system.
1970
J.R. Pierce proposes a hierarchical interconnecting loop network for high-speed data communications, with users responsible for their own signaling and error control.
1970
A.G. Fraser begins the construction of Spider, an experimental high-speed packet-switched network of interconnected computers and terminals.
1970
GROOVE composes, stores and edits synthesized music.
1972
UNIX system is supporting word processing in Bell Labs Patent Division and a long distance test room in Charlotte, S.C.; and is handling trouble reports for Pacific Telephone.
1972
One of the early computer-based network maintenance tools, the CAROT (Centralized Reporting on Telephone Trunks) system, is field trialed in the San Francisco Bay area. LMOS (Loop Management Operations System), SARTS (Switched Access Remote Test System) and CMS (Circuit Maintenance System) soon follow.
1973
Dennis M. Ritchie writes the C programming language.
1974
Digital data service (DDS) is introduced, offering end-to-end digital data transport at rates of up to 56 Kb/s, using end user and private line network equipment developed by Bell Labs. The synchronous baseband data network supports point-to-point and multi-point transmission.
1975
UNIX version 6 released to universities.
1975
Western Electric, the predecessor organization to Lucent Technologies, begins external licensing of UNIX.
1975
B.W. Kernighan and L.L. Cherry use YACC (yet another complier-compiler) to write eqn, a natural language for setting mathematics.
1976
B.W. Kernighan and P.J. Plauger popularize the UNIX philosophy of design in their book Software Tools.
1976
BOS11 real-time database management operating system developed for PDP-11.
1976
Bell Labs Interlocation Computing Network permits a user at one site to run a job at a second site, and direct the results to a third site.
1970s
The DATAKIT(TM) virtual circuit switch is developed, based on A.G. Fraser's perfect scheduling algorithm, followed by the ISN packet switch for business applications.
1970s
The StarLAN local area network is developed to provide LAN connectivity over twisted pair wiring at 1 Mb/s and later 10 Mb/s, eliminating the need for coaxial cable connections.
1978
UNIX version 7 released commercially.
1980s
Bell Labs develops the synchronous 6500 series computers; the 3B family of multi-tasking computers; and the asynchronous 615 Business Communications Terminal, the 630 and 730 Multitasking Graphics Terminals, and the 705 Multitasking Terminal.
1981
UNIX System III released commercially.

Bjarne Stroustrup.
1983
Bjarne Stroustrup develops the first version of C++, which combines the expressive power of object-oriented programming (OOP) with the speed, compactness, and flexibility of C, its systems programming language predecessor.
1983
David Korn develops the Korn Shell scripting language for systems experts. It is the basis for large-scale systems.
1983
UNIX System V, Release 1 released commercially.
1984
UNIX System V, Release 2 released commercially.
1984
Narendra Karmarkar invents a software algorithm based on linear programming, known as the Karmarkar algorithm, that is used as an optimization tool for solving complex business and research problems that have a huge number of possible solutions.
1985
The 1PSS packet switch is developed to support virtual circuit or permanent virtual circuit switching at speeds from 4.8 kb/s to 56 kb/s in packets of 1024 bits or 2048 bits.



Rob Pike and Luca Cardelli.
1985
Rob Pike and Luca Cardelli develop a computer language, Squeak, that can be used to program computer mice and other interface devices.
1985
Access equipment and signaling procedures are developed by Bell Labs to permit switched 56 kb/s data through the 4ESS® toll switch, permitting customers to transmit data on a dial-up, as-needed basis to multiple locations without dedicated private lines between those locations.
1992
Bell Labs develops fault tolerant software, an alternative to large mainframe backups, allowing a telecommunications system to "tolerate" hardware faults, and some of the design and coding faults built into them.
1995
Bell Labs introduces Plan 9, a new distributed computer operating system and associated utilities built by the Computing Science Research Center.
1996
Bell Labs then-parent company, AT&T, creates independent Lucent Technologies with Bell Labs as its R&D arm, and removes itself from the computer business by divesting itself of NCR.
Bell Labs contributions to computer communications continues with the emergence of Lucent Technologies in 1996.
 

Lorem ipsum

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Donec libero. Suspendisse bibendum. Cras id urna. Morbi tincidunt, orci ac convallis aliquam, lectus turpis varius lorem, eu posuere nunc justo tempus leo. Donec mattis, purus nec placerat bibendum, dui pede condimentum odio, ac blandit ante orci ut diam.

Images Gallery

pix pix pix pix pix pix