element14 Community
element14 Community
    Register Log In
  • Site
  • Search
  • Log In Register
  • About Us
  • Community Hub
    Community Hub
    • What's New on element14
    • Feedback and Support
    • Benefits of Membership
    • Personal Blogs
    • Members Area
    • Achievement Levels
  • Learn
    Learn
    • Ask an Expert
    • eBooks
    • element14 presents
    • Learning Center
    • Tech Spotlight
    • STEM Academy
    • Webinars, Training and Events
    • Learning Groups
  • Technologies
    Technologies
    • 3D Printing
    • FPGA
    • Industrial Automation
    • Internet of Things
    • Power & Energy
    • Sensors
    • Technology Groups
  • Challenges & Projects
    Challenges & Projects
    • Design Challenges
    • element14 presents Projects
    • Project14
    • Arduino Projects
    • Raspberry Pi Projects
    • Project Groups
  • Products
    Products
    • Arduino
    • Avnet Boards Community
    • Dev Tools
    • Manufacturers
    • Multicomp Pro
    • Product Groups
    • Raspberry Pi
    • RoadTests & Reviews
  • Store
    Store
    • Visit Your Store
    • Choose another store...
      • Europe
      •  Austria (German)
      •  Belgium (Dutch, French)
      •  Bulgaria (Bulgarian)
      •  Czech Republic (Czech)
      •  Denmark (Danish)
      •  Estonia (Estonian)
      •  Finland (Finnish)
      •  France (French)
      •  Germany (German)
      •  Hungary (Hungarian)
      •  Ireland
      •  Israel
      •  Italy (Italian)
      •  Latvia (Latvian)
      •  
      •  Lithuania (Lithuanian)
      •  Netherlands (Dutch)
      •  Norway (Norwegian)
      •  Poland (Polish)
      •  Portugal (Portuguese)
      •  Romania (Romanian)
      •  Russia (Russian)
      •  Slovakia (Slovak)
      •  Slovenia (Slovenian)
      •  Spain (Spanish)
      •  Sweden (Swedish)
      •  Switzerland(German, French)
      •  Turkey (Turkish)
      •  United Kingdom
      • Asia Pacific
      •  Australia
      •  China
      •  Hong Kong
      •  India
      •  Korea (Korean)
      •  Malaysia
      •  New Zealand
      •  Philippines
      •  Singapore
      •  Taiwan
      •  Thailand (Thai)
      • Americas
      •  Brazil (Portuguese)
      •  Canada
      •  Mexico (Spanish)
      •  United States
      Can't find the country/region you're looking for? Visit our export site or find a local distributor.
  • Translate
  • Profile
  • Settings
Code Exchange
  • Technologies
  • More
Code Exchange
Forum multiple pre increment/post increment in expression of C language
  • Blog
  • Forum
  • Documents
  • Events
  • Polls
  • Files
  • Members
  • Mentions
  • Sub-Groups
  • Tags
  • More
  • Cancel
  • New
Join Code Exchange to participate - click to join for free!
Actions
  • Share
  • More
  • Cancel
Forum Thread Details
  • State Suggested Answer
  • Replies 35 replies
  • Answers 3 answers
  • Subscribers 51 subscribers
  • Views 15501 views
  • Users 0 members are here
  • increment
  • c
  • in
  • Code Exchange
  • post
  • single
  • precedency
  • operator
  • left
  • value
  • pre
  • expression
  • right
  • turbo
Related

multiple pre increment/post increment in expression of C language

dr.akshay_1980@yahoo.com
dr.akshay_1980@yahoo.com over 9 years ago

I would like to know the explanation for the following expression evaluation in C under windows TURBO c..

void main()

{

     int i=4;

    int x;

    x= ++i + ++i + ++i;   // i becomes 5 then 6 added becomes 11 and then incremented to 12 so 11+12=23   

    printf("%d",x);

    getch();

}

when the above was executed value of x comes out to be 21

 

Slightly eliminating the x variable in the above

 

void main()

{

    int i=4;

    printf("%d", ++i + ++i + ++i);   //accordingly at this step  5+6+7=18

    getch();

}

when the above is executed the answer comes out to be 18


Can anyone provide a decent explanation step by step and why two answers are different???


Thanks in advance.

Akshay


  • Sign in to reply
  • Cancel

Top Replies

  • michaelkellett
    michaelkellett over 9 years ago in reply to dr.akshay_1980@yahoo.com +3
    If anyone asked you that (kind of) question at an interview (unless, perhaps, the job was to revise the C standard specification) you should explain that the only reasonable approach to such code was to…
  • gadget.iom
    gadget.iom over 9 years ago in reply to dr.akshay_1980@yahoo.com +2
    Ahhh... Complete code usually helps As for the problem... You have fallen victim to undefined behaviour as a result of each compilers interpretation of ambiguous code.
  • shabaz
    shabaz over 9 years ago in reply to dr.akshay_1980@yahoo.com +1
    Oh. I now get this is purely an academic question (and a very esoteric one not in my area of interest, sorry!) In real life people wouldn't write that code.. perhaps it is tested nowadays and therefore…
  • michaelkellett
    0 michaelkellett over 6 years ago in reply to neuromodulator

    The version of the C standard you quote, page 76:

     

    84) This paragraph renders undefined statement expressions such as

    i = ++i + 1;

    a[i++] = i;

     

    You have to hop around the standard a bit to get the full story on this but the standard (to me ) suggests that you would expect a warning, not an error.

     

    But, as the behavior is undefined, it's not something you should ever do.

     

    You'll need a C compiler expert (not me) to explain the philosophy behind what gets to be an error and what is just undefined.

     

    But I don't see much of a problem here, the answer to the interview question is simple enough, it's undefined behavior (with a nice clear example in the standard) so you shouldn't do it.

     

     

    MK

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • blanca12
    0 blanca12 over 6 years ago
    [deleted]
    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • neuromodulator
    0 neuromodulator over 6 years ago in reply to blanca12

    The compiler doesn't require consistence as its undefined behavior. Optimizations may or may not change behavior as well. You could try other compilers to see what you get, it may be different. Still, you should never code like that.

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • shabaz
    0 shabaz over 6 years ago in reply to blanca12

    Or ask the authors of Turbo C, if their 25+year old compiler has a bug or not image

    It doesn't make sense trying to decipher the behaviour of a 25 year old out of support compiler surely?

    Maybe I'm missing something.......

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • phoenixcomm
    0 phoenixcomm over 6 years ago

    If you did about inside C which I have done a few times.. the standard K&R says I= I++ + I++ ok but not realy. here's what is allowed i = i++ + b++ is valid on its face and is repeatable. as i is on the left side of the = this is where the value of i++ + b++ if I and b both  = 5 before now here is the funny chuck of it:

    we all know 5 + 5 = 10 right so after the assignment i becomes 10 right?

    then I and b are both incremented. which become 6 + 6 but whatever happened to the poor i on the left side of the = is it 10 or 11 which state takes precedence over the other? you see the BNF will only get you so far you also need the "state table" and thats where that info is. Nobody talks about the State Table.

    Question? if this  (i=i++ + i++) posable why couldn't you do this ( i =+i  + i++)    ??????????/

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • phoenixcomm
    0 phoenixcomm over 6 years ago in reply to phoenixcomm

    One more nail for the coffin. The big problem is if you look at the BNF ::= i++ = i++ + i++

    it doesn't really mean that you use the variable i in all three spots i just means variable. the problem with assignments where the same variable is on both sides is problematic.   take a look at this: i = i + 1 this could be rewritten as i =+i which tells the compiler to (right hand first) increment  i and then store it in i,  this itself could just be i++ or could it nope, but you could do this i++ = i but you that is the compilers state table will become confused. as most of the time using the same variable on both sides of an assignment statement like a = a; what up with that? the problem is that there is something called an lvalue. Basically, any named object that persists beyond a single expression is an lvalue. So by using the same lvalue on both sides of the assignment statement, you can get some bizarre results.  The problem lies in the finite state machine. that takes your input tokenizes it and determines what to do next. To show you I will use a simple c statement.  return ( a+b ); seems innocuous at first. heres what goes on. 

    1 reads: return finds that it is a keyword. checks bnf to find out whats next

    2. ' ' white space; this is ignored by C

    3. ( Optional (statement to follow)

    4. ' ' white space; this is ignored by C

    5.  a followed by + means this is a statement. get the value for a from the Data Dictionary.

    6. +  this is a standard C operator "ADD" BNF::= <i>[+]<i>

    7  b  this is a variable (and was expected) get the value from the Data Dictionary.

    8. ' ' white space; this is ignored by C

    9. ) Close paren.

    10. ; end of line.

    The compiler on the second or third pass puts the value of the addition of the two lvalues a, b on the stack and returns you will note that the return is not a lvalue. as it is transitory,  or temporary.

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • james.flynn
    0 james.flynn over 6 years ago

    Very interesting discussion but overall doesn't yield much useful information, mostly just fun to read about all the contributors opinions and self-reflective expertise.  I've been writing embedded code since the 80's in FORTRAN IV, FORTRAN77, PASCAL, MODULA-2, C, C++, and Assembly for way to many architectures and I still wouldn't consider myself an expert (I did have to write a Modula2 compiler during my masters project capstone).  But all that being what it is, the code presented here is kind of an Obfuscated code project rather than what you would see in a commercially supported/maintained project.  You can find other eccentric coding examples at  https://en.wikipedia.org/wiki/International_Obfuscated_C_Code_Contest.  More to the point of this original question, you can step through the statement using the 'C Operator Precedence' rules and determine the answer a compliant compiler would generate yourself.  That would cover the expression evaluation itself but not the language semantics/adherence. A 24 year old compiler, you would have to dig out the operator precedence rules that applied for that compiler.

     

    Just for the fun of it though, I did put this code into a GCC compiler:

     

    arm-oe-linux-gnueabi-gcc (GCC) 5.3.0

    Copyright (C) 2015 Free Software Foundation, Inc.

    This is free software; see the source for copying conditions.  There is NO

    warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

     

    To see what it said, it doesn't generate a syntax error but it does generate a warning:

     

    warning: operation on 'i' may be undefined [-Wsequence-point]

         x= ++i + ++i + ++i;   // i becomes 5 then 6 added becomes 11 and then incremented to 12 so 11+12=23  

                           ^

    warning: operation on 'i' may be undefined [-Wsequence-point]

     

     

    This warning is tell you the code has undefined semantics because of violations of sequence point rules in the C and C++ standards, so it isn't a syntax error but it is telling you that you may spend a long time debugging a problem that you could easily avoid.

     

    But hey, if you are trying to win the Obfuscated Code Coding contest maybe that is what you want...

     

    /Jim

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • michaelkellett
    0 michaelkellett over 6 years ago in reply to james.flynn

    C isn't really in the running for obfuscation:

     

    From the Wiki page on APL:

     

    The following function "life", written in Dyalog APL, takes a boolean matrix and calculates the new generation according to Conway's Game of Life. It demonstrates the power of APL to implement a complex algorithm in very little code, but it is also very hard to follow unless one has advanced knowledge of APL.

    life←{↑1 ⍵∨.∧3 4=+/,¯1 0 1∘.⊖¯1 0 1∘.⌽⊂⍵} 

     

     

    MK

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • james.flynn
    0 james.flynn over 6 years ago in reply to michaelkellett

    Interesting, I've not seen Dyalog APL before image  I still get amazed at the C stuff out there (https://www.ioccc.org/2018/burton1/hint.text ):

    char O,o[];main(l){for(;~l;O||puts(o))O=(O[o]=~(l=getchar())?4<(4^l>>5)?l:46:0)?-~O&printf("%02x ",l)*5:!O;}

     

    Actually, I avoid looking for stuff like this because it makes my hair fall out and I'm not ready to be bald yet LOL --  no really, I"m not bald yet!

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • phoenixcomm
    0 phoenixcomm over 6 years ago in reply to james.flynn

    James, you are on the right track and a good try.. And you actually ran the silliness. BUT to no avail, you did not understand the error message. The compiler got confused and ran home. And puff you have the error/warning message and it tells you 'i' is undefined, well not really. Debugging is not an option.

      In the 'data table' where all the variables are stored you have one instance of 'i', yes you can do a=a++; (not advised) better just use the increment operator a++; the problem as I said before is with <statement> while i = i + 1; says i equals  the value of i and add one to i and then store the new value of i back to i;   This is better i++; it says whatever is in i increment it. The problem is when you try this stunt i = i + i; which <statement>'s BNF seams to alow but can't be performed as you run into the confusion of "who is on first" (Abbot and Costello), or in other words who is 'i' this state is undefined (not valid syntactically) and therefore uncompilable.

    .

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
<>
element14 Community

element14 is the first online community specifically for engineers. Connect with your peers and get expert answers to your questions.

  • Members
  • Learn
  • Technologies
  • Challenges & Projects
  • Products
  • Store
  • About Us
  • Feedback & Support
  • FAQs
  • Terms of Use
  • Privacy Policy
  • Legal and Copyright Notices
  • Sitemap
  • Cookies

An Avnet Company © 2025 Premier Farnell Limited. All Rights Reserved.

Premier Farnell Ltd, registered in England and Wales (no 00876412), registered office: Farnell House, Forge Lane, Leeds LS12 2NE.

ICP 备案号 10220084.

Follow element14

  • X
  • Facebook
  • linkedin
  • YouTube