Practice
Resources
Contests
Online IDE
New
Free Mock
Events New Scaler
Practice
Improve your coding skills with our resources
Contests
Compete in popular contests with top coders
logo
Events
Attend free live masterclass hosted by top tech professionals
New
Scaler
Explore Offerings by SCALER
/ Interview Guides / Compiler Design MCQ

Compiler Design MCQ

Last Updated: Jan 08, 2024
Certificate included
About the Speaker
What will you Learn?
Register Now

Compiler -  It is a software program that converts a program written in High-level language to a low-level language(object/ target language). It also reports errors present in source programs.

Types of compilers:

  • Single-pass compilers: It is a type of compiler that processes the source code only once.
  • Multi-pass compilers: It is a type of compiler that processes the source code multiple time(to convert High-level language to Low-level language) i.e. to convert source code to target/ object code.

There are two phases of the compilation process:

  • Analysis: It breaks up the source code/program into small parts and creates an intermediate representation of the source program.
  • Synthesis phase: It takes the intermediate representation of the source program as input and creates the desired target code/program.

There are five phases of a compiler:

Lexical analyzer 

  • Reads the program and converts it into tokens using the LEX tool.
  • Tokens are defined by regular expressions which are understood by the lexical analyzer
  • Removes white spaces, comments, tabs.

Syntax analyzer

  • Constructs the parse tree.
  • Takes the tokens one by one and uses CFG to construct the parse tree.
  • Using these productions we can represent what the program actually is.
  • The input has to be checked whether it is in the desired format or not.

Semantic analyzer

  • Verifies the parse tree, whether it is meaningful or not.
  • It uses the parse tree and info in the symbol table to check the source program for semantic consistency with the language definition.

Intermediate code generator

  • Generates the intermediate code. Example: Three address codes.
  • This code is converted to machine language using the last two phases which are platform dependent. 

Code optimizer

  • We can get optimized code.
  • The code optimization phase attempts to improve the intermediate code so that it runs faster and consumes fewer resources.

Target code generator

  • The final phase of the compiler generates the target code/assembly code.

Symbol Table

  • The data structure is used by the compiler to store all the information related to identifiers, for example, their types, scope, location name, etc.
  • It helps the compiler to function smoothly by finding the identifiers quickly.
  • All the phases interact with the symbol table manager.

Error handler

It is a module that takes care of the events which are encountered during compilation and it takes care to continue the compilation process even if the error is encountered. The task of the error handling process is to detect each error, report it to the user and implement them to handle errors.

Grammars

It is basically a set of rules that defines the valid structure of a particular language.

A grammar consists of four components:

  • Set of terminals: They are not replaced by any other thing further.
  • Set of non-terminals: Values/variables that are replaced by terminals.
  • Set of productions
  • Start symbol: One of the non-terminals is designated as the start symbol from where the production begins.

Compiler Design MCQs

1. 

What of the following can recognize Context-sensitive grammar?

Create a free personalised study plan Create a FREE custom study plan
Get into your dream companies with expert guidance
Get into your dream companies with expert..
Real-Life Problems
Prep for Target Roles
Custom Plan Duration
Flexible Plans
2. 

What does LR stand for?

3. 

What does the lexical analyzer take as input?

4. 

What does the lexical analyzer take as output?

5. 

What is a linear analysis called in a compiler?

Explore InterviewBit’s Exclusive Live Events
Explore Exclusive Events
By
No More Events to show!
No More Events to show!
No More Events to show!
No More Events to show!
Certificate included
About the Speaker
What will you Learn?
Register Now
6. 

What is the action of parsing the source program into proper syntactic classes known as?

7. 

What is the action of parsing the source program into proper syntactic classes known as?

Start Your Coding Journey With Tracks Start Your Coding Journey With Tracks
Master Data Structures and Algorithms with our Learning Tracks
Master Data Structures and Algorithms
Topic Buckets
Mock Assessments
Reading Material
Earn a Certificate
8. 

What is the bottom-up parsing method also known as?

9. 

What is the compiler called which runs on one machine and produces code for a different machine?

10. 

What is the graph called which shows basic blocks along with their successor relationship?

11. 

What is the process of finding a parse tree for a string of tokens called?

12. 

What is the process of searching for match tokens described using?

Discover your path to a   Discover your path to a   Successful Tech Career for FREE! Successful Tech Career!
Answer 4 simple questions & get a career plan tailored for you
Answer 4 simple questions & get a career plan tailored for you
Interview Process
CTC & Designation
Projects on the Job
Referral System
Try It Out
2 Lakh+ Roadmaps Created
13. 

What is the role of optimizing the compiler?

14. 

What does a top-down parser generate?

15. 

When can semantic errors be detected?

16. 

When is an interpreter preferred over a compiler?

17. 

When is type checking done?

18. 

Which of the compiler allows the only modified sections of source code to be recompiled?

19. 

Which of the following errors can a compiler check?

20. 

Which parsing technique avoids backtracking?

21. 

Which part produces the target code from the intermediate representation of source code?

22. 

Why is handle pruning used?

23. 

Why is semantic analysis responsible for?

24. 

Why is the minimum Hamming distance method used?

25. 

Why is the symbol table used?

26. 

Identify the output of the assembler.

27. 

Check whether the following statement is true or false: Ambiguous grammar produces more than one parse tree for some sentence.

28. 

Identify the correct definition of lexical analysis?

29. 

Identify the correct phase of the compiler.

30. 

Identify the data structure which has minimum access time in case of symbol table implementation?

31. 

Identify the data structure which is based on the locality of reference used for implementation of the symbol table.

32. 

Identify the interpreted language.

33. 

Identify the language processor among the following.

34. 

Identify the method to determine whether tokens can be generated by a given grammar?

35. 

Identify the method which merges the bodies of two loops?

36. 

Identify the most general phase of structured grammar.

37. 

Identify the most powerful parser?

38. 

Another name of top-down parsing is?

39. 

Identify the technique used to replace run-time computations with compile-time computations.

40. 

Identify the term which is recognized as a sequence of characters in token.

41. 

Identify which among the following is used for grouping characters into tokens.

42. 

Identifying the class of statement when compiled does not produce any executable code.

43. 

In which class does recursive descent parsing belong?

44. 

In which does the compiler translate the source code?

45. 

In which language do users write the programs?

46. 

In which phase of the compiler is grammar checked?

47. 

On what basis is the phase syntax analysis modeled?

48. 

Through which type of grammar can synthesized attributes can be simulated?

49. 

What does a bottom-up parser generate?

Excel at your interview with Masterclasses Know More
Certificate included
What will you Learn?
Free Mock Assessment
Fill up the details for personalised experience.
Phone Number *
OTP will be sent to this number for verification
+1 *
+1
Change Number
Graduation Year *
Graduation Year *
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
*Enter the expected year of graduation if you're student
Current Employer
Company Name
College you graduated from
College/University Name
Job Title
Job Title
Engineering Leadership
Software Development Engineer (Backend)
Software Development Engineer (Frontend)
Software Development Engineer (Full Stack)
Data Scientist
Android Engineer
iOS Engineer
Devops Engineer
Support Engineer
Research Engineer
Engineering Intern
QA Engineer
Co-founder
SDET
Product Manager
Product Designer
Backend Architect
Program Manager
Release Engineer
Security Leadership
Database Administrator
Data Analyst
Data Engineer
Non Coder
Other
Please verify your phone number
Edit
Resend OTP
By clicking on Start Test, I agree to be contacted by Scaler in the future.
Already have an account? Log in
Free Mock Assessment
Instructions from Interviewbit
Start Test