Presentation is loading. Please wait.

Presentation is loading. Please wait.

Programming Languages and Translators

Similar presentations


Presentation on theme: "Programming Languages and Translators"— Presentation transcript:

1 Programming Languages and Translators
Ashima Wadhwa Assistant Professor (giBS)

2 LANGUAGE GENERATIONS Classification 1st Machine languages 2nd
Assembly languages 3rd Procedural languages 4th Application languages (4GLs) 5th AI techniques, inference languages 6th Neural networks , others….

3 Programming Languages
A computer program resides in primary memory where it is represented as a set of machine instructions which in turn are represented as sequences of binary digits. At any point in time the computer is said to be in a particular state. A central feature of the state is the instruction pointer which points to the next machine instruction to be executed. The execution sequence of a group of machine instructions is known as the flow of control.

4 EVOLUTION To write a program for a computer, we must use a computer language. A computer language is a set of predefined words that are combined into a program according to predefined rules (syntax). Over the years, computer languages have evolved from machine language to high-level languages.

5 Machine languages In the earliest days of computers, the only programming languages available were machine languages. Each computer had its own machine language, which was made of streams of 0s and 1s.

6 A machine’s own language
For understanding how computers work, we need familiarity with the computer’s own language (called “machine language”) It’s LOW-LEVEL language (very detailed) It is specific to a machine’s “architecture” It is a language “spoken” using voltages Humans represent it with zeros and ones

7 Example of machine-language
Here’s what a program-fragment looks like: It means: z = x + y;

8 Assembly languages The next evolution in programming came with the idea of replacing binary code for instruction and addresses with symbols or mnemonics. Because they used symbols, these languages were first known as symbolic languages. The set of these mnemonic languages were later referred to as assembly languages.

9 Hence assembly language
There are two key ideas: -- mnemonic opcodes: we use abbreviations of English language words to denote operations -- symbolic addresses: we invent “meaningful” names for memory storage locations we need These make machine-language understandable to humans – if they know their machine’s design Let’s see our example-program, rewritten using actual “assembly language” for Intel’s Pentium

10

11 High-level languages Although assembly languages greatly improved programming efficiency, they still required programmers to concentrate on the hardware they were using. Working with symbolic languages was also very tedious, because each machine instruction had to be individually coded. The desire to improve programmer efficiency and to change the focus from the computer to the problem being solved led to the development of high-level languages. Over the years, various languages, most notably BASIC, COBOL, Pascal, Ada, C, C++ and Java, were developed.

12 High-Level Language Most programming nowdays is done using so-called “high-level” languages (such as FORTRAN, BASIC, COBOL, PASCAL, C, C++, JAVA, SCHEME, Lisp, ADA, etc.) These languages deliberately “hide” from a programmer many details concerning HOW his problem actually will be solved by the underlying computing machinery

13 The BASIC language Some languages allow programmers to forget about the computer completely! The language can express a computing problem with a few words of English, plus formulas familiar from high-school algebra EXAMPLE PROBLEM: Compute 4 plus 5

14 The example in BASIC LET X = 4 LET Y = 5 LET Z = X + Y
PRINT X, “+”, Y, “=“, Z END Output: = 9

15 The object-oriented paradigm
The object-oriented paradigm deals with active objects instead of passive objects. We encounter many active objects in our daily life: a vehicle, an automatic door, a dishwasher and so on. The action to be performed on these objects are included in the object: the objects need only to receive the appropriate stimulus from outside to perform one of the actions. A file in an object-oriented paradigm can be packed with all the procedures—called methods in the object-oriented paradigm—to be performed by the file: printing, copying, deleting and so on. The program in this paradigm just sends the corresponding request to the object.

16 Some object-oriented languages
Java

17 TRANSLATION Programs today are normally written in one of the high-level languages. To run the program on a computer, the program needs to be translated into the machine language of the computer on which it will run. The program in a high-level language is called the source program. The translated program in machine language is called the object program. Two methods are used for translation: compilation and interpretation.

18 Translation process Compilation and interpretation differ in that the first translates the whole source code before executing it, while the second translates and executes the source code a line at a time. Source code translation process

19 Translation process  lexical analysis is the process of converting a sequence of characters into a sequence of tokens, i.e. meaningful character strings. syntax of a computer language is the set of rules that defines the combinations of symbols that are considered to be a correctly structured document or fragment in that language.

20 ASSEMBLER To convert the assembly language into machine code.
Translate mnemonic operation codes to their machine language equivalents. Assigning machine addresses to symbolic labels.

21 Working of Assembler Programmer write a program using a sequence of assemble instructions. This sequence of assembler instructions, known as the source code/source program, then specified to the assembler program when that program is started. It translates a source code into machine language. The output of the assembler program is called the object code or object program.

22 Compilers Translates high-level language into low-level instructions
High-level language: Source code Machine-level: Object code Changes, including bug fixes, require recompiling

23 Interpreters Translates source code instructions into machine language and executes it one statement at a time Disadvantages Longer to execute, particularly bad for loops Uses more memory Advantage Faster testing and code modification Examples of interpreted languages Java, BASIC, LISP

24 Queries?


Download ppt "Programming Languages and Translators"

Similar presentations


Ads by Google