Compatibility of C and C++
From Wikipedia, the free encyclopedia
This article is part of the Programming Language Comparison series. |
General Comparison |
Basic Syntax |
String Operations |
String Functions |
|
Evaluation strategy |
List of "hello world" programs |
|
Compatibility of C and C++ |
Comparison of C and Pascal |
Comparison of C++ and Java |
Comparison of C# and Java |
Comparison of C# and Visual Basic .NET |
The C and C++ programming languages are closely related. C++ grew out of C and is mostly a superset of the latter. Due to this, C code is often developed with C++ IDEs, integrated with C++ code, and compiled in C++ compilers. While most C source code will compile as C++ code without any changes, certain language differences prevent C++ from being a strict superset of C.
C++ introduces many features that are not available in C — C++ code is not valid C code. Here, however, we focus on differences that cause valid C code to be invalid C++ code, or to be valid in both languages but to behave differently in C and C++.
Bjarne Stroustrup, the creator of C++, has suggested [1] that the incompatibilities between C and C++ should be reduced as much as possible in order to maximize inter-operability between the two languages. Others have argued that since C and C++ are two different languages, compatibility between them is useful but not vital; according to this camp, efforts to reduce incompatibility should not hinder attempts to improve each language in isolation. The official rationale for the 1999 C standard (C99) [2] "endorse[d] the principle of maintaining the largest common subset" between C and C++ "while maintaining a distinction between them and allowing them to evolve separately," and was "content to let C++ be the big and ambitious language."
Several additions of C99 are not supported in C++ or conflict with C++ features, such as variadic macros, compound literals, variable-length arrays, and native complex-number types. The long long int
datatype is also defined in C99, but not included in any official C++ standard. On the other hand, C99 has reduced some other incompatibilities by incorporating C++ features such as //
comments and mixed declarations and code.
[edit] Constructs valid in C but not C++
One commonly encountered difference is that C allows a void* pointer to be assigned to any pointer type without a cast, whereas C++ does not; this idiom appears often in C code using malloc
memory allocation. For example, the following is valid in C but not C++:
void* ptr; int *i = ptr; /* Implicit conversion from void* to int* */
or similarly:
int *j = malloc(sizeof(int) * 5); /* Implicit conversion from void* to int* */
In order to make the code compile in both C and C++, one must use an explicit cast:
void* ptr; int *i = (int *) ptr; int *j = (int *) malloc(sizeof(int) * 5);
Another portability issue from C to C++ are the numerous additional keywords that C++ introduced. This makes C code that uses them as identifiers invalid in C++. For example:
struct template { int new; struct template* class; };
is legal C code, but is rejected by a C++ compiler, since the keywords "template", "new" and "class" are reserved.
C++ compilers prohibit goto from crossing an initialization, as in the following C99 code:
void fn(void){ goto flack; int i = 1; flack: ; }
There are many other C syntaxes which are invalid or behave differently in C++ [3]:
- The comma operator can result in an "l-value" (a quantity that can be used for the left-hand side of an assignment) in C++, but not in C.
- C does not allow a given
typedef
to be duplicated in the same scope, whereas C++ allows redundanttypedef
s. - Enumeration constants (
enum
values) are always of typeint
in C, whereas they are distinct types in C++ and may have size different fromint
. - C++ identifiers are not allowed to contain two or more consecutive underscores, whereas C identifiers may.
- C++ also changes some C standard-library functions to add additional
const
qualifiers, e.g.strchr
returnschar*
in C andconst char*
in C++. - In both C and C++ one can define nested
struct
types, but the scope is interpreted differently (in C++, a nestedstruct
is defined only within the scope/namespace of the outerstruct
). - Non-prototype ("K&R"-style) function declarations are not allowed in C++, although they have also been deprecated in C since 1990. Similarly, implicit function declarations (using functions that have not been declared) are not allowed in C++, but have also been deprecated in C since 1999.
- C allows
struct
,union
, andenum
types to be declared in function prototypes, whereas C++ does not. Astruct
,union
, orenum
declaration in C++ declares an implicittypedef
, while in C it does not.
In order to intermix C and C++ code, any C++ functions which are to be called from C-compiled code must be declared as extern "C"
.
[edit] Constructs that behave differently in C and C++
There are a few syntactical constructs that are valid in both C and C++, but produce different results in the two languages.
For example, character literals such as 'a'
are of type int
in C and of type char
in C++, which means that sizeof('a')
gives different results in the two languages.
The static
keyword is used in C to restrict a function or global variable to file scope (internal linkage). This is also valid in C++, although C++ deprecates this usage in favor of anonymous namespaces (which are not available in C). Also, C++ implicitly treats any const
global as file scope unless it is explicitly declared extern
, unlike C in which extern
is the default. Conversely, inline
functions in C are of file scope whereas they have external linkage by default in C++.
Several of the other differences from the previous section can also be exploited to create code that compiles in both languages but behaves differently. For example, the implicit typedefs created by C++ struct declarations can change the meaning of an identifier in a given scope.
Both C99 and C++ have a boolean type bool
with constants true
and false
, but they behave differently. In C++, bool
is a built-in type and a reserved keyword. In C, these keywords and types are only defined if the program includes the stdbool.h
header, and may be redefined by the programmer.
[edit] References
- Detailed comparison , sentence by sentence, from a C Standard perspective.
- Incompatibilities Between ISO C and ISO C++, David R. Tribble (2001).
C programming language | |
---|---|
Libraries: | C standard library | glibc | Dietlibc | uClibc | Newlib |
History: | Criticism of the C programming language |
Language Features: | String | Syntax | Preprocessor | Variable types and declarations | Functions |
Dialects: | C++ | Objective-C |
C and Other Languages: | Compatibility of C and C++ | Operators in C and C++ | Comparison of Pascal and C | C to Java byte-code compiler |