2.2.1 Programming Techniques Flashcards

1
Q

Programming Constructs

A

Programming constructs : Represent a programs control flow, used in structured programming.

Sequence - Code executed line by line from top to bottom.

Selection - Code ran if specific condition is met.

Iteration - Block of code repeated/executed certain number of times or while a condition is met due to a loop.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
2
Q

Local Variables

A

Local Variables : Can only be accessed within block of code defined in

Advantages :
- Ensures subroutines are self-contained with no danger of variables affecting / being affected by other code AND can reuse in other programs without needing to take global variables too.

  • Requires less memory as deleted when subroutine completes.

Disadvantages :
- Must be passed in by parameters into other subroutines as cannot be directly accessed by other subroutines (by value or by reference depending on situation)

  • Difficult to trace and follow where variables are passed.
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
3
Q

Global Variables

A

Global Variables : Can be accessed by whole program.
- often used for variables that don’t need to be changed (e.g. Date, Pi)

Advantages :
- Useful if needed by multiple parts of the program - inefficient to pass into many subroutines as parameters
- Easier to follow and program

Disadvantages :
- Can be unintentionally overwritten by other parts of program.

  • Require more memory as not deleted until program terminates so memory inefficient.
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
4
Q

Recursion

A

Recursion : Programming construct where subroutine calls itself until base case is met.
- Each recursive call makes a new copies of values that are added to a stack (if passing in by val)
-When base case met it unwinds popping values back off of stack.

Advantages :
- Can represent problems in fewer lines of code - less prone to errors.
- Some functions naturally recursive - suited to some problems
- Can reduce size of problem with each call
- More natural to read

Disadvantages :
- Inefficient use of memory - prone to stack overflow (stack full) if subroutine called too many times (Uses more memory).
- Difficult to trace.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
5
Q

Integrated Development Environment

A

IDE : Program with a set of tools to aid in development of code.
- Help debug code (Breakpoints, Stepping, Variable Watch Window)
- Help write code (auto indentation, autocomplete etc)

Features :
- Breakpoints : Stop programming running at a point to check variables - Debug sections of code.

  • Syntax highlighting : To identify key words, variables and help identify syntax errors.
  • Stepping : Run the program line by line to check result and watch variables at each stage to see where errors are.
  • Auto-complete : When you start writing a command / identifier it completes it.
  • Variable watch : View how variables change while program executes.
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
6
Q

Text editors

A

Text editor : Does not have any helpful debugging tools or features to help develop program.
- Forced to learn syntax
- Smaller CPU usage

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
7
Q

Recursion vs Iteration

A

Recursion:
- Some Problems more Suited to be coded Recursively - more elegant solutions.

  • Recursion can represent problem in Fewer lines of code whereas iteration in more lines.
  • Harder to trace Recursion than iteration.
  • Uses more memory as new stack frame created each call whereas iteration cannot run out of memory as same variables used throughout.
  • Recursive code can be Easier to understand than iterative.
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
8
Q

Parameters, By Value + By Reference

A

Parameters : items passed to a sub-problem / Values passed into a subroutine.

By Value : Passing by value sends a copy of the value, so the original will not be changed when variable is altered in subroutine and changes lost as copy of variable changed.
- Changes made need to be returned to be accessed by rest of program.
- When don’t want to change variable, only access or simulate changes that shouldn’t be propagated to original in main program.
- used often in recursion where don’t want to override values

By reference : Passing by reference sends the memory address / Pointer of the original value, so this variable will be changed for whole program when variable is changed in subroutine as change original variables value.
- Changes automatically accessible to rest of program
- When you want to change original variables value.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly