C is a general-purpose programming language
initially developed by Dennis Ritchie between 1969 and 1973 at AT&T Bell
Labs. Like most imperative languages in the ALGOL tradition, C has facilities
for structured programming and allows lexical variable scope(static variable
scope) and recursion, while a static type system prevents many unintended
operations. Its design provides constructs that map efficiently to typical
machine instructions, and therefore it has found lasting use in applications
that had formerly been coded in assembly language, most notably system software
like the Unix computer operating system.
C is an
imperative (procedural) language. It was designed to be compiled using a
relatively straightforward compiler, to provide low-level access to memory, to
provide language constructs that map efficiently to machine instructions, and
to require minimal run-time support. C was therefore useful for many
applications that had formerly been coded in assembly language, such as
insystem programming.
Like most
imperative languages in the ALGOL tradition, C has facilities for structured
programming and allows lexical variable scope and recursion, while a static
type system prevents many unintended operations. In C, all executable code is
contained within subroutines, which are called "functions" (although
not in the strict sense of functional programming). Function parameters are
always passed by value. Pass-by-reference is simulated in C by explicitly
passing pointer values. C program source text is free-format, using the
semicolon as a statement terminator and curly braces for grouping blocks of
statements.
The C
language also exhibits the following characteristics:
1. There is a
small, fixed number of keywords, including a full set of flow of control
primitives: for, if/else, while, switch, and do/while. There is one namespace,
and user-defined names are not distinguished from keywords by any kind of
sigil.
2.There are a
large number of arithmetical and logical operators, such as +, +=, ++, &,
~, etc.
3. More than
one assignment may be performed in a single statement.
4. Typing is
static, but weakly enforced: all data has a type, but implicit conversions can
be performed; for instance, characters can be used as integers.
5. Declaration
syntax mimics usage context. C has no "define" keyword; instead, a
statement beginning with the name of a type is taken as a declaration. There is
no "function" keyword; instead, a function is indicated by the
parentheses of an argument list.
6. User-defined
(typedef) and compound types are possible.
7. Heterogeneous
aggregate data types (struct) allow related data elements to be accessed and
assigned as a unit.
8. Array
indexing is a secondary notion, defined in terms of pointer arithmetic. Unlike
structs, arrays are not first-class objects; they cannot be assigned or
compared using single built-in operators. There is no "array"
keyword, in use or definition; instead, square brackets indicate arrays
syntactically, e.g. month.
9. Enumerated
types are possible with the enum keyword. They are not tagged, and are freely
interconvertible with integers.
10. Strings are
not a separate data type, but are conventionally implemented as null-terminated
arrays of characters.
11.Low-level
access to computer memory is possible by converting machine addresses to typed
pointers.
12. Procedures
(subroutines not returning values) are a special case of function, with an
untyped return type void.
13. Functions
may not be defined within the lexical scope of other functions.
14. Function
and data pointers permit ad hoc run-time polymorphism.
15. A
preprocessor performs macro definition, source code file inclusion, and
conditional compilation.
16. There is a
basic form of modularity: files can be compiled separately and linked together,
with control over which functions and data objects are visible to other files
via static and externattributes.
17. Complex functionality
such as I/O, string manipulation, and mathematical functions are consistently
delegated to library routines.
18. C does not
include some features found in newer, more modern high-level languages,
including object orientation and garbage collection.
No comments:
Post a Comment