From: Vikas S <vikas_soolapani@yahoo.com>
To: Steve Graegert <graegerts@gmail.com>
Cc: Rechberger Markus <mrechberger@gmail.com>,
linux-c-programming@vger.kernel.org
Subject: Re: Variable to sizeof function.
Date: Fri, 15 Jul 2005 23:44:21 -0700 (PDT) [thread overview]
Message-ID: <20050716064421.85333.qmail@web31901.mail.mud.yahoo.com> (raw)
In-Reply-To: <6a00c8d505071515355f041394@mail.gmail.com>
Thanks, This is a workable solution.
But the issue is I've some 100+ structures. So, writing
a if or case is going to be difficult.
a) You are right.
b) Yes. I want to pass a structure name. ie, make sizeof
accept a variable.
Is this impossible?
Thanks,
Vikas
--- Steve Graegert <graegerts@gmail.com> wrote:
> On 7/15/05, Vikas S <vikas_soolapani@yahoo.com> wrote:
> >
> > I guess I was not clear. Say, we have two structures.
> >
> > str1 {int x, char y} and str2 {int x, char *y};
>
> OK...
>
> > printf(sizeof(struct str1)); will give proper output. ie memory occupied
> > by str1.
>
> ...reasonable...
>
> > What I want is, instead of hard-coding str1 etc., I want to find
> > the size of structure which I will give as 1st argument. So, if the
> > program name is size, i'll give:
> > $ ./size str1 --- to get size of str1
> > $ ./size str2 --- to get size of str2
>
> This makes things even more confusing to me. So, you want
>
> (a) query the size of a particular structure among others
> (b) provide a structure as an argument to your program
>
> identified by name? Obviously (b) is something completely impossible,
> obscure at least. The solution to (a) is simple:
>
> struct s1 { int i; char *c; } str1;
> struct s2 { int i; char c[5]; } str2;
>
> if (argc != 2) return 0;
>
> if (!strcmp(argv[1], "str1"))
> printf("sizeof(str1): %d\n", sizeof(str1));
> else
> printf("sizeof(str2): %d\n", sizeof(str2))
>
> $ cc -o test test.c
>
> $ ./test str2
> sizeof(str2): 12
>
>
> > The code which I gave earlier is giving compile-time error message.
> >
> > Thanks,
> > Vikas
> > --- Rechberger Markus <mrechberger@gmail.com> wrote:
> >
> > > strlen on a null pointer will segfault...
> > > if arc is 1 then argv[0] will contain a pointer to an array of char
> > > if arc is 2 then argv[1] (the users first argument) will contain an
> > > array of char..
> > > so don't forget to check the number of arguments ..
> > >
> > > On 7/15/05, Vadiraj <vadiraj.cs@gmail.com> wrote:
> > > > Vikas,
> > > >
> > > > On 7/15/05, Vikas S <vikas_soolapani@yahoo.com> wrote:
> > > > > I want to find out the size of a structure which the user will give as an argument
> > > > > as follows.
> > > > >
> > > > > #include <> -- All includes..
> > > > > ..
> > > > > main(int arc, char *argv[])
> > > >
> > > > argv is a charecter pointer . You cannot pass struct * as an
> > > > arguement to main.
> > > >
> > > > > {
> > > > > printf("Size of structure %s is: %d\n", argv[1], sizeof(struct argv[1]));
> > > >
> > > > use strlen(argv[1]) to find the lenght of the string.
> > > >
> > > > --
> > > > cheers,
> > > > Vadi
> > > > -
> > > > 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
> > > >
> > > -
> > > 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
> > >
> >
> >
> >
> >
> >
> > __________________________________
> > Do you Yahoo!?
> > Yahoo! Mail - You care about security. So do we.
> > http://promotions.yahoo.com/new_mail
> > -
> > 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
> >
>
>
> --
> ______________________________________
> Steve Graegert //
> Software Consultancy // Whether you know it or not, if you
> Mobile: +49 (176) 21248869 // are a hacker, you are a revolutionary.
> Office: +49 (9131) 7126409 // Don't worry, you're on the right side.
> ____________________________// -- Dr Crash / Phrack 6 / phile 3
> -
> 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
>
__________________________________________________
Do You Yahoo!?
Tired of spam? Yahoo! Mail has the best spam protection around
http://mail.yahoo.com
next prev parent reply other threads:[~2005-07-16 6:44 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-07-15 14:02 Variable to sizeof function Vikas S
2005-07-15 15:00 ` Vadiraj
2005-07-15 15:16 ` Rechberger Markus
2005-07-15 17:53 ` Vikas S
2005-07-15 22:35 ` Steve Graegert
2005-07-16 6:44 ` Vikas S [this message]
2005-07-16 7:04 ` Steve Graegert
2005-07-16 8:26 ` Steven Smith
2005-07-16 14:30 ` Eric Bambach
2005-07-17 16:27 ` Vadiraj
2005-08-01 6:10 ` Query in C avinash pawar
2005-08-01 6:44 ` Steve Graegert
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=20050716064421.85333.qmail@web31901.mail.mud.yahoo.com \
--to=vikas_soolapani@yahoo.com \
--cc=graegerts@gmail.com \
--cc=linux-c-programming@vger.kernel.org \
--cc=mrechberger@gmail.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).