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 15492 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…
Parents
  • 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
Reply
  • 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
Children
No Data
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