I want if "a C program is a standard C++ program, but not vice versa"
is a correct statement?
In a C++ program, we can use standard C libraries. However, we cannot
use C++ libraries inside C program.
Please advise. thanks!!
Nov 15 '05
50 2066
Martin Ambuhl <ma*****@earthl ink.net> writes: John Carson wrote: "With minor exceptions, C++ is a superset of C. Most differences stem from C++'s greater emphasis on type checking. Well-written C programs tend to be C++ programs as well." Bjarne Stroustrup, The C++ Programming Language, 3rd ed., Appendix B, Compatibility, p. 816.
This is an example of why one should *not* cite Stroustrup as an authority on this issue. He is obviously an authority on C++, but the fact is that well-written C programs tend to be uncompilable as C++. Best C practice is often illegal in C++. Remember that BS has a horse in this race.
The obvious exception to Stroustrup's statement is casting the result
of malloc() (and realloc()). A well-written C program is likely to
call malloc() and assign the result, without a cast, to a pointer
object of a type other than void*; this is illegal in C++.
Are there other significant exceptions? Let's limit the discussion to
well-written C90 programs.
For example, C++ has several additional keywords, but most C programs
aren't going to happen to use them as identifiers; they provide a
counterexample to any claim that C is a strict subset of C++, but not
to Stroustrup's statement.
Character literals are of type char in C++ and of type int in C, but
I've never seen any programs that depend on this difference other than
ones specifically written to demonstrate it.
So, did you have anything in mind other than casting malloc() that
would cause a typical well-written C program not to be valid C++?
--
Keith Thompson (The_Other_Keit h) ks***@mib.org <http://www.ghoti.net/~kst>
San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst>
We must do something. This is something. Therefore, we must do this.
"Branimir Maksimovic" <bm***@eunet.yu > writes: "Keith Thompson" <ks***@mib.or g> wrote in message news:ln******** ****@nuthaus.mi b.org...
[...] Presumably a header intended to be used by both C and C++ compilers could have
#ifdef __cplusplus #define restrict #endif
This can be dangerous. restrict type qualifier has specific meaning to C compiler, and does not mean anything to C++ compiler, so C++ calling C function with such parameter can lead to undefined behavior, therefore it is better to live that as it is.
C99 6.7.3p7 says:
An object that is accessed through a restrict-qualified pointer
has a special association with that pointer. This association,
defined in 6.7.3.1 below, requires that all accesses to that
object use, directly or indirectly, the value of that particular
pointer. The intended use of the restrict qualifier (like the
register storage class) is to promote optimization, and deleting
all instances of the qualifier from all preprocessing translation
units composing a conforming program does not change its meaning
(i.e., observable behavior).
Though I suppose there might be problems if "restrict" is removed from
the caller but not from the implementation of the function.
--
Keith Thompson (The_Other_Keit h) ks***@mib.org <http://www.ghoti.net/~kst>
San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst>
We must do something. This is something. Therefore, we must do this.
"Keith Thompson" <ks***@mib.or g> wrote in message
news:ln******** ****@nuthaus.mi b.org... "Branimir Maksimovic" <bm***@eunet.yu > writes: "Keith Thompson" <ks***@mib.or g> wrote in message news:ln******** ****@nuthaus.mi b.org... [...] Presumably a header intended to be used by both C and C++ compilers could have
#ifdef __cplusplus #define restrict #endif
This can be dangerous. restrict type qualifier has specific meaning to C compiler, and does not mean anything to C++ compiler, so C++ calling C function with such parameter can lead to undefined behavior, therefore it is better to live that as it is.
C99 6.7.3p7 says:
An object that is accessed through a restrict-qualified pointer has a special association with that pointer. This association, defined in 6.7.3.1 below, requires that all accesses to that object use, directly or indirectly, the value of that particular pointer. The intended use of the restrict qualifier (like the register storage class) is to promote optimization, and deleting all instances of the qualifier from all preprocessing translation units composing a conforming program does not change its meaning (i.e., observable behavior).
Though I suppose there might be problems if "restrict" is removed from the caller but not from the implementation of the function.
For the sake of compatibility and good behavior of code it would
be better to remove "restrict" from all C standard library functions.
Greetings, Bane.
In article <ln************ @nuthaus.mib.or g>
Keith Thompson <ks***@mib.or g> wrote:
[snippage] Are there other significant exceptions? Let's limit the discussion to well-written C90 programs.
[snippage]So, did you have anything in mind other than casting malloc() that would cause a typical well-written C program not to be valid C++?
One might argue whether this is "well-written", but I have had
C vs C++ scope issues bite, in real C code that someone attempted
to include part of in a C++ program.
The example I like to use is:
% cat t.c
#include <stdio.h>
struct A { int x[1]; };
int main(void) {
struct B { struct A { int x[1000]; } b; } var;
printf("sizeof( struct A) = %lu\n",
(unsigned long)sizeof(str uct A));
return 0;
}
% ln t.c t.c++
% cc -o t t.c
% ./t
sizeof(struct A) = 4000
% cc -o t t.c++
% ./t
sizeof(struct A) = 4
%
This is not the same as the original example (which was of course
much more complicated), but it does demonstrate that C and C++ are
wildly different languages. :-)
(OK, one might also argue that it is not "typical" either. It is
true that collisions on structure names are relatively rare, and
it is probably even more rare to have them matter in this way.)
--
In-Real-Life: Chris Torek, Wind River Systems
Salt Lake City, UT, USA (40°39.22'N, 111°50.29'W) +1 801 277 2603
email: forget about it http://web.torek.net/torek/index.html
Reading email is like searching for food in the garbage, thanks to spammers.
Branimir Maksimovic wrote: For the sake of compatibility and good behavior of code it would be better to remove "restrict" from all C standard library functions.
For the sake of compatibility and good behavior of code it would
be better to insist that C++ incorporate "restrict" and use it for all
C++ standard library functions where it is appropriate. But C++
chauvinists who believe in bloated languages and obfuscated code will
differ.
"Martin Ambuhl" <ma*****@earthl ink.net> wrote in message
news:BS******** *********@newsr ead3.news.atl.e arthlink.net... Branimir Maksimovic wrote:
For the sake of compatibility and good behavior of code it would be better to remove "restrict" from all C standard library functions. For the sake of compatibility and good behavior of code it would be better to insist that C++ incorporate "restrict" and use it for all C++ standard library functions where it is appropriate. But C++ chauvinists who believe in bloated languages and obfuscated code will differ.
Agreed!
Greetings, Bane.
On 2005-10-22, Keith Thompson <ks***@mib.or g> wrote: John Carson wrote: "With minor exceptions, C++ is a superset of C. Most differences stem from C++'s greater emphasis on type checking. Well-written C programs tend to be C++ programs as well." Bjarne Stroustrup, The C++ Programming Language, 3rd ed., Appendix B, Compatibility, p. 816. [...] For example, C++ has several additional keywords, but most C programs aren't going to happen to use them as identifiers; [...]
That reminds me of the Unix functions mktemp()/mkstemp(), which take a
template string argument from which they build a unique file name. Most
Unix manual pages, as well as the POSIX/UNIX standards themselves (which
are ignorant of C++), call the prototypes parameter declaration
``template'' (a C++ keyword):
int mkstemp(char *template);
.... which may be the reason why I've run into problems by calling the
character array I passed to mkstemp() ``template'' in C++ code as well
:-)
``new'' and ``class'' are also identifiers I would expect to see in many
C programs written by people unaware of C++ (or by c.l.c. citizens who
use them deliberately to introduce incompatibiliti es because they
dislike the whole compatibility debate so much), but I agree that it's a
minor problem when porting C programs to C++.
Martin Ambuhl wrote: Branimir Maksimovic wrote:
For the sake of compatibility and good behavior of code it would be better to remove "restrict" from all C standard library functions.
For the sake of compatibility and good behavior of code it would be better to insist that C++ incorporate "restrict" and use it for all C++ standard library functions where it is appropriate. But C++ chauvinists who believe in bloated languages and obfuscated code will differ.
Several of the more popular implementations of C++ do implement a form
of restrict as an extension, in a different way for each compiler. I
fail to see, though, how this solves the bloat and obfuscation problem.
Keith Thompson wrote: Michael Mair <Mi**********@i nvalid.invalid> writes:
John Carson wrote:
[...]
The statement that "C++ ... with few exceptions retains C as a subset" is not a statement of intent but a description of the relationsh ip between the two languages, albeit one that seems to be directed at C89. I quote again: "With minor exceptions, C++ is a superset of C. Most differences stem from C++'s greater emphasis on type checking. Well-written C programs tend to be C++ programs as well." Bjarne Stroustrup, The C++ Programming Language, 3rd ed., Appendix B, Compatibilit y, p. 816.
Hmmm, my C code tends to look quite different from my C++ code. Things I find quite acceptable in C are not acceptable in C++ where better solutions to address certain problems exist.
Apart from the different semantics of void* and ambiguities w.r.t. overloaded functions, there are better ways to perform explicit type conversions in C++ than the good old C-style cast.
Stroustrup's statement is that well-written C programs tend to be C++ programs, not that well-written C programs tend to be *well-written* C++ programs.
The former statement is basically true apart from the issue of casting the result of malloc(). The latter is not.
I see. Thanks for the pointer (no pun intended).
Cheers
Michael
--
E-Mail: Mine is an /at/ gmx /dot/ de address.
In article <dj***********@ otis.netspace.n et.au>, "John Carson" <jc************ ****@netspace.n et.au> writes: "Martin Ambuhl" <ma*****@earthl ink.net> wrote in message news:F8******** ********@newsre ad3.news.atl.ea rthlink.net It is a grossly erroneous statement. C and C++ are different languages. There are countless C programs that are not C++ programs.
"C++ was developed from the C programming language and, with few exceptions, retains C as a subset." Bjarne Stroustrup, The C++ Programming Language, 3rd ed., p. 8.
If you'd bothered to check, you'd see that this has been introduced
as an argument in this debate countless times (pretty much every time
the question has been raised), and someone has invariably pointed out
that it is in no way a satisfactory argument that C and C++ are not
different languages.
There are certainly those, including Stroustrop, who feel that C++ is
"mostly" a superset of C (whatever that might mean). And there are
many of us who do not. Appeals to authority in this case carry no
weight with us, unless that authority is ISO.
--
Michael Wojcik mi************@ microfocus.com This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics |
by: Pie |
last post by:
I like to have my program (running on my home machine)
email me (wherever I am) whenever it reaches a certain mile-stone
(finishes a phase of the simulation or runs into an interesting
path in the simulation). I just like add the feature so it can
email me the partial results. Is there a source code for
something like this I can add to my program? Do I need
an SMTP server code or can I use my current SMTP ISP smtp
server to email myself?...
|
by: christopher diggins |
last post by:
I am wondering if any can point me to any open-source library with program
objects for C++ like there is in Java? I would like to be able to write
things like
MyProgram1 >> MyProgram2 >> Fork(MyProgram3, SomeFile);
If not would this be something of interest to others?
Thanks in advance,
|
by: strutsng |
last post by:
I want if "a C program is a standard C++ program, but not vice versa"
is a correct statement?
In a C++ program, we can use standard C libraries. However, we cannot
use C++ libraries inside C program.
Please advise. thanks!!
|
by: Raghavendra R A V, CSS India |
last post by:
hie..
Do any one knows how to write a C program without using the
conditional statements if, for, while, do, switch, goto and even
condotional statements ? It would be a great help for me if someone
helps me...
Urgent - Please reply soon !
Thanks, Raghu
|
by: findmadhav |
last post by:
I need a program in C (something like a TSR) which will automatically
press the function key F6, say about every 5 seconds. Can anyone
provide me with an exe of such a program?
Thanks in advance.
| |
by: robinsonreyna |
last post by:
Hi everyone
Is it possible to write a program which do not have a
main() function. The program should compile and run. Please give
sample code to do this.
|
by: Francine.Neary |
last post by:
I am learning C, having fun with strings & pointers at the moment!
The following program is my solution to an exercise to take an input,
strip the first word, and output the rest. It works fine when you give
it 2 or more words, but when there's only 1 word the results vary
depending on whether it's on Windows or Linux: under MSVC it displays
no output (as it should); under gcc/Linux it instead gives
"Segmentation fault".
Any ideas...
|
by: Vince C. |
last post by:
Hi all.
I've installed Bloodshed Dev-C++ on a Windows 2000 SP4 machine. I'm using
MinGW 3.4.2.
I'd like to temporarily disable standard functions to write to stderr, i.e.
for instance redirect stderr to a temporary file (or /dev/null but is there
an equivalent under Windows? Is it "nul:") and then to *restore* the
default stderr so that standard library functions that write to stderr
produce output again.
|
by: Knute Johnson |
last post by:
I'm trying to write a C wrapper to run a Java program. I need to
distribute a CD with the Java runtime, my application and a C startup
program. I've put the C wrapper program, my java app and the runtime
directories in the same directory. It will run under MS XP or maybe
Vista. I'm using MS Visual C++ Express 2005 for a compiler and I tried
using the _execl and _spawnl functions. These all give me assertion
errors and file not found...
|
by: Banfa |
last post by:
Posted by Banfa
The previous tutorial discussed what programming is, what we are trying to achieve, the answer being a list of instructions constituting a valid program. Now we will discuss how we set about doing that.
Every program starts with a specification, this may be a several hundred page document from your latest client or one small paragraph from your professor and pretty much anything in-between.
The specification is very...
|
by: jinu1996 |
last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven tapestry of website design and digital marketing. It's not merely about having a website; it's about crafting an immersive digital experience that captivates audiences and drives business growth.
The Art of Business Website Design
Your website is...
| |
by: Hystou |
last post by:
Overview:
Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows Update option using the Control Panel or Settings app; it automatically checks for updates and installs any it finds, whether you like it or not. For most users, this new feature is actually very convenient. If you want to control the update process,...
|
by: tracyyun |
last post by:
Dear forum friends,
With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
|
by: agi2029 |
last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing, and deployment—without human intervention. Imagine an AI that can take a project description, break it down, write the code, debug it, and then launch it, all on its own....
Now, this would greatly impact the work of software developers. The idea...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome a new presenter, Adolph Dupré who will be discussing some powerful techniques for using class modules.
He will explain when you may want to use classes instead of User Defined Types (UDT). For example, to manage the data in unbound forms.
Adolph will...
|
by: TSSRALBI |
last post by:
Hello
I'm a network technician in training and I need your help.
I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs.
The last exercise I practiced was to create a LAN-to-LAN VPN between two Pfsense firewalls, by using IPSEC protocols.
I succeeded, with both firewalls in the same network. But I'm wondering if it's possible to do the same thing, with 2 Pfsense firewalls...
|
by: adsilva |
last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
| |
by: 6302768590 |
last post by:
Hai team
i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated we have to send another system
|
by: muto222 |
last post by:
How can i add a mobile payment intergratation into php mysql website.
| |