Page 1 of 3
C pros and cons (was: I want to create an OS!!!)
Posted: Sun Jan 27, 2013 3:40 pm
by Love4Boobies
Casm wrote:C is by far the most widely used language in operating systems development; mostly because it was designed for that very purpose.
It was indeed designed for that purpose... in the '70s.
Re: I want to create an OS!!!
Posted: Sun Jan 27, 2013 4:05 pm
by sandras
Love4Boobies wrote:Casm wrote:C is by far the most widely used language in operating systems development; mostly because it was designed for that very purpose.
It was indeed designed for that purpose... in the '70s.
I'm not advocating C, but age does not mean, the thing is bad at what it does. One may even suggest, that the language must be good, if it's in the field for such a long time. Though, personally, I'd say, we tend to accumulate legacy technology simply because there's not enough momentum for a change, not because there are no better alternatives.
Re: I want to create an OS!!!
Posted: Sun Jan 27, 2013 6:45 pm
by Casm
Love4Boobies wrote:It was indeed designed for that purpose... in the '70s.
Just because a computer with 16Gb of memory now sit on my desktop, instead of a 1970s computer with 2mb of memory, occupying several rooms, the need for a "high level assembly language" hasn't changed, and C fills that role well.
Fortran was designed in the fifties, and it is still in widespread use in the scientific community. If it didn't do the job it is supposed to do it would long ago have been ditched in favour of something else.
Re: I want to create an OS!!!
Posted: Mon Jan 28, 2013 6:34 am
by Love4Boobies
Sandras wrote:Love4Boobies wrote:It was indeed designed for that purpose... in the '70s.
I'm not advocating C, but age does not mean, the thing is bad at what it does.
Why would you assume that because I said something used to be useful but no longer is, my rationale was its age? As requirements change in ways that are incompatible with the original design, three options become apparent: let the language collect dust, break backwards compatiblity, or come up with terrible hacks. C is guilty of all three.
Sandras wrote:One may even suggest, that the language must be good, if it's in the field for such a long time. Though, personally, I'd say, we tend to accumulate legacy technology simply because there's not enough momentum for a change, not because there are no better alternatives.
Legacy technologies tend to stay in use for the purpose of backwards compatibility. In the case of C, the abundant body of existing code.
Casm wrote:Just because a computer with 16Gb of memory now sit on my desktop, instead of a 1970s computer with 2mb of memory, occupying several rooms, the need for a "high level assembly language" hasn't changed, and C fills that role well.
Of course it has. We have since learned a lot about programming language theory, compiler theory, and software engineering.
Casm wrote:Fortran was designed in the fifties, and it is still in widespread use in the scientific community. If it didn't do the job it is supposed to do it would long ago have been ditched in favour of something else.
Fallacy 1. Fortran is in widespread use and thus Fortran is good.
Fallacy 2. Because Fortran is old and still good, C is the same.
Re: I want to create an OS!!!
Posted: Mon Jan 28, 2013 8:59 am
by Combuster
Instead of arbitrarily bashing a language (which btw
hasn't been collecting dust by sensible definitions), do you have any alternatives that do not suffer from your list of personal annoyances?
Re: I want to create an OS!!!
Posted: Mon Jan 28, 2013 9:35 am
by Antti
Combuster wrote:do you have any alternatives
I would like to hear too. It sounds like C is terrible.
Re: I want to create an OS!!!
Posted: Mon Jan 28, 2013 10:10 am
by Love4Boobies
I am aware of C11 and even talked about it several times about it on both the forum and the wiki. What I meant was that many aspects of the language are in desperate need of modernization. But, unfortunately, that can't happen because of the need for backwards compatibility.
Combuster wrote:do you have any alternatives that do not suffer from your list of personal annoyances?
They are not personal annoyances. I can explain quite objectively what is wrong with the language. The short story is that it asks for a lot and offers to little in return. Here is a longer story, which better explains the previous sentence:
- It has many pitfalls (undefined, implementation-defined, and unspecified behavior) which invariably translate bugs every so often, even in the case of expert C programmers. What's worse, correct code sometimes requires ugly workarounds. The reason why these "features" were introduced to the language was to allow optimizers to perform well while still keeping compilers relatively simple. However, compiler technology has suprassed that point.
- It lacks modern code reusability/abstraction mechanisms, such as user-defined namespaces and classes. The namespace issue is usually worked around by prefixing identifiers with "LIBRARY_" which results in overly verbose code. Classes can also be implemented but the resulting code will be far less expressive than it would have been with language support.
- Error handling in C cannot be performed in a clean manner. There are 3 options:
- Using traditional idioms: return values and thread-local variables, such as errno (eww!). Both require that the error handling and normal control flow be interleaved.
- Using goto statements that jump to the clean-up code positioned at the end of the functions in which the errors ocurred, à la Linux. However, it is in general difficult to handle the situation where a library detects an error but expects the client code to handle it.
- Exception handling can be implemented (e.g., using macros and setjmp/longjmp). Unfortunately, since C lacks RAII, things don't get destroyed as they go out as scope so a finally block must also be implemented (again, resulting in more error-prone code). VLA's are also tricky to clean up.
- There is no support for serialization. To avoid using files or arrays (which are not expressive enough to work with in this situation), most people rely on compiler-specific extensions, such as GCC's "__attribute__((packed))" to pack structures. You know a language is no good when you need to look for extensions here and there to make up for its shortcomings.
- Implicit declarations---seriously? If you forget to include the appropriate header, you may end up using a function that doesn't exist and the compiler won't complain. Have fun hunting the problem down through the build system.
- Certain micro-optimization aspects are exposed to the programmer, forcing them to write micro-optimizations that do not perform well everywhere. These could have easily been abstracted. The most obvious example is string processing.
- While we're at it, what's up with the null-terminated strings? Surely, it is better to store the character count and perhaps data structure size somewhere... The only reason for this design is the standard library (which was incepted long ago).
- I expect people to start shouting about this one but... it lacks automatic memory management and it's easy to mess up by going out of array bounds when using its pointer arithmetic design (any object in C is actually stored as an array). The compiler should do as much as possible and the programmer as little as possible. This heavily increases the chances of ending up with more correct programs.
Since I mentioned places where the standard has accumulated dust or where ugly solutions were found, I feel like I should provide a couple of examples:
- The so-called standard integer types (i.e., char, short, int, etc.) were not standardized with the appropriate constraints, leading the committee to introduce the minimum-width integer types (i.e., (u)int_leastN_t) in C99.
- All sorts of compiler hints that were introduced as hacks because yesterday's compilers sucked (e.g., void foo(int a[static 42]), register, inline). As far as micro-optimization is concerned, the standard says that the compiler is free to ignore them entirely.
- Because computers and parsers used to be slow, C was designed such that compilers require few passes. This means identifiers only become visible after the point where they have been declared rather than the entire scope. This leads to things like forward declarations which need to be kept in sync with the actual definitions.
I can
gladly go on all year long. It's true that all languages have their idiosyncracies but unless they have something to compensate for them...
You asked for alternatives... Well, it depends on what the task is. For numerical computation, I'll use Octave. For logic programming, Prolog. As far as most systems are concerned, functional programming is more elegant because (a) it allows for simpler solutions with fewer constructions and in which the programmer only needs to concentrate on the solution in space but not time, (b) it can be parallelized better, (c) very good static analysis can be performed on it. To give some examples, I often use Scheme, Common Lisp, Standard ML, and JavaScript (which has matured beyond anyone's expectations and is, as Owen said, basically "Scheme in Java clothing"). I also encourage people to look into Smalltalk.
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 10:22 am
by iansjack
Surely, in this context, we are most interested in languages that are better for OS programming than C? None of the ones that you cite seem to fulfil that requirement. Have you tried writing an OS in Smalltalk (a fine language in the appropriate context)?
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 10:28 am
by Love4Boobies
What do you think makes C so special for OS development that other languages lack? Other than JavaScript, all the languages I have mentioned in the context of functional-style programming have been used to develop operating systems in. I would argue that JavaScript is also a strong candidate. As for Smalltalk, it was designed specifically with developing this type of environment in mind.
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 10:36 am
by Casm
"I expect people to start shouting about this one but... it lacks automatic memory management."
Just as well for OS development. The last thing we need is a garbage collector trying to invoke a nonexistent operating system to free memory. And how would you do bounds checking on arrays without an interpreter (presumably written in C) trying to micro manage everything?
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 10:46 am
by Owen
Casm wrote:"I expect people to start shouting about this one but... it lacks automatic memory management."
Just as well for OS development.
Semi-automatic (i.e. RAII-based) memory management tends to work pretty well in most applications...
Casm wrote:And how would you do bounds checking on arrays without an interpreter (presumably written in C) trying to micro manage everything?
The same way you do in C (except this time automatically): Emit the code for if(array.size <= index) raise_error();
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 10:51 am
by Love4Boobies
Casm wrote:The last thing we need is a garbage collector trying to invoke a nonexistent operating system to free memory.
Where did you get the idea that garbage collectors must invoke an OS?
Casm wrote:And how would you do bounds checking on arrays without an interpreter (presumably written in C) trying to micro manage everything?
Interpreter?! It's very simple: A language can mandate a specific behavior when you go out of bounds. As an example, it might throw an exception.
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 11:05 am
by Casm
Casm wrote:And how would you do bounds checking on arrays without an interpreter (presumably written in C) trying to micro manage everything?
The same way you do in C (except this time automatically): Emit the code for if(array.size <= index) raise_error();
What would raise_error() do, apart from try to use an OS service to print an error message or terminate the program?
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 11:08 am
by Love4Boobies
Casm wrote:Casm wrote:And how would you do bounds checking on arrays without an interpreter (presumably written in C) trying to micro manage everything?
The same way you do in C (except this time automatically): Emit the code for if(array.size <= index) raise_error();
What would raise_error() do, apart from try to use an OS service to print an error message or terminate the program?
Recover, for instance. Have you ever used a language other than C or assembly?
Re: C pros and cons (was: I want to create an OS!!!)
Posted: Mon Jan 28, 2013 11:13 am
by Casm
Where did you get the idea that garbage collectors must invoke an OS?
The compiler for any high or medium level programming language is going to presuppose the existence of an operating system. It couldn't very well do anything else if there is supposed to be a garbage collector freeing memory. The only way around that would be to wreite your own compiler, and even then you would need to be able to disable garbage collection until you had got your OS's memory manager in place.
Interpreter?! It's very simple: A language can mandate a specific behavior when you go out of bounds. As an example, it might throw an exception.
And what would any exception handler put in place by a compiler do?