2 Programming Flashcards

1
Q

What is declaration?

A

Declaration is telling the computer what the identifier (name) should be and what type of data should be stored for a variable.

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

What is assignment?

A

The allocation of data values to variables, constants, arrays and
other data structures so that the values can be stored.

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

what is a variable

A

Value that can change during the running of a program. By
convention we use lower case to identify variables (eg a=12)

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

what is a constant?

A

Value that remains unchanged for the duration of the program. By
convention we use upper case letters to identify constants. (e.g. PI=3.141)

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

what are data structures?

A

a data structure refers to a way of organizing and storing data in a computer so that it can be accessed and used efficiently. e.g. arrays, 2-D arrays, data types.

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

what do we use to show indices in python? e.g. if someone wants to find out the answer to 2^3

A

2 ** 3, which equals 8

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

What is input?

A

Input is collecting data, usually through the keyboard
it is data sent to a computer to be processed

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

What is input in pseudocode and in python?

A

psuedocode:
name <— USERINPUT

python:
name = str(input(“Enter your name: “))

psuedocode: variable = USERINPUT

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

What is output?

A

Output is putting data onto the screen, usually as text
it is processed info that is sent out from a computer

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

What is output in pseudocode and in python?

A

psuedocode:
OUTPUT “text”

python:
print(“text”)

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

What are the data types?

A
Character
Real
String
Integer
Boolean
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
12
Q

What is Character data?

A

Character data is a single letter of text data

Eg. ‘a’

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

What is Real data?

A

Real data is decimal numbers.

Eg. ‘0.55’

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

What is String data?

A

String data is text data (multiple characters).

Eg. “Hello”

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

What is Integer data?

A

Integer data is whole numbers.

Eg. ‘12’

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

What is Boolean data?

A

Boolean data is a true or false value.

Eg. ‘True’ or ‘False’

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

What does the type of data determine?

A

The type of the data determines how it is stored and what you can do with the data.

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

What is casting?

A

Casting is the process of converting data from one type to another.

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

What are the reasons for casting?

A

One of the most common reasons for casting is output.
Output must be formatted as a string, and so we may need to convert a certain piece of data to a string.
All input also comes as a string, and must then be converted to other data types.

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

How do you cast to a string?

A

Casting to a string can be done by using the str function

Eg. str(3) gives “3”

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

How do you cast to an integer?

A

Casting to an integer can be done using the int function. Eg. int(3.4) gives 3

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

How do you cast to a real?

A

Casting to a real can be done using the real function.

Eg. real(“3.4”) gives 3.4

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

What are operators?

A

Operators are symbols that represent a specific function within a program

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

What are the Arithmetic operators?

A

Integer division
Modulus/modulo operator
Basic Operators

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
25
What is the integer division operator? what do we use to show integer divsion?
The integer division operator returns the quotient (whole part) of a division. Eg. 5 DIV 2 would give 2. the word DIV is used in pseudocode. the symbol for integer division in python coding is: 5 // 2 = 2
26
What is the Modulus/Modulo operator? what symbol do we use for modulus/modulo in python coding and in psuedocode?
The modulus/modulo operator gives the remainder of the division of two numbers. Eg. 5 MOD 2 would be equal to 1. The word MOD is used in psuedocode. The symbol in python coding is: 5 % 2 = 1
27
how do we do integer division, including remainders?
we would use both DIV and MOD. see pic
28
What are the basic operators?
``` Addition is done using a + sign. Subtraction is done using a - sign. Division is done using a / sign. Multiplication is done using a * sign. Exponentiation is done using a ** sign. ```
29
What is the relational operator?
Relational operators compare two values, and produce a True or False value.
30
What are the Equality operators?
We can test if two values are equal using the equality operator. Eg. 4 == 4 is True We can also test if two values are not equal using the not-equal-to operator Eg. 4 ≠ 4 would evaluate to False. that symbol is used in psuedocode to show not equal to. <> is also used in psuedocode to show not equal to. in python coding, the symbol for not equal to is !=
31
symbol for less than, greater than, less than or equal to and greater than or equal to in pseudocode and in python coding?
less than (in python and psuedocode): < greater than (in python and psuedocode): > less than or equal to (in python and psuedocode): <= greater than or equal to (in python and psuedocode): >=
32
What are the Boolean operators?
AND OR NOT
33
What is the AND Boolean operator?
``` The AND boolean operator evaluates if both operands are True Eg. True AND True = True True AND False = False False AND True = False False AND False = False ```
34
What is the OR boolean operator?
``` The OR boolean operator evaluates to True if only one of the operands are True. Eg. True OR True = True True OR False = True False OR False = False False OR True = True ```
35
What is the NOT boolean operator?
NOT negates a logical value Eg. NOT True = False NOT False = True
36
what do these evaluate to? 7 < 2 and 1 < 2 7 < 2 or 1 < 2 not 7 < 2
-> False -> True -> True
37
What is Sequence?
Sequence is when the computer follows a set of steps in the same order every time it is run. Each line of code will have some operation and these operations will be carried out in order line-by-line
38
in python and in psuedocode, how do you generate a random integer?
# This also includes 1 and 10 ``` python: import random #Generate a random integer between 1 and 10 random_integer = random.randint(1, 10) # 1 and 10 can be generated print("Random Integer:", random_integer) psuedocode: random_integer -> RANDOM_INT(0,9) OUTPUT random_integer ```
39
in python, how do you generate a random item from a list?
``` import random #Given a list, pick a random value my_list = [2, 5, 8, 10] random_choice = random.choice(my_list) print("Random Choice:", random_choice) ```
40
What is selection?
Selection allows us to have decisions made in our program Selection represents a decision in the code according to some condition. The condition is met then the block of code is executed otherwise it is not. Often alternative blocks of code are executed according to some condition Selection allows us to execute a section of code depending on whether a condition is met or not.
41
What is an If-statement?
If-statements is an easy way of checking if a condition is true
42
convert this to psuedocode: ``` if i > 2: j=10 else: j=3 ```
``` IF i > 2 THEN j <--- 10 ELSE j <--- 3 ENDIF ```
43
convert this to python: ``` IF i ==2 THEN j <--10 ELSE IF i==3 j <-- 3 ELSE j <--1 ENDIF ```
``` if i ==2: j=10 elif i==3: j=3 else: j=1 ```
44
Which shape is used to show a selection on a flow diagram?
Diamond symbol
45
What is Iteration?
Iteration allows a group of statements to be repeated multiple times. Iteration statements are often called loops.
46
What is definite iteration? give an example
Definite iteration repeats a block of code for a known number of time. For loops are an example. For loops are used when we know before hand the number of iterations we wish to make.
47
convert to psuedocode: ``` for a in range(3): print(a) ```
``` FOR a ← 0 TO 3 OUTPUT a ENDFOR ```
48
What is indefinite iteration? give three examples.
Indefinite iteration is a block of code that will repeat while a specified condition is true. so we don't know beforehand the number of iterations that will occur. three examples are: while loop, do...while and repeat...until. these loops are used when we do not know beforehand the number of iterations needed and the block of code will repeat while a specified condition is true.
49
convert to python and what would be the output? ``` a <-- 0 WHILE a < 4 OUTPUT a a <-- a + 3 ENDWHILE ```
``` a=0 while a<4: print(a) a=a+3 ``` output: 0 3
50
use a nested for loop to print out a grid of x's
see pic
51
Use a nested while and if to print out only even numbers until and including 50
see pic
52
Which shape is used in a flow diagram for iteration?
Diamond shape
53
What is a subroutine?
A subroutine is a names block of code within your program
54
What are the advantages of a subroutine?
* subroutines can be developed in isolation/independently/separately; * easier to discover errors // testing is more effective (than without a subroutine); * subroutines make program code easier to understand; * subroutines make it easier for a team of programmers to work together on a large project; * subroutines make it easier to reuse code
55
How does a subroutine make code easy to read?
There are fewer long blocks of code to understand
56
How does a subroutine make the program more efficient?
Blocks of code only have to be created once but can be reused multiple times
57
How do subroutines make the program more reliable?
If there are bugs in the program, each subroutine can be tested individually to make sure it works
58
What are parameters?
Parameters are variables listed inside the parentheses in the function definition (see pic in key points in onenote) parameters are used to pass data into functions
59
What are arguments?
Arguments are the actual values that are sent to the function when it is called (see pic in key points in onenote)
60
What are the two types of subroutine?
- Function - procedure
61
What is a function?
A function is a subroutine which returns a value A function is a named block of code that takes arguments, manipulates data and returns a value functions have both input(s) and an output(s)
62
What is a procedure?
A procedure is a subroutine which does not return a value a procedure is a named block of code that performs a set of instructions without returning a value. a procedure either has an input or an output
63
what is the similarity and difference in the way procedures and functions are set out in Python
they are both declared using the def keyword, but a function has a return statement and a procedure does not. Examples: # A function that returns the square of a number def square(x): return x * x # A procedure that prints "Hello, world!" def greet(): print("Hello, world!")
64
What is the scope of a variable?
The scope of a variable determines which parts of a program can access and use that variable
65
What will be the scope of a variable defined within a subroutine?
Local scope
66
describe variables with a local scope
A variable with a local scope can only be accessed within the subroutine that it is defined in. Local variables are not recognized outside a subroutine unless they are returned. There is no way of modifying or changing the behavior of a local variable outside its scope. local variables only exist while the subroutine is executing Once the execution of the subroutine ends, the local variable is destroyed, and its memory is released
67
What is a global variable?
A global variable is a variable that can be accessed by any part of the whole program A global variable is a variable that can be used anywhere in a program. they are defined outside of subroutines.
68
How can a variable inside a subroutine be made to have a global scope?
A variable can be made global by adding the 'global' keyword in front of it the first time it is used see pic
69
compare global variables with local variables
The issue with global variables is that one part of the code may inadvertently modify the value because global variables are hard to track. also, global variables need to defined throughout the running of the whole program. This is an inefficient use of memory resources. Local variables are defined only when they are needed and so have less demand on memory. also, the localised scope of local variables makes it easier to debug programs because any issues related to a local variable are confined to a specific part of the code. in addition, local variables are held in RAM only during the execution of the corresponding subroutine. Once the subroutine completes, the local variable is no longer retained in memory. This efficient use of system resources contrasts with global variables, which remain in memory throughout the entire program execution. also, When using local variables, programmers can reuse the same variable names for different purposes within different subroutines. This flexibility helps prevent accidental conflicts between variables with the same name. but, local variables only exist within a subroutine, so cannot be accessed by other parts of the programme, and sometimes, programmes need variables that can be accessed throughout the whole programme.
70
what is structured programming?
Structured programming is the process of breaking down a large problem into a set of smaller problems The smaller sub-problems are then used to:- Working out the parameters needed Decide which data type would be the most appropriate Work if out if a value is needed to be returned these sub-problems allow the larger programme to be programmed in a modular manner, so that each section of the programme can be coded one by one.
71
use the structured programming technique to decompose the task of making a computer game
Modern computer games are decomposed to break down the complexity of the problem into more manageable 'chunks' Creating an entire game at once would be challenging and inefficient, so it could be decomposed into: Levels - Levels can be designed/created/tested/ independently of other levels Characters - The mechanics of characters in the game can be designed and created by a separate team Landscape - The art team can work on the visual aspects of the game without needing to understand how the game is programmed Once all of the smaller problems are completed, joined together a complex game has been created
72
what is a hierarchy chart?
A hierarchy chart is an example of a diagram used to show problem decomposition in structured programming Each problem is divided into multiple subproblems, which is turn are divided into further subproblems until they cannot be divided any further Hierarchy charts show how module and subroutines relate to each other and is depicted as a tree structure Hierarchy charts can be created on paper or digitally and can also be created programmatically by software An example of a hierarchy chart is shown below for a sending messages and calls on a mobile phone. Each sub-problem is broken down into smaller sub-problems:
73
Mabel is a software engineer. She is writing a computer game for a client. In the game the main character has to avoid their enemies. This becomes more difficult as the levels of the game increase. The computer game allows a user to select a character (e.g. name, gender). They can then choose a level for the game (easy, normal, challenging). The user controls their character by moving it left or right. The character can jump using space bar as an input. If the character touches one of the enemies then it loses a life. The character has to make it to the end of the level without losing all their lives. The game is designed in a modular way. One sub-procedure will handle the user input. Describe three other sub-procedures Mabel could create for the given game description. [6]
Mabel could create a sub-procedure to select a character, including name and gender, etc [1], which gives the user options when choosing a character [1] Mabel could create a sub-procedure to choose a level [1] which gives the user a choice of difficulty (easy, medium, challenging) by taking the user input [1] Mabel could create a sub-procedure to allow the character to lose lives [1]. If the character has less than 0 lives left then the game ends [1]
74
benefits of decomposition/structured programming
When developing code for a large problem or project, decomposition/structured programming can be used to divide the code into manageable sections, so that the coder can code different parts of the programme in an organised manner without being overwhelmed by the whole project at once. Another benefit is that error detection and debugging is made easier when you focus on smaller sections of code. Also, decomposition can be used when working in a group, so you can distribute different sub-problems to different people to solve, according to their strengths.
75
What is an array?
An array is a data structure that stores a fixed number of values under a single identifier.
76
if we want to access a file in our code, what do we need to do?
Whatever we are doing to a file whether we are reading, writing or adding to or modifying a file we first need to open it using: open(filename,access_mode) There are a range of access mode depending on what we want to do to the file, the principal ones are given in the pic:
77
When storing values in an array what must the values all be?
The values must be of the same type.
78
When are Arrays useful?
Arrays are useful when you have lots of related data that you don't want to store in multiple variables
79
What is an element?
An element is each piece of data inside an array
80
What is an element's index?
An element's index is it's position within the array. The counting of the elements starts at zero
81
format of an array
primes = [2, 3, 5, 7, 11, 13]
82
How would you assign values in an array?
name_of_array[x] = "Hello" | x is the element number you wish to put the value number into
83
How can you access values within an array? how to get 5 from this array? primes = [2, 3, 5, 7, 11, 13]
OUTPUT name_of_array[x] x is the element number you wish to access The first element is at index 0, so primes[2] gives us the value 5.
84
What do lists store?
Lists store multiple elements under the same identifier.
85
What is the maximum number of elements a list can have?
There can be a variable number of elements - they never get full.
86
how to find the length of an array? what is the length of this array? list = ["banana", "apples", "blueberries"]
using len(name_of_array) the length of that array is 3.
87
How can lists be declared?
A list can be declared as follows: | list = []
88
How can values be added to the end of the list?
Values can be added to the end of the list as follows: | list.append["value"]
89
What is a 2D (2-Dimensional) array?
A 2D array is the data structure which consists of a list of lists. Example: multiples = [[2, 4, 6, 8, 10], [3, 6, 9, 12, 15]]
90
how to access an individual list in a 2D list? multiples = [[2, 4, 6, 8, 10], [3, 6, 9, 12, 15]] how to access the first list of this 2D array?
we use name of list followed by index position of list. multiples = [[2, 4, 6, 8, 10], [3, 6, 9, 12, 15]] multiples[0] gives us the first list.
91
How would you access an individual element in a 2D array? How to get 8 and 15 from this 2D list? multiples = [[2, 4, 6, 8, 10], [3, 6, 9, 12, 15]]
To access a specific value, we use row and column indices, e.g., multiples[0][3] gives us 8, and multiples[1][4] gives us 15.
92
What are the uses of a 2D list?
A 2D list could be used for a 2D surface or a database
93
How can a 2D list be used for a database?
Each inner list can store a record of the database | The outer list can store each record
94
What is a string?
Strings are special cases of arrays or lists, where each element is a character
95
What is concatenation?
Concatenation is joining two strings together. This can be done with the + sign. Eg. "Hello" + "World" = "Hello World"
96
How would we access a character in a string?
str[3] | This accesses the 4th character in the string
97
How would we see the length of a string?
Use the len function | Eg. len("Hello") would give 5
98
What are the string operations?
- Length - Substring - Concatenation
99
what is a substring? how to extract a substring? extract the first three characters of the word "Computer"
Definition: A substring is a sequence of characters that exists inside a string. For example, you might want to extract the first three characters of a password or a specific section of a longer text. Syntax: To extract a substring, you use a process called slicing. You specify the start and end positions within the original string. The syntax looks like this: string[start:end]
100
defintion of concatenation
concatenation refers to the process of joining two or more strings together to create a new string.
101
What is the purpose of files??
Files allow us to store data so it continues even when the program is not running Files allows programs to carry on where they left off when they are executed
102
What are text file made up of?
String data
103
What is binary files mad up of?
Binary data
104
Why should we be careful with the way we handle data?
We should be careful with the way we handle data so we do not accidentally corrupt them
105
How do we open a file so the operating system knows we are using it?
We can use these commands: openRead("filename.txt") openWrite("filename.txt")
106
How do we assign a variable to a file?
``` MyVariable = openRead("filename.txt") MyVariable = openWrite("filename.txt") ```
107
How do we read/write in a file?
We use the following commands: myFile.readLine() will return the next line of a file as a string. myFile.writeLine() will write a line to the file. myFile.endOfFile() will return True if we reach the end of the file.
108
How do we close a file?
We can close a file using the following command: | myFile.close()
109
What is structured data?
Structured data refers to any data that resides in a fixed field within a record or file so that it can be easily entered, stored, queried, and analysedof records
110
What are the pros and cons of records?
Pros: Very simple, text-based format. Can be read by many applications. Easy to use in programs. Cons: Inefficient for large datasets. Can only store text data. No built-in means of sorting or searching.
111
What are comma separated values (CSV)?
CSV is one method of storing a record Each record is stored on its own line Each field is separated by a special character such as a comma
112
What are records made up of?
Fields
113
in python, create a record of students using this information, then output this information in this exact format.
see pic
114
What are identifiers?
Identifiers are the names given to variables, constants, and subroutines
115
How should variables be named?
Variables should be be lowercase and an underscore should separate each word. They should also have descriptive names Eg. this_is_my_variable
116
How should constants be named?
Constants should be named the same as variables (an underscore separates each letter and they should have descriptive names) but unlike variables the letters are uppercase
117
How should subroutines be named?
Subroutines should have lowercase names, with each word separated by an underscore Eg. calculate_sum() Subroutines should have descriptive names where possible
118
What is Whitespace?
Whitespace is key to good code, since it is used to separate blocks of code and make code easier to read.
119
When should blank lines generally be used?
Subroutines should be separated by a blank line. Blank lines can be used sparingly in subroutines to show sections of the subroutine. Other lines of code should not have blank space around them.
120
What are comments?
Comments are lines of code that are ignored completely by the computer They are used to add description to your code to make it easy to understand A Python comment is preceeded by a #
121
Why is indentation necessary in some coding languages?
Indentation is necessary in some languages to control program flow
122
What is an interface?
An interface is a collection of comments which describe a subroutine. An interface includes: List of parameters and their types. Return value and its type. What the subroutine does.
123
What do validation and sanitation protect against?
Validation and sanitation can help to protect against malicious inputs such as SQL injection attacks
124
What is input sanitation?
Input sanitation involves the removal of unwanted characters from input data Any data entered by users which might be executed or become part of a query should first be sanitised.
125
What is input validation?
Input validation is the process of making sure that input data meets certain criteria. If a user's data is rejected, they should be informed and asked to enter it again
126
What are the input validation rules?
``` Input validation rules include: Type checks Range checks Presence checks Format checks Length checks ```
127
What are type checks?
Type checks check the type (e.g. Integer) of the input
128
What are range checks?
Range checks check that the data is inside an allowed range, e.g. less than 100
129
What are presence checks?
Presence checks check that the required data has been input
130
What are format checks?
Format checks check that the data fits a set format, e.g. an email address has an @ symbol
131
What are length checks?
Length checks check that the number of characters entered is inside a permitted range.
132
What is Contingency planning?
Contingency planning is a course of action designed to help someone respond to a future event or situation that may happen This includes: Providing helpful prompt messages Providing error-recovery routes (e.g. an undo feature) Preventing access from certain parts of the system Using exception handling
133
What is authentication?
Authentication is the process of checking that a person or system is authorised to use a system.
134
What is the most common form of authentication?
The most common form of authentication is to require users to enter a username and password.
135
What happens when a user is authenticated?
Once a user has authenticated themselves, they should be able to see data relevant to themselves and no one else.
136
What are errors in software often called?
Bugs
137
what are syntax errors? examples of syntax errors
Errors in the code that mean the program will not even run at all. Normally this is things like missing brackets, spelling mistakes and other typos. Examples of syntax errors are: Typos and spelling errors Missing or extra brackets or quotes Misplaced or missing semicolons Invalid variable or function names Incorrect use of operators Incorrectly nested loops & blocks of code
138
what are runtime errors?
Errors during the running of the program. This might be because the program is writing to a memory location that does not exist for instance. eg. An array index value that does not exist.
139
what are logic errors? examples of logic errors?
The program runs to termination, but the output is not what is expected. Often these are arithmetic errors. examples: Division by 0 Incorrect use of operators (< and >) Logical operator confusion (AND for OR) Looping one extra time Indexing arrays incorrectly (arrays indexing starts from 0) Using variables before they are assigned Infinite loops
140
see pic
see pic
141
What gets rid of bugs?
Debugging
142
What are the purposes of testing?
The purposes of testing are to check that a program: Works as intended under good conditions Copes with errors when given bad data Testing involves inputting test data into the programme to check if the output given is what the expected output is. Code needs to be tested with a range of different input data to ensure that it works as expected under all situations. we need to ensure that data entered into the programme is checked by the programme to make sure that the input values are: * within a certain range * in correct format * the correct length * The correct data type (eg float, integer, string)
143
What does debugging means?
Debugging is to find the cause of the bug and fix it
144
Are bugs deliberate attempts to bring down systems?
No
145
What are some different types of testing in the development stages?
Performance and load testing Usability testing Functionality testing Security testing
146
When does terminal testing occur?
Terminal testing occurs at the end of development
147
What are the results of terminal testing used for?
The results of terminal testing are used to check how the software performs when given a certain set of test data.
148
When does Iterative testing occur?
Iterative testing involves testing code as it is written
149
What are the results of iterative testing used for?
The results of iterative testing are fed back into the development process
150
What is test data?
Test data involves using a range of data, both valid and invalid, to see how the program responds Code needs to be tested with a range of different input data to ensure that it works as expected under all situations.
151
What are the different types of data used in testing?
The program is tested using normal (typical), erroneous or boundary (extreme) data. Normal data - Data that we would normally expect to be entered. For example for the age of secondary school pupils we would expect integer values ranging from 11 to 19. Erroneous data - Data that are input that are clearly wrong. For instance, if some entered 40 for the age of a school pupil. The program should identify this as invalid data but at the same time should be able to handle this sensibly which returns a sensible message and the program does not crash. Boundary data - Data that are on the edge of what we might expect. For instance if someone entered their age as 10, 11, 19 or 20.
152
What are test plans?
Test plans are created to make sure that testing is effective by detailing which test will be performed, which test data will be used, and what the intended outcome will be
153
When should a test plan be created?
A test plan should be made before development and is part of the design stage
154
SME Electronics is an online shop which sells electronic items. The following flowchart shows an algorithm used to calculate the price of an item when they have a sale.
see pic
155
What are High-level languages?
High-level languages include most programming languages such as Python, C++ and Java
156
What are High-level languages (HLLs) made up of?
High-level languages are made up of human-readable statements which makes it easy to understand
157
What does it mean when High-level languages (HLLs) are portable?
High level languages are portable, which means that they can be run on many different types of hardware
158
Why don't we always use High-level languages (HLLs)?
Computers can only process instructions in the form of binary numbers. We have to use special HLL software which translates our HLL source code into executable binary
159
What are Low-level languages (LLLs)?
Low-level programming languages are languages which are much closer to computer-understandable binary.
160
Why do we use Low-level languages (LLLs)?
LLLs provide exact control over the central processing unit LLLs need less translation, and often lead to faster code which is useful for computers with low specifications such as embedded systems
161
What are translators?
Translators are special software that convert source code into executable binary
162
What are compilers?
Compilers are software that translates the whole of a program in one go Eg. C, C++, Visual Basic and Swift
163
What are the pros of compilers?
Compilers produce an executable program: There is no need to repeat this process more than once per version of the software. Compilers hide the source code from the end user. This helps to protect developers' intellectual property. Compilers will provide a list of errors once it has attempted the compilation process. This can make debugging easier.
164
What are the cons of compilation?
The compilation process can be very slow, this slows development if small changes need to be made
165
What are Interpreters?
Interpreters are are a type of translator which convert high level languages to executable machine code Eg. Python and JavaScript
166
What are the cons of Interpreters?
Running an interpreted program is slower than a compiled program because we have to translate each line every time we run the software But it is quicker to get started which can be good for small changes Interpreters do not produce a compiled program file: The process must be repeated each time the program is run
167
What are the pros of interpreters?
Interpreters stop as soon as they encounter an error. This is useful for debugging Interpreted languages are portable. This means they can be run on many different types of CPU's as long as there is an interpreter available for the platform
168
What do assemblers do?
Assemblers translate assembly code into executable binary
169
What is Assembly?
Assembly is a low-level language where each instruction directly responds to a binary sequence and the assembler replaces the commands with the relevant binary
170
What are the pros of assemblers?
Assembly provides exact control over the hardware: This can lead to very efficient code that takes up little space in memory and is quick to execute. Assembly can be used on low specification machines.
171
What are the cons of assemblers?
Assembly is very difficult to use, and needs deep technical knowledge of the central processing unit and the memory.