From: Micha Feigin <michf@post.tau.ac.il>
To: linux-c-programming <linux-c-programming@vger.kernel.org>
Subject: Re: "static const" attribute in C++ (How to ?)
Date: Thu, 1 Jul 2004 06:22:27 +0300 [thread overview]
Message-ID: <20040701032226.GB3419@luna.mooo.com> (raw)
In-Reply-To: <16611.16213.876963.610967@cerise.nosuchdomain.co.uk>
On Wed, Jun 30, 2004 at 11:31:49PM +0100, Glynn Clements wrote:
>
> John Richard Moser wrote:
>
> > |>It doesn't matter. A #include directive simply inserts the contents of
> > |>the header file directly into the source code which is fed to the
> > |>compiler. The compiler doesn't care which file a given piece of code
> > |>comes from.
> > |>
> > |
> > | It is a problem since a header can be included more then once, and
> >
> > Umm.
> >
> > #import "foo.h"
> >
> > This includes only one time. I'd only use this with Objective-C though.
> >
> > For C, and in general, you should use:
> >
> > #ifndef __FOO_H__
> > #define __FOO_H__
> >
> > ....
> >
> > #endif /*__FOO_H__*/
>
> That only prevents against the header being included multiple times
> within a given compilation unit, which isn't the issue which was being
> discussed. The issue was that, if an lvalue is defined (as opposed to
> declared) in a header file, it will exist in every object file whose
> source code included the header.
>
> The key point is that C++ appears to treat initialised "static const"
> members as compile-time constants, not as lvalues. Thus, they don't
> exist in any object file, and so the problem of them existing in
> multiple object files doesn't arise.
That can't be true; What happens if the static int value is defined in
another file? it's value won't be known at compile time, only at link
time. What g++ may be doing is ignoring the problem of multiple
definitions if they have the same value.
It does allow initializing array size using static const, unlike gcc, I
don't know the mechanism, but I believe it also requires linker
support, not only compiler.
I compiled a sample program with a static const int val = 10; and then
ran nm on it and in the output:
a.out:080484c4 r val
so the value is in the object, read only data if I recall the section
symbols correctly.
>
> --
> Glynn Clements <glynn.clements@virgin.net>
> -
> To unsubscribe from this list: send the line "unsubscribe linux-c-programming" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
> +++++++++++++++++++++++++++++++++++++++++++
> This Mail Was Scanned By Mail-seCure System
> at the Tel-Aviv University CC.
>
next prev parent reply other threads:[~2004-07-01 3:22 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-06-28 22:46 "static const" attribute in C++ (How to ?) Luciano Moreira - igLnx
2004-06-28 23:52 ` Glynn Clements
2004-06-29 14:30 ` Luciano Moreira - igLnx
2004-06-29 17:26 ` Henry Margies
2004-06-29 19:10 ` Luciano Moreira - igLnx
2004-07-02 7:47 ` wwp
[not found] ` <40E56EFF.1030901@ig.com.br>
2004-07-02 14:30 ` Luciano Moreira - igLnx
2004-06-29 17:39 ` Glynn Clements
2004-06-29 14:32 ` Micha Feigin
2004-06-29 17:43 ` Glynn Clements
2004-06-30 1:33 ` Micha Feigin
2004-06-30 2:01 ` Glynn Clements
2004-06-30 23:42 ` Daniel Brockman
2004-07-01 22:33 ` Glynn Clements
2004-06-30 20:39 ` John Richard Moser
2004-06-30 22:31 ` Glynn Clements
2004-07-01 3:22 ` Micha Feigin [this message]
2004-07-01 4:27 ` Glynn Clements
2004-07-01 7:12 ` John Richard Moser
2004-06-29 19:08 ` Luciano Moreira - igLnx
-- strict thread matches above, loose matches on Subject: below --
2004-07-02 10:20 Dinesh Ahuja
2004-07-02 14:29 ` Luciano Moreira - igLnx
2004-07-02 22:32 ` Glynn Clements
2004-07-03 0:12 ` Luciano Moreira - igLnx
2004-07-05 5:35 ` Dinesh Ahuja
2004-06-28 21:42 Luciano Moreira - igLnx
2004-06-28 21:52 ` Glynn Clements
2004-06-29 1:10 ` Micha Feigin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20040701032226.GB3419@luna.mooo.com \
--to=michf@post.tau.ac.il \
--cc=linux-c-programming@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.