Key Component: The central element of a computer system.
Main Functions: Contains the circuitry necessary to:
Fetch program instructions from main memory (RAM).
Decode these instructions.
Execute the instructions.
Command Handling:
Loads new commands into the CPU.
Decodes these commands.
Data Flow Direction: Directs the flow of data and the operation of the ALU.
Function:
Performs all arithmetic operations (e.g., addition and subtraction).
Conducts logical operations (e.g., AND, OR).
Core: Sometimes referred to as a ‘core’; dual-core technology implies two ALUs for parallel processing of two calculations.
Connection: Connected to the address bus.
Function: Contains the RAM address of the next instruction the CPU wants.
Connection: Connected to the data bus.
Function:
Holds data to be written to RAM.
Holds data read from RAM.
Relationship with MAR:
The MAR provides the address.
The MDR holds the data to be read from or written to that address.
Definition: Connecting wires that link the CPU to other devices, carrying instructions to/from components. Usually integrated into the motherboard.
Types of Buses:
Data Bus: Links RAM to the CPU via the MDR.
Control Bus: Links RAM to the CPU via the CU.
Memory Bus: Links RAM to the CPU via the MAR.
Address Bus: Links RAM to the CPU via the MDR.
Definition: RAM stands for Random Access Memory.
Volatility: Volatile memory (data is deleted when power is lost).
Function:
Stores the modules needed to make applications work.
Provides temporary storage for programs and data loaded since booting up.
Supports multitasking by allowing multiple windows to be open and enabling quick switching between them.
Example: When you open a word processing application, there may be a short delay as the necessary modules are loaded into RAM.
Definition: ROM stands for Read Only Memory.
Function:
Contains the BIOS (Basic Input/Output System) and startup operations.
Volatility: Non-volatile memory (data is retained even when power is lost).
Immutability: Data cannot be changed as ROM is read-only and cannot be written to.
A small, high-speed memory inside the CPU is used to hold frequently used data, so the CPU needs to access the much slower RAM less frequently.
This results in faster processing speeds.
The Fetch – Decode – Execute cycle, also known as the instruction cycle, is the process by which a computer retrieves a program instruction from memory, determines what actions are required, and then carries out those actions. Here’s a step-by-step breakdown of this cycle:
Program Counter (PC) Points to the Next Instruction:
The Program Counter holds the address of the next instruction to be executed.
Instruction Fetch:
The Control Unit sends the address in the Program Counter to the memory unit to fetch the instruction located at that address.
Instruction Loaded into Instruction Register (IR):
The instruction is fetched from memory and loaded into the Instruction Register.
Increment Program Counter (PC):
The Program Counter is incremented to point to the next instruction in sequence. This prepares the system to fetch the next instruction in the following cycle.
Instruction Decoding:
The Control Unit reads the instruction from the Instruction Register and decodes it to determine what actions are needed.
Identify Operand(s) and Opcode:
The instruction is typically divided into two parts: the opcode (operation code) which specifies the operation to be performed, and the operand(s) which are the data or addresses involved in the operation.
Load Necessary Data:
If the instruction requires additional data, such as an operand located in memory, the Control Unit will fetch this data from the specified memory address or register.
Execute the Instruction:
The Control Unit sends the decoded information to the relevant components of the CPU to carry out the instruction. This may involve arithmetic or logic operations, data movement, or control operations.
Perform ALU Operations:
If the instruction involves arithmetic or logic operations, the Arithmetic Logic Unit (ALU) performs the specified operation on the data.
Write Back Results:
The result of the operation is written back to a register or memory location, as specified by the instruction.
Update Status Register:
The Status Register (or Flags Register) is updated based on the outcome of the operation (e.g., setting flags for zero, carry, overflow, etc.).
Cycle Repeats:
The cycle repeats from the fetch step, now with the Program Counter pointing to the next instruction.
We need persistent storage to be able to keep all our files and data for later use. It allows us to permanently store a variety of data. Persistent storage is important as without it, data would be lost when the computer was turned off due to RAM being volatile.
History of Storage:
The Solectron Tube (32 to 512 bytes)
Punch Cards (input both programs and data)
Punched Tape
Magnetic Drum Memory (around 10kB)
Hard Disk Drive (5 million characters – just under 5 MB 1956, 2.52GB)
An operating system is a group of computer programs that co-ordinates all the activities among computer hardware devices. It is the first program loaded into the computer by a boot program and always remains in memory.
The basic functions of an operating system are:
Booting the computer
Performs basic computer tasks e.g. managing the various peripheral devices e.g. mouse, keyboard.
Provides a user interface, e.g. command line, graphical user interface (GUI).
Handles system resources such as a computer’s memory and sharing of the central processing unit (CPU) time by various applications or peripheral devices.
Provides file management which refers to the way that the operating system manipulates, stores, retrieves and saves data.
Booting the computer:
The process of starting or restarting the computer is known as booting.
A cold boot is when you turn on a computer that has been turned off completely.
A warm boot is the process of using the operating system to restart the computer.
User Interface (UI)
Definition: The means by which the user interacts with the computer system.
Types:
Graphical User Interface (GUI): Features icons, windows, and menus.
Command Line Interface (CLI): Requires text commands.
Importance: Provides an accessible and intuitive way for users to interact with the computer and execute commands.
Memory Management
Definition: The process of managing the computer's memory resources.
Functions:
Allocation and Deallocation: Assigns memory to processes and reclaims it when no longer needed.
Virtual Memory: Extends physical memory by using disk space.
Segmentation and Paging: Divides memory into segments and pages for efficient management.
Importance: Ensures efficient utilization of memory, prevents memory leaks, and provides isolation between processes.
Peripheral Management
Definition: The control and management of peripheral devices such as printers, scanners, and external drives.
Functions:
Device Drivers: Software that communicates with hardware devices.
I/O Operations: Manages input and output operations between the system and peripherals.
Importance: Facilitates the communication between the computer and external devices, ensuring they function correctly.
Multitasking
Definition: The ability of the OS to execute multiple tasks simultaneously.
Functions:
Process Scheduling: Determines the order and time allocation for processes.
Context Switching: Saves and restores the state of processes for smooth execution.
Importance: Enhances the efficiency of the computer by allowing multiple applications to run concurrently, improving user productivity.
Security
Definition: The mechanisms implemented to protect the system and data from unauthorized access and threats.
Functions:
User Authentication: Verifies the identity of users through passwords, biometrics, etc.
Access Control: Manages permissions for users and processes to access resources.
Encryption: Protects data confidentiality by encoding it.
Firewall and Antivirus: Defends against external threats and malware.
Importance: Ensures the integrity, confidentiality, and availability of data and resources, protecting the system from attacks and unauthorized access.
Word Processors (e.g., LibreOffice Writer, Google Docs)
Definition: A program for storing, manipulating, and formatting text entered from a keyboard and providing a printout.
Functions:
Text editing and formatting
Spell checking and grammar correction
Insert images, tables, and other multimedia
Save and export documents in various formats
Spreadsheets (e.g., Google Sheets, LibreOffice Calc)
Definition: A program in which data is arranged in the rows and columns of a grid and can be manipulated and used in calculations.
Functions:
Organize data in cells, rows, and columns
Perform mathematical and statistical calculations
Create charts and graphs for data visualization
Use functions and formulas for data analysis
Database Management Systems (DBMS) (e.g., MySQL, PostgreSQL)
Definition: System software for creating and managing databases. The DBMS provides users and programmers with a systematic way to create, retrieve, update, and manage data.
Functions:
Data storage, retrieval, and updating
Database creation and management
Query processing and optimization
Ensuring data integrity and security
Providing support for multi-user access and concurrency control
Email Clients (e.g., Microsoft Outlook, Mozilla Thunderbird)
Definition: A computer program used to access and manage a user's email.
Functions:
Send and receive emails
Organize emails into folders and categories
Manage contacts and address books
Support for multiple email accounts
Email filtering and spam detection
Web Browsers (e.g., Mozilla Firefox, Google Chrome)
Definition: A software application for retrieving, presenting, and traversing information resources on the World Wide Web.
Functions:
Display web pages and multimedia content
Navigate between pages using hyperlinks
Support for various web standards (HTML, CSS, JavaScript)
Bookmarks and history management
Extensions and plugins for additional functionality
Computer-Aided Design (CAD) (e.g., AutoCAD, SolidWorks)
Definition: Programs that use computer systems to assist in the creation, modification, analysis, or optimization of a design.
Functions:
Create detailed 2D and 3D models
Draft technical drawings and schematics
Simulate and analyze designs for stress, heat, and other factors
Generate blueprints and specifications
Enhance productivity and accuracy in the design process
Graphic Processing Software (e.g., Adobe Photoshop, GIMP)
Definition: Graphics software or image editing software is a program or collection of programs that enable a person to manipulate visual images on a computer.
Functions:
Edit and enhance digital images
Create and manipulate raster and vector graphics
Apply filters, effects, and transformations
Work with layers and masks for complex compositions
Export images in various formats for print and web use
Toolbars
Definition: A set of icons or buttons that are part of a software program's interface or an open window.
Functions: Provide quick access to frequently used commands and functions.
Menus
Definition: A list of options or commands presented to the user.
Functions: Allow users to choose actions or settings by selecting from a list.
Dialogue Boxes
Definition: A small window that prompts the user to provide information or make decisions.
Functions: Facilitate user input, display messages, and provide options or settings for tasks.
GUI Components
Graphical User Interface (GUI):
Definition: A user interface that includes graphical elements like windows, icons, and buttons.
User-Friendly: Provides an intuitive way for users to interact with the computer using visual elements.
Components:
Windows: Rectangular areas on the screen where applications run.
Icons: Pictures or symbols representing software applications or hardware devices.
Menus: Lists of options from which users can choose actions.
Pointers: Symbols (e.g., an arrow) that move around the screen with mouse movement, helping users select objects.
WIMP Interface (Windows, Icons, Menus, Pointers):
Windows: Rectangular sections on the screen that display content and applications.
Icons: Visual representations of applications, files, or functions.
Menus: Organized lists of commands and options.
Pointers: Moveable symbols that facilitate interaction with screen elements.
OS-Provided Features:
Standard Interface Elements: Certain parts of the user interface, such as menu bars and buttons, are provided by libraries in the operating system.
Consistency: Ensures a consistent look and feel across different applications.
Application-Specific Features:
Customization: Applications can customize specific aspects of the interface, such as icons, pictures, and specific functionalities.
Unique Elements: Each application may have unique features and designs to enhance its specific use case.
Menu Bar and Buttons:
Standard Elements: The structure and behavior of menu bars and buttons are often provided by the OS.
Application Customization: The specific icons, pictures, and additional features of the menu bar and buttons are defined by the individual application.
A Command Line Interface allows the user to interact directly with the computer system by typing in commands (instructions) into a screen which looks like the one below:
Before Windows was developed, this type of user interface was what most people used to get the computer to follow instructions.
It is still around though, for example a technician setting up a server in a data centre might use a command line interface or a mainframe administrator setting up a configuration file.
The main disadvantage of a command line interface is that the person must have detailed knowledge of the command that can be used.
Bit
Definition: A ‘bit’ (short for ‘binary digit’) is the smallest unit of data that can be stored by a computer.
Representation: Each ‘bit’ is represented as a binary number, either 1 (true) or 0 (false).
Nibble
Definition: A nibble consists of 4 bits.
Byte
Definition: Contains 8 bits.
Example: A byte could be stored as 11101001.
Usage: A single keyboard character that you type takes up one byte of storage.
Denary / Decimal
Definition: Base 10 number system.
Usage: In our everyday lives, we use a ‘denary’ number system which has the number digits 0, 1, 2, 3, 4, 5, 6, 7, 8, and 9 (a ‘base-10’ number system).
Examples: 5, 24, 316, 8715.
Hexadecimal
Definition: Numbers using the base-16 notation.
Usage: Hexadecimal numbers use the digits 0-9 and the letters A-F to represent values.
The decimal numbers 10 to 15 are represented with the letters A to F. There are 16 values, hence why it is a base-16 number system (this means that it represents everything using just 16 symbols)
Often used when programming because hex is easier to remember than binary but faster to run than denary which is normal base 10.
Hex can be used to represent anything, but you only need to know how it’s used to represent numbers. You need to be able to convert from denary to hex and back.
To convert to hex:
Take your decimal number and convert it into binary
Split the 8-bit binary into two four-bit section
Convert each four-bit section into a denary
Hex can only use 0-9 and A-F so any number 10 or above will be represented with a letter.
Allowed Hexadecimal digits are:
AND
Definition: The output is true when both A and B are true.
Truth Table:
A = True, B = True → Output = True
A = True, B = False → Output = False
A = False, B = True → Output = False
A = False, B = False → Output = False
OR
Definition: The output is true when either A is true, B is true, or both are true.
Truth Table:
A = True, B = True → Output = True
A = True, B = False → Output = True
A = False, B = True → Output = True
A = False, B = False → Output = False
NOT
Definition: The output is true when the input is false (unary operator).
Truth Table:
A = True → Output = False
A = False → Output = True
XOR (Exclusive OR)
Definition: The output is true when either A is true or B is true, but not when both are true.
Truth Table:
A = True, B = True → Output = False
A = True, B = False → Output = True
A = False, B = True → Output = True
A = False, B = False → Output = False
NAND
Definition: The output is true when not both A and B are true (the opposite of AND).
Truth Table:
A = True, B = True → Output = False
A = True, B = False → Output = True
A = False, B = True → Output = True
A = False, B = False → Output = True
NOR
Definition: The output is true when neither A is true nor B is true (the opposite of OR).
Truth Table:
A = True, B = True → Output = False
A = True, B = False → Output = False
A = False, B = True → Output = False
A = False, B = False → Output = True