Instructor : HUSSAIN IBRAHIM
Govt: College of Technology Hyderabad.
Email: amur.hb@gmail.com
INTRODUCTION TO COMUTER PROGRAMMING
(COMP-112)
 What is a programming language?
Why are there so many programming languages?
What are the types of programming languages?
Does the world need new languages?



A programming language is a set of rules that
provides a way of telling a computer what
operations to perform.
A programming language is a set of rules for
communicating an algorithm
It provides a linguistic framework for
describing computations



A programming language is a notational system for
describing computation in a machine-readable and
human-readable form.
A programming language is a tool for developing
executable models for a class of problem domains.
PS — Introduction
A programming language is a tool for developing
executable models for a class of problem domains.
A programming language is a notational system for
describing computation in a machine-readable and
human-readable form.
English is a natural language. It has words,
symbols and grammatical rules.
A programming language also has words,
symbols and rules of grammar.
The grammatical rules are called syntax.
Each programming language has a different
of syntax rules.


 set
Why does some people speak French?
Programming languages have evolved over time as
better ways have been developed to design them.
◦ First programming languages were developed in the
1950s
◦ Since then thousands of languages have been developed
Different programming languages are designed for
different types of programs.



class Triangle {
...
float surface()
return b*h/2;
}
LOAD r1,b
LOAD r2,h
MUL r1,r2
DIV r1,#2
RET
0001001001000101
0010010011101100
10101101001...
High-level program
Low-level program
Executable Machine code 0001001001000101
0010010011101100
10101101001...
LOAD r1,b
LOAD r2,h
MUL r1,r2
DIV r1,#2
RET
class Triangle {
...
float surface()
return b*h/2;
}
First Generation Languages
Second Generation Languages
Third Generation Languages
Fourth Generation Languages
Fifth Generation Languages





Machine language
◦
◦
◦
Operation code – such as addition or subtraction.
Operands – that identify the data to be processed.
Machine language is machine dependent as it is the
only language the computer can understand.
Very efficient code but very difficult to write.◦
Assembly languages
◦ Symbolic operation codes replaced binary operation
codes.
Assembly language programs needed to be “assembled”◦
for execution by the computer. Each assembly language
instruction is translated into one machine language
instruction.
Very efficient code and easier to write.◦
Closer to English but included simple
mathematical notation.

◦ Programs written in source code which must be
translated into machine language programs called object
code.
The translation of source code to object code is
accomplished by a machine language system program
called a compiler.
◦
Alternative to compilation is interpretation which is
accomplished by a system program called
interpreter.
an
Common third generation languages
◦
◦
◦
◦
FORTRAN
COBOL
C and C++
Visual Basic
A high level language (4GL) that requires fewer
instructions to accomplish
generation language.
Used with databases
a task than a third

◦
◦
◦
◦
Query languages
Report generators
Forms designers
Application generators
Declarative languages
Functional(?): Lisp, Scheme,
◦ Also called applicative
◦ Everything is a function

SML
Logic: Prolog
◦ Based on mathematical logic
◦ Rule- or Constraint-based
Though no clear definition at present, natural
language programs generally can be interpreted
and executed by the computer with no other
action by the user than stating their question.
Limited capabilities at present.


Imperative Programming (C)
Object-Oriented Programming (C++)
Logic/Declarative Programming (Prolog)
Functional/Applicative Programming (Lisp)




Two broad groups
◦ Traditional programming languages


Sequences of instructions
First, second and some third generation languages
◦ Object-oriented languages


Objects are created rather than sequences of instructions
Some third generation, and fourth and fifth generation
languages
FORTRAN
◦
◦
◦
FORmula TRANslation.
Developed at IBM in the mid-1950s.
Designed for scientific and mathematical applications by
scientists and engineers.
COBOL
◦
◦
◦
◦
COmmon Business Oriented Language.
Developed in 1959.
Designed to be common to many different computers.
Typically used for business applications.
BASIC
◦
◦
◦
Beginner’s
Developed
Developed
All-purpose Symbolic Instruction Code.
at Dartmouth College in mid 1960s.
as a simple language for students to write
programs with which they could interact through
terminals.
C
◦
◦

Developed by Bell Laboratories in the early 1970s.
Provides control and efficiency of assembly language
while having third generation language features.
Often used for system programs.
UNIX is written in C.
◦
◦
Simula
◦ First object-oriented language
◦ Developed by Ole Johan Dahl in the 1960s.
Smalltalk


◦
◦
◦
First purely object-oriented language.
Developed by Xerox in mid-1970s.
Still in use on some computers.
C++
◦
◦
It is C language with additional features.
Widely used for developing system and application
software.
Graphical user interfaces can be developed easily with
visual programming tools.
◦
JAVA
◦ An object-oriented language similar to C++ that
eliminates lots of C++’s problematic features
Allows a web page developer to create programs for
applications, called applets that can be used through a
browser.
Objective of JAVA developers is that it be machine,
platform and operating system independent.
◦
◦
Scripting Languages
◦
◦
◦
JavaScript and VBScript
Php and ASP
Perl and Python
Command Languages
◦ sh, csh, bash
Text processing Languages
◦ LaTex, PostScript

HTML
◦
◦
◦
HyperText Markup Language.
Used on the Internet and the World Wide Web (WWW).
Web page developer puts brief codes called tags in the
page to indicate how the page should be formatted.
XML
◦ Extensible Markup Language.
◦ A language for defining other languages.

Programming languages are languages
When it comes to mechanics of the task,
learning to speak and use a programming
language is in many ways like learning to speak
a human language
In both kind of languages you have to learn new
vocabulary, syntax and semantics (new words,
sentence structure and meaning)
And both kind of language require considerable
practice to make perfect.




Computer languages
vagueness
In English sentences
lack ambiguity and
such as I saw the man with a
telescope (Who had the telescope?) or Take a
pinch of salt (How much is a pinch?)
In a programming language a sentence either
means one thing or it means nothing

Formerly: Run-time performance
◦ (Computers were more expensive than programmers)
Now: Life cycle (human) cost is more important
◦
◦
◦
◦
Ease of designing,
Debugging
Maintenance
Reusability
coding
FADS
Writability: The quality of a language that enables a
programmer to use it to express a computation clearly,
correctly, concisely, and quickly.
Readability: The quality of a language that enables a
programmer to understand and comprehend the nature of a
computation easily and accurately.
Reliability: The quality of a language that assures a program
will not behave in unexpected or disastrous ways during
execution.
Maintainability: The quality of a language that eases errors
can be found and corrected and new features added.





ProgrammingCycleSteps
1. TrytounderstandandanalyzetheProblem.
2. Writethealgorithmordrawtheflowchartfortheproblem
3. CreateTheSourcefileusingeditorandthecodeaccordingtothe
flowchartoralgorithm.
4. CompileTheprogramusingsystemsoftwareandtheobjectfileis
created.
5. Step4isrepeatdtillthesourceprogramcontainsnocompilation
errorsthanstep6.
6. Linkthenecessarylibraryfilesneededforthecompilationerrors.
7. Loadthefileforexecution.
8. Executetheprogramusingtherunoption.
Flowchart
 A flowchart is a type of diagram that
represents a workflow or process. A flowchart
can also be defined as a diagrammatic
representation of an algorithm, a step-by-step
approach to solving a task.
 The flowchart shows the steps as boxes of
various kinds, and their order by connecting
the boxes with arrows.
 Flowcharts are used in analyzing, designing,
documenting or managing a process or
program in various fields.
Common symbols
Rectangle Shape - Represents a process
Oval or Pill Shape - Represents the start
or end
Diamond Shape - Represents a decision
Parallelogram - Represents input/output
Example
Terms
HARDWARE – Computer hardware includes
the physical, tangible parts or components of
a computer, such as the cabinet, central processing
unit, monitor, keyboard, computer data
storage, graphics card, sound
card, speakers and motherboard
software, is a collection of data or computer instructions
that tell the computer how to work.
Peopleware is a term used to refer to one of the three core
aspects of computer technology, the other two being hardware
and software .
Peopleware can refer to anything that has to do with the role of
people in the development or use of computer software and
hardware systems, including such issues as developer
productivity, teamwork, group dynamics, the psychology of
programming, project management, organizational factors,
human interface design, and human-machine-interaction.
Peopleware
Introduction To Computer Programming

Introduction To Computer Programming

  • 1.
    Instructor : HUSSAINIBRAHIM Govt: College of Technology Hyderabad. Email: [email protected] INTRODUCTION TO COMUTER PROGRAMMING (COMP-112)
  • 2.
     What isa programming language? Why are there so many programming languages? What are the types of programming languages? Does the world need new languages?   
  • 3.
    A programming languageis a set of rules that provides a way of telling a computer what operations to perform. A programming language is a set of rules for communicating an algorithm It provides a linguistic framework for describing computations   
  • 4.
    A programming languageis a notational system for describing computation in a machine-readable and human-readable form. A programming language is a tool for developing executable models for a class of problem domains. PS — Introduction A programming language is a tool for developing executable models for a class of problem domains. A programming language is a notational system for describing computation in a machine-readable and human-readable form.
  • 5.
    English is anatural language. It has words, symbols and grammatical rules. A programming language also has words, symbols and rules of grammar. The grammatical rules are called syntax. Each programming language has a different of syntax rules.    set
  • 6.
    Why does somepeople speak French? Programming languages have evolved over time as better ways have been developed to design them. ◦ First programming languages were developed in the 1950s ◦ Since then thousands of languages have been developed Different programming languages are designed for different types of programs.   
  • 7.
    class Triangle { ... floatsurface() return b*h/2; } LOAD r1,b LOAD r2,h MUL r1,r2 DIV r1,#2 RET 0001001001000101 0010010011101100 10101101001... High-level program Low-level program Executable Machine code 0001001001000101 0010010011101100 10101101001... LOAD r1,b LOAD r2,h MUL r1,r2 DIV r1,#2 RET class Triangle { ... float surface() return b*h/2; }
  • 8.
    First Generation Languages SecondGeneration Languages Third Generation Languages Fourth Generation Languages Fifth Generation Languages     
  • 9.
    Machine language ◦ ◦ ◦ Operation code– such as addition or subtraction. Operands – that identify the data to be processed. Machine language is machine dependent as it is the only language the computer can understand. Very efficient code but very difficult to write.◦
  • 10.
    Assembly languages ◦ Symbolicoperation codes replaced binary operation codes. Assembly language programs needed to be “assembled”◦ for execution by the computer. Each assembly language instruction is translated into one machine language instruction. Very efficient code and easier to write.◦
  • 11.
    Closer to Englishbut included simple mathematical notation.  ◦ Programs written in source code which must be translated into machine language programs called object code. The translation of source code to object code is accomplished by a machine language system program called a compiler. ◦
  • 12.
    Alternative to compilationis interpretation which is accomplished by a system program called interpreter. an Common third generation languages ◦ ◦ ◦ ◦ FORTRAN COBOL C and C++ Visual Basic
  • 13.
    A high levellanguage (4GL) that requires fewer instructions to accomplish generation language. Used with databases a task than a third  ◦ ◦ ◦ ◦ Query languages Report generators Forms designers Application generators
  • 14.
    Declarative languages Functional(?): Lisp,Scheme, ◦ Also called applicative ◦ Everything is a function  SML Logic: Prolog ◦ Based on mathematical logic ◦ Rule- or Constraint-based
  • 15.
    Though no cleardefinition at present, natural language programs generally can be interpreted and executed by the computer with no other action by the user than stating their question. Limited capabilities at present.  
  • 16.
    Imperative Programming (C) Object-OrientedProgramming (C++) Logic/Declarative Programming (Prolog) Functional/Applicative Programming (Lisp)    
  • 17.
    Two broad groups ◦Traditional programming languages   Sequences of instructions First, second and some third generation languages ◦ Object-oriented languages   Objects are created rather than sequences of instructions Some third generation, and fourth and fifth generation languages
  • 18.
    FORTRAN ◦ ◦ ◦ FORmula TRANslation. Developed atIBM in the mid-1950s. Designed for scientific and mathematical applications by scientists and engineers.
  • 19.
    COBOL ◦ ◦ ◦ ◦ COmmon Business OrientedLanguage. Developed in 1959. Designed to be common to many different computers. Typically used for business applications.
  • 20.
    BASIC ◦ ◦ ◦ Beginner’s Developed Developed All-purpose Symbolic InstructionCode. at Dartmouth College in mid 1960s. as a simple language for students to write programs with which they could interact through terminals.
  • 21.
    C ◦ ◦  Developed by BellLaboratories in the early 1970s. Provides control and efficiency of assembly language while having third generation language features. Often used for system programs. UNIX is written in C. ◦ ◦
  • 22.
    Simula ◦ First object-orientedlanguage ◦ Developed by Ole Johan Dahl in the 1960s. Smalltalk   ◦ ◦ ◦ First purely object-oriented language. Developed by Xerox in mid-1970s. Still in use on some computers.
  • 23.
    C++ ◦ ◦ It is Clanguage with additional features. Widely used for developing system and application software. Graphical user interfaces can be developed easily with visual programming tools. ◦
  • 24.
    JAVA ◦ An object-orientedlanguage similar to C++ that eliminates lots of C++’s problematic features Allows a web page developer to create programs for applications, called applets that can be used through a browser. Objective of JAVA developers is that it be machine, platform and operating system independent. ◦ ◦
  • 25.
    Scripting Languages ◦ ◦ ◦ JavaScript andVBScript Php and ASP Perl and Python Command Languages ◦ sh, csh, bash Text processing Languages ◦ LaTex, PostScript 
  • 26.
    HTML ◦ ◦ ◦ HyperText Markup Language. Usedon the Internet and the World Wide Web (WWW). Web page developer puts brief codes called tags in the page to indicate how the page should be formatted.
  • 27.
    XML ◦ Extensible MarkupLanguage. ◦ A language for defining other languages. 
  • 28.
    Programming languages arelanguages When it comes to mechanics of the task, learning to speak and use a programming language is in many ways like learning to speak a human language In both kind of languages you have to learn new vocabulary, syntax and semantics (new words, sentence structure and meaning) And both kind of language require considerable practice to make perfect.    
  • 29.
    Computer languages vagueness In Englishsentences lack ambiguity and such as I saw the man with a telescope (Who had the telescope?) or Take a pinch of salt (How much is a pinch?) In a programming language a sentence either means one thing or it means nothing 
  • 30.
    Formerly: Run-time performance ◦(Computers were more expensive than programmers) Now: Life cycle (human) cost is more important ◦ ◦ ◦ ◦ Ease of designing, Debugging Maintenance Reusability coding FADS
  • 31.
    Writability: The qualityof a language that enables a programmer to use it to express a computation clearly, correctly, concisely, and quickly. Readability: The quality of a language that enables a programmer to understand and comprehend the nature of a computation easily and accurately. Reliability: The quality of a language that assures a program will not behave in unexpected or disastrous ways during execution. Maintainability: The quality of a language that eases errors can be found and corrected and new features added.     
  • 32.
    ProgrammingCycleSteps 1. TrytounderstandandanalyzetheProblem. 2. Writethealgorithmordrawtheflowchartfortheproblem 3.CreateTheSourcefileusingeditorandthecodeaccordingtothe flowchartoralgorithm. 4. CompileTheprogramusingsystemsoftwareandtheobjectfileis created. 5. Step4isrepeatdtillthesourceprogramcontainsnocompilation errorsthanstep6. 6. Linkthenecessarylibraryfilesneededforthecompilationerrors. 7. Loadthefileforexecution. 8. Executetheprogramusingtherunoption.
  • 33.
    Flowchart  A flowchartis a type of diagram that represents a workflow or process. A flowchart can also be defined as a diagrammatic representation of an algorithm, a step-by-step approach to solving a task.  The flowchart shows the steps as boxes of various kinds, and their order by connecting the boxes with arrows.  Flowcharts are used in analyzing, designing, documenting or managing a process or program in various fields.
  • 34.
    Common symbols Rectangle Shape- Represents a process Oval or Pill Shape - Represents the start or end Diamond Shape - Represents a decision Parallelogram - Represents input/output
  • 35.
  • 36.
    Terms HARDWARE – Computerhardware includes the physical, tangible parts or components of a computer, such as the cabinet, central processing unit, monitor, keyboard, computer data storage, graphics card, sound card, speakers and motherboard software, is a collection of data or computer instructions that tell the computer how to work.
  • 37.
    Peopleware is aterm used to refer to one of the three core aspects of computer technology, the other two being hardware and software . Peopleware can refer to anything that has to do with the role of people in the development or use of computer software and hardware systems, including such issues as developer productivity, teamwork, group dynamics, the psychology of programming, project management, organizational factors, human interface design, and human-machine-interaction. Peopleware