2.2.6
Compiling a Program
Compiling a Program
Compiling a Program
You need to know the process a piece of code undergoes when it is compiled by a program.
data:image/s3,"s3://crabby-images/515b4/515b4a2e8d9109d7ca26c18ca71d5a16aa08e749" alt="Illustrative background for Compiling a program"
data:image/s3,"s3://crabby-images/515b4/515b4a2e8d9109d7ca26c18ca71d5a16aa08e749" alt="Illustrative background for Compiling a program ?? "content"
Compiling a program
Compiling a program
- When code is compiled through a compiler, it has to go through 4 stages before it is ready to run.
data:image/s3,"s3://crabby-images/515b4/515b4a2e8d9109d7ca26c18ca71d5a16aa08e749" alt="Illustrative background for Stages of compilation"
data:image/s3,"s3://crabby-images/515b4/515b4a2e8d9109d7ca26c18ca71d5a16aa08e749" alt="Illustrative background for Stages of compilation ?? "content"
Stages of compilation
Stages of compilation
- Those stages are:
- Lexical analysis.
- Syntax analysis.
- Code generation.
- Code optimisation.
Lexical Analysis
Lexical Analysis
Lexical analysis is the first stage a compiled language goes through to compile code.
data:image/s3,"s3://crabby-images/abb2d/abb2d3d1e55adb149402d7e5a2edb4219bbdd563" alt="Illustrative background for White space"
data:image/s3,"s3://crabby-images/abb2d/abb2d3d1e55adb149402d7e5a2edb4219bbdd563" alt="Illustrative background for White space ?? "content"
White space
White space
- Firstly, white space is removed from the code.
- This is the white space that is present to help humans read the code.
- The compiler doesn’t need the white space so it is removed.
data:image/s3,"s3://crabby-images/31db2/31db296fbff9f83da35a9ddd058c2230e25c33ec" alt="Illustrative background for Tokens"
data:image/s3,"s3://crabby-images/31db2/31db296fbff9f83da35a9ddd058c2230e25c33ec" alt="Illustrative background for Tokens ?? "content"
Tokens
Tokens
- The compiler will then look through the code and create tokens out of the keywords and operators it finds (lexemes).
- A token is a string that is recognised by the computer.
- For example, the number 8 might be assigned the token 'number:8'.
- Any comments are ignored by the compiler.
data:image/s3,"s3://crabby-images/1e9e2/1e9e254296870d9c4d0f3cbe437c5422472de86a" alt="Illustrative background for Symbol table"
data:image/s3,"s3://crabby-images/1e9e2/1e9e254296870d9c4d0f3cbe437c5422472de86a" alt="Illustrative background for Symbol table ?? "content"
Symbol table
Symbol table
- These tokens are assembled into a symbol table ready for the next step of the compiling process.
Syntax Analysis, Code Generation & Optimisation
Syntax Analysis, Code Generation & Optimisation
When code is compiled through a compiler, it has to go through 4 stages before it is ready to run.
data:image/s3,"s3://crabby-images/ccae6/ccae6729636f4f39e8f5d765c864f86ead4a8f2a" alt="Illustrative background for Step 2: syntax analysis"
data:image/s3,"s3://crabby-images/ccae6/ccae6729636f4f39e8f5d765c864f86ead4a8f2a" alt="Illustrative background for Step 2: syntax analysis ?? "content"
Step 2: syntax analysis
Step 2: syntax analysis
- During syntax analysis, the tokenised code from the lexical analysis is compared to the rules of the programming language.
- If a section or part of the code is found to not fit with these rules, an error is generated with details of what and where it is.
- It will continue to perform syntax analysis of all of the code and generate more errors if found.
- A full error report will be given back to the user of all errors found.
- This differs to interpreted languages as they return one error at a time.
data:image/s3,"s3://crabby-images/b560b/b560bcf943be056baae75b4485d4b8cf4cb7834f" alt="Illustrative background for Step 3: code generation"
data:image/s3,"s3://crabby-images/b560b/b560bcf943be056baae75b4485d4b8cf4cb7834f" alt="Illustrative background for Step 3: code generation ?? "content"
Step 3: code generation
Step 3: code generation
- Once the code has successfully passed the first two stages, it’s time to generate the code.
- During this stage object or machine code is generated.
- This is what the CPU actually works with to make your program run.
data:image/s3,"s3://crabby-images/0d585/0d585b244a02538bfec7cb23344a98a38091f0c4" alt="Illustrative background for Step 4: optimisation"
data:image/s3,"s3://crabby-images/0d585/0d585b244a02538bfec7cb23344a98a38091f0c4" alt="Illustrative background for Step 4: optimisation ?? "content"
Step 4: optimisation
Step 4: optimisation
- After your code has been generated into machine or object code it will be optimised for efficiency.
- The purpose is to make the binary footprint as small as possible and will remove procedures and variables that are written into the code but never used.
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
Jump to other topics
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
data:image/s3,"s3://crabby-images/9220a/9220a64e707af924249b072e9ddcfcd413526ea9" alt="Go student ad image"
Unlock your full potential with GoStudent tutoring
Affordable 1:1 tutoring from the comfort of your home
Tutors are matched to your specific learning needs
30+ school subjects covered