Download presentation
Presentation is loading. Please wait.
Published byArabella Hines Modified over 9 years ago
1
COMP1070/2002/lec1/H.Melikian COMP1070 Lecture #2 Computers and Computer Languages Some terminology What is Software? Operating Systems
2
COMP1070/2002/lec1/H.Melikian Administrivia Class web page http://wbambi.acc.nccu.edu/~melikian/cs_intrcom not much there yet, but keep your eyes on it. Almost everything from the Blackboard will be here except your grades, online staff ( exams, quizzes) and solutions
3
COMP1070/2002/lec1/H.Melikian Understanding computers How does a computer work? – Idiot savant – Very good with a small number of tasks – Completely clueless otherwise What can computers do well? – store and retrieve numbers – very quickly – very accurately – add, subtract, multiply, and divide – also fast and accurate – compare numbers (with 0) – follow a list of instructions and jump around in the list
4
COMP1070/2002/lec1/H.Melikian What about everything else? – more complex math combination of atomic operations – interaction with peripheral devices output: graphics cards and printers input: keyboards, mice, joysticks all sorts of specialized devices – everything done using numbers
5
COMP1070/2002/lec1/H.Melikian Computer numbers To the computer, everything is numbers. Computers use binary (base 2) – each digit is 0 or 1 – represents a power of 2 human numbers : You are familiar with decimal d n d n-1 d n-2... d 2 d 1 d 0 d n 10 n + d n-1 10 n-1 + d n-2 10 n-2... d 2 10 2 + d 1 10 1 + d 0 10 0 38649 3 10 4 + 8 10 3 + 6 10 2 + 4 10 1 + 9 10 0
6
COMP1070/2002/lec1/H.Melikian binary b n b n-1 b n-2 … b 2 b 1 b 0 b n 2 n + b n-1 2 n-1 + b n-2 2 n-2 … b 2 2 2 + b 1 2 1 + b 0 2 0 Example: 10110110 1 2 7 + 0 2 6 + 1 2 5 + 1 2 4 + 0 2 3 + 1 2 2 + 1 2 1 + 0 2 0 1 128 + 0 64 + 1 32 + 1 16 + 0 8 + 1 4 + 1 2 + 0 1 128 + 32 + 16 + 4 + 2 = 182
7
COMP1070/2002/lec1/H.Melikian More teminology bit: binary digit byte: a group of 8 bits word: a group of bytes that a specific computer is optimized for working with (usually 4 or 8) kilobyte (K or KB): 1,000 bytes, or sometimes 1,024 bytes (2 10 ) megabyte (M or MB): 1,000,000 bytes, or sometimes 1,028,576 bytes (2 20 )
8
COMP1070/2002/lec1/H.Melikian why all these powers of 2? Everything is little electronic switches – off or on, true or false, 0 or 1 Decimal is foreign to the computer – it can convert a number to decimal, but that’s really only for human convenience other numbering systems octal – base 8 – used rarely, but you should at least recognize it – digits are 0 through 7 3264 = 3 8 3 + 2 8 2 + 6 8 1 + 4 8 0 = 3 512 + 2 64 + 6 8 + 4 = 1536 + 128 + 48 + 4 = 1716
9
COMP1070/2002/lec1/H.Melikian hexadecimal ( base 16) – used occasionally – you can’t really avoid it – digits are 0-9, a-f 8b7e = 8 16 3 + 11 16 2 + 7 16 1 + 14 16 0 = 8 4096 + 11 256 + 7 16 + 14 = 32768 + 2816 + 112 + 14 = 35710 other numbering systems v You do not have to be fluent in either of these (octal or hex) for this class recognize them, don’t be scared of them v know how to convert if you need to but you will rarely need to
10
COMP1070/2002/lec1/H.Melikian inside the computer… Everything is bits Bits are always grouped – into bytes – into words Every byte is numbered – sequential – called an address – addresses are, of course, numbers themselves Computers execute computer instructions Instructions are numbers – memory access (get/put) – arithmetic (add, subtract, multiply, divide) – compare values (equal, greater than, less than) – change the order instructions are executed in often based on the result of a comparison
11
COMP1070/2002/lec1/H.Melikian The machine cycle
12
COMP1070/2002/lec1/H.Melikian what kinds of numbers do computers work with? Instructions, Addresses, Data– integers, real numbers – text – all sorts of other things What is a computer program? - A sequence of processor instructions designed to achieve a specific purpose Computers execute programs sequentially like driving directions – each instruction depends on the last one being completed
13
COMP1070/2002/lec1/H.Melikian What is a computer program? Each instruction has a numerical code Examples: – Get some data from memory – Add two numbers – If two numbers are equal, jump to a different part of the program Instructions are numbers This is important!
14
COMP1070/2002/lec1/H.Melikian Only numbers! 00401040 55 8B EC 83 EC 5C 53 56 57 6A 00 FF 15 B8 C2 42 00401050 00 89 45 FC 83 7D FC 00 7D 1B 68 0F 10 40 00 68 00401060 14 61 42 00 B9 E8 99 42 00 E8 32 05 00 00 8B C8 00401070 E8 90 FF FF FF 8D 45 EC 50 8B 0D 50 8D 42 00 51 00401080 FF 15 C0 C2 42 00 89 45 FC 83 7D FC 00 7D 20 68 00401090 0F 10 40 00 68 F8 60 42 00 B9 E8 99 42 00 E8 FD 004010A0 04 00 00 8B C8 E8 5B FF FF FF E9 9C 00 00 00 68 004010B0 0F 10 40 00 68 D8 60 42 00 B9 E8 99 42 00 E8 DD 004010C0 04 00 00 8B C8 E8 3B FF FF FF 8D 55 E4 52 68 28 004010D0 71 42 00 6A 01 6A 00 68 18 71 42 00 FF 15 C4 C2 004010E0 42 00 89 45 FC 83 7D FC 00 7C 1D 68 0F 10 40 00 004010F0 68 B4 60 42 00 B9 E8 99 42 00 E8 A1 04 00 00 8B 00401100 C8 E8 FF FE FF FF EB 43 8B 45 FC 50 68 88 60 42 00401110 00 E8 6A 25 00 00 83 C4 08 68 0F 10 40 00 68 84 00401120 60 42 00 8B 4D FC 51 68 60 60 42 00 B9 E8 99 42 00401130 00 E8 6A 04 00 00 8B C8 E8 33 01 00 00 8B C8 E8 00401140 5C 04 00 00 8B C8 E8 BA FE FF FF FF 15 BC C2 42
15
COMP1070/2002/lec1/H.Melikian 00401040 push ebp 00401041 mov ebp,esp 00401043 sub esp,5Ch 00401046 push ebx 00401047 push esi 00401048 push edi 00401049 push 0 0040104B call dword ptr [__imp__CoInitialize@4 (0042c2b8)] 00401051 mov dword ptr [ebp-4],eax 00401054 cmp dword ptr [ebp-4],0 00401058 jge main+35h (00401075) 0040105A push offset @ILT+10(endl) (0040100f) 0040105F push offset string "CoInitialize failed." (00426114) 00401064 mov ecx,offset cout (004299e8) 00401069 call ostream::operator<< (004015a0) 0040106E mov ecx,eax v 00401070 call @ILT+0(ostream::operator<<) (00401005) Part 1
16
COMP1070/2002/lec1/H.Melikian Part 2 00401075 lea eax,[ebp-14h] 00401078 push eax 00401079 mov ecx,dword ptr [pid (00428d50)] 0040107F push ecx 00401080 call dword ptr [__imp__CLSIDFromProgID@8 (0042c2c0)] 00401086 mov dword ptr [ebp-4],eax 00401089 cmp dword ptr [ebp-4],0 0040108D jge main+6Fh (004010af) 0040108F push offset @ILT+10(endl) (0040100f) 00401094 push offset string "CLSIDFromProgID failed." (004260f8) 00401099 mov ecx,offset cout (004299e8) 0040109E call ostream::operator<< (004015a0) 004010A3 mov ecx,eax 004010A5 call @ILT+0(ostream::operator<<) (00401005) 004010AA jmp main+10Bh (0040114b) 004010AF push offset @ILT+10(endl) (0040100f) 004010B4 push offset string "CLSIDFromProgID succeeded." (004260d8)
17
COMP1070/2002/lec1/H.Melikian machine language The one “true” computer language – …except there isn’t just one Every computer has its own machine language All other computer languages created for human convenience The computer doesn’t understand C Must be converted into machine language computer languages Assembler ;essentially just machine language with some text codes Compiled languages ;converted into machine language before use – examples: C, Pascal, Fortran Interpreted languages; converted into machine language during use – examples: Basic, Java
18
COMP1070/2002/lec1/H.Melikian Why more than one? Meet different needs, Tradeoffs, Different approaches Special features Application domain – programmer prefers to think about the application Computer domain – programmer is willing to think about the computer Tradeoffs Control, Ease-of-programming, Performance flexibility different approaches Procedural Object-oriented Special features There are lots of special-purpose languages
19
COMP1070/2002/lec1/H.Melikian HW #2 Please send the solutions via email to gmelikian@wpo.nccu.edu and hand in hard copy by the beginning of the class
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.