All Exams  >   Computer Science Engineering (CSE)  >   Compiler Design  >   All Questions

All questions of Intermediate Code Generation for Computer Science Engineering (CSE) Exam

The graph that shows basic blocks and their successor relationship is called
  • a)
    Dag
  • b)
    Flow Graph
  • c)
    Control Graph
  • d)
    Hamilton Graph
Correct answer is option 'B'. Can you explain this answer?

Shivam Sharma answered
A flow graph is a form of digraph associated with a set of linear algebraic or differential equations:
"A signal flow graph is a network of nodes (or points) interconnected by directed branches, representing a set of linear algebraic equations. The nodes in a flow graph are used to represent the variables, or parameters, and the connecting branches represent the coefficients relating these variables to one another. The flow graph is associated with a number of simple rules which enable every possible solution [related to the equations] to be obtained.

Relocating bits used by relocating loader are specified by
  • a)
    Relocating loader itself
  • b)
    Linker
  • c)
    Assembler
  • d)
    Macro Processor
Correct answer is option 'B'. Can you explain this answer?

Kiran Mehta answered
Relocating bits used by relocating loaders are specified by the linker.

Explanation:
A relocating loader is a program that loads an object program into memory for execution. It is responsible for allocating memory, resolving external references, and performing relocations. Relocations involve adjusting the memory addresses in the object program to match the actual memory locations where the program will be loaded.

When a program is compiled, it may contain references to external symbols, such as functions or variables, that are defined in other modules or libraries. These references are usually represented as symbolic addresses or offsets. However, these addresses are not fixed because the program can be loaded at different memory locations each time it is executed.

To resolve these external references and perform relocations, the relocating loader uses information provided by the linker. The linker is a program that combines multiple object files and libraries into a single executable file. It resolves symbols, calculates addresses, and generates relocation information.

The relocation information specifies the locations in the object program where adjustments need to be made. It contains the addresses or offsets that need to be modified to reflect the actual memory locations. The relocating loader uses this information to update the object program before loading it into memory.

Therefore, it is the linker's responsibility to specify the relocating bits used by the relocating loader. The linker analyzes the object files, resolves symbols, and generates relocation entries based on the memory layout and the addresses of external symbols. These relocation entries are then used by the relocating loader to perform the necessary adjustments during the loading process.

In conclusion, the linker is responsible for specifying the relocating bits used by the relocating loader. It generates relocation information based on the object files and libraries being linked, which is then used by the relocating loader to perform relocations and ensure correct execution of the program.

 Grammar that produce more than one Parse tree for same sentence is
  • a)
    Ambiguous
  • b)
    Unambiguous
  • c)
    Complementary
  • d)
    Concatenation Intersection
Correct answer is option 'A'. Can you explain this answer?

Anirban Khanna answered
An ambiguous grammar is one for which there is more than one parse tree for a single sentence. Since each parse tree corresponds to exactly one leftmost (or rightmost) derivation, an ambiguous grammar is one for which there is more than one leftmost (or rightmost) derivation of a given sentence.

 A non relocatable program is the one which
  • a)
    Cannot execute in any area of storage other than the one designated
  • b)
    Consists of a program and information for its relocation
  • c)
    None of the mentioned
  • d)
    All of the mentioned
Correct answer is option 'A'. Can you explain this answer?

Divya Kaur answered
Explanation:

Non-relocatable Program:
A non-relocatable program is a program that cannot execute in any area of storage other than the one designated. This means that the program is loaded into a specific memory location and cannot be moved to another location for execution.

Characteristics of Non-relocatable Program:
- Fixed Memory Location: Non-relocatable programs are designed to run from a specific memory location and cannot be relocated to another location for execution.
- No Information for Relocation: Unlike relocatable programs, non-relocatable programs do not contain any information for their relocation to different memory locations.
- Restricted Execution: These programs are limited to executing only in the designated memory location and cannot be run from any other location.

Advantages and Disadvantages:
- Advantages: Non-relocatable programs provide a secure and controlled environment for execution, as they are confined to a specific memory location.
- Disadvantages: The main disadvantage of non-relocatable programs is that they lack flexibility, as they cannot be moved to different memory locations for efficient memory management.
In conclusion, a non-relocatable program is designed to run from a fixed memory location and does not have the capability to execute in any other area of storage. It is important for ensuring security and control over program execution, but it may limit flexibility in memory management.

A relocatable program form is one which
  • a)
    Cannot execute in any area of storage other than the one designated
  • b)
    Consists of a program and information for its relocation
  • c)
    None of the mentioned
  • d)
    All of the mentioned
Correct answer is option 'C'. Can you explain this answer?

A relocatable program form is one which consists of a program and relevant information for its relocation. Using this information it is possible to relocate the program to execute from a storage area then the one designated for it at the time of its coding or translation.

 Which of the following can be accessed by transfer vector approach of linking?
  • a)
    External data segments
  • b)
    External sub-routines
  • c)
    Data located in other procedure
  • d)
    All of the mentioned
Correct answer is option 'B'. Can you explain this answer?

Dishani Bajaj answered
External Sub-routines can be accessed by transfer vector approach of linking
Accessing External Sub-routines:
- When using the transfer vector approach of linking, external sub-routines can be accessed.
- This method involves creating a transfer vector table that contains addresses of external sub-routines.
- The main program can then call these external sub-routines by accessing their addresses from the transfer vector table.
- This allows for the execution of code located in external sub-routines without having to physically include them in the main program.
Other Options:
- External data segments and data located in other procedures may not be directly accessed using the transfer vector approach.
- External data segments typically require other methods of linking, such as loading them into memory at runtime.
- Data located in other procedures may be accessed through inter-procedural communication mechanisms, but not necessarily through the transfer vector approach.
In conclusion, while the transfer vector approach of linking is useful for accessing external sub-routines, it may not be suitable for accessing other types of data or code located in external procedures.

 A series of statements explaining how the data is to be processed is called
  • a)
    Assembly
  • b)
    Machine
  • c)
    COBOL
  • d)
    Program
Correct answer is option 'D'. Can you explain this answer?

Abhay Ghoshal answered
 A program is a sequence of instructions, written to perform a task by computer. It requires programs to function, typically executing the program’s instructions in a central processor.

A self-relocating program is one which
  • a)
    Cannot execute in any area of storage other than the one designated
  • b)
    Consists of a program and information for its relocation
  • c)
    None of the mentioned
  • d)
    All of the mentioned
Correct answer is option 'C'. Can you explain this answer?

Nabanita Basak answered
A self-relocating program is a program which can perform the relocation itself
•A table of information about address sensitive instruction in the program.
•Relocating logic that can perform the relocation of the address sensitive instructions.

A top down parser generates
  • a)
    Rightmost Derivation
  • b)
    Right most derivation in reverse
  • c)
    Left most derivation
  • d)
    Left most derivation in reverse
Correct answer is option 'C'. Can you explain this answer?

Bijoy Iyer answered
Top-down parsing is a parsing strategy where one first looks at the highest level of the parse tree and works down the parse tree by using the rewriting rules of a formal grammar.

The linker
  • a)
    Is similar to interpreter
  • b)
    Uses source code as its input
  • c)
    Is required to create a load module
  • d)
    None of the mentioned
Correct answer is option 'C'. Can you explain this answer?

Arka Dasgupta answered
It is a program that takes one or more object files generated by a compiler and combines them into a single executable file, library file, or another object file.

 An optimizer Compiler
  • a)
    Is optimized to occupy less space
  • b)
    Both of the mentioned
  • c)
    Optimize the code
  • d)
    None of the mentioned
Correct answer is option 'D'. Can you explain this answer?

Meghana Rane answered
In computing, an optimizing compiler is a compiler that tries to minimize or maximize some attributes of an executable computer program.

Chapter doubts & questions for Intermediate Code Generation - Compiler Design 2025 is part of Computer Science Engineering (CSE) exam preparation. The chapters have been prepared according to the Computer Science Engineering (CSE) exam syllabus. The Chapter doubts & questions, notes, tests & MCQs are made for Computer Science Engineering (CSE) 2025 Exam. Find important definitions, questions, notes, meanings, examples, exercises, MCQs and online tests here.

Chapter doubts & questions of Intermediate Code Generation - Compiler Design in English & Hindi are available as part of Computer Science Engineering (CSE) exam. Download more important topics, notes, lectures and mock test series for Computer Science Engineering (CSE) Exam by signing up for free.

Compiler Design

26 videos|67 docs|30 tests

Signup to see your scores go up within 7 days!

Study with 1000+ FREE Docs, Videos & Tests
10M+ students study on EduRev