In Section 2.8, we mentioned that local variables in a procedure are allocated on the stack. While this description is convenient for keeping the exposition simple, modern compilers work quite differently. This exercise is for you to search the Internet and find out how exactly modern compilers allocate space for local variables in a procedure call. [Hint: Recall that registers are faster than memory. So, the objective should be to keep as many of the variables in registers as possible.]

What will be an ideal response?

As we have already seen many local variables which technically if located in memory would be found on the stack are in reality maintained in registers because of the significant advantage in speed enjoyed by the registers. We have already seen saved and temporary register conventions, argument registers, return value and return address registers. All of these are an attempt to increase speed and efficiency. In addition, modern optimizing compilers employ sophisticated register allocation strategies designed to maximize use of registers. However, arrays and structures are maintained on the stack and not in registers.

Computer Science & Information Technology

You might also like to view...

The ________ field can easily be used to include the file name to a footer

A) FileExtension B) FileName C) FileFooter D) Name

Computer Science & Information Technology

It's good practice to provide a(n) ____________ when connecting to anonymous FTP sites.

a. password b. email address c. IP address d. host name

Computer Science & Information Technology