(heavily based on last year s notes (Andrew Moore) with thanks to Alastair R. Beresford. 1. Types Variables Expressions & Statements 2/23

Similar documents
Structure of this course. C and C++ Past Exam Questions. Text books

Programming in C and C++

Programming in C and C++

Presented By : Gaurav Juneja

Object-Oriented Programming

Work relative to other classes

Control flow and string example. C and C++ Functions. Function type-system nasties. 2. Functions Preprocessor. Alastair R. Beresford.

CS 261 Fall C Introduction. Variables, Memory Model, Pointers, and Debugging. Mike Lam, Professor

C and C++ 2. Functions Preprocessor. Alan Mycroft

C Language Part 1 Digital Computer Concept and Practice Copyright 2012 by Jaejin Lee

C Introduction. Comparison w/ Java, Memory Model, and Pointers

Room 3P16 Telephone: extension ~irjohnson/uqc146s1.html

C-LANGUAGE CURRICULAM

Language Design COMS W4115. Prof. Stephen A. Edwards Spring 2003 Columbia University Department of Computer Science

Features of C. Portable Procedural / Modular Structured Language Statically typed Middle level language

IECD Institute for Entrepreneurship and Career Development Bharathidasan University, Tiruchirappalli 23.

Chapter 1 & 2 Introduction to C Language

Computers Programming Course 5. Iulian Năstac

Chapter 1 Introduction to Computers and C++ Programming

The component base of C language. Nguyễn Dũng Faculty of IT Hue College of Science

Contents. Figures. Tables. Examples. Foreword. Preface. 1 Basics of Java Programming 1. xix. xxi. xxiii. xxvii. xxix

Introduction to C++ Introduction. Structure of a C++ Program. Structure of a C++ Program. C++ widely-used general-purpose programming language

Variables Data types Variable I/O. C introduction. Variables. Variables 1 / 14

CE221 Programming in C++ Part 1 Introduction

Introduction to C++ with content from

Language Design COMS W4115. Prof. Stephen A. Edwards Fall 2006 Columbia University Department of Computer Science

Outline. 1 About the course

Writing an ANSI C Program Getting Ready to Program A First Program Variables, Expressions, and Assignments Initialization The Use of #define and

Differentiate Between Keywords and Identifiers

Programming in C and C++

Variables and literals

Review of the C Programming Language for Principles of Operating Systems

P.G.TRB - COMPUTER SCIENCE. c) data processing language d) none of the above

C OVERVIEW. C Overview. Goals speed portability allow access to features of the architecture speed

EL2310 Scientific Programming

Introduction to C Language

Fundamental of C programming. - Ompal Singh

C OVERVIEW BASIC C PROGRAM STRUCTURE. C Overview. Basic C Program Structure

A Fast Review of C Essentials Part I

UNIT- 3 Introduction to C++

C Programming Multiple. Choice

CSC 1107: Structured Programming

Preface... (vii) CHAPTER 1 INTRODUCTION TO COMPUTERS

6.096 Introduction to C++ January (IAP) 2009

Introduction to Programming Using Java (98-388)

Programming in C and Data Structures [15PCD13/23] 1. PROGRAMMING IN C AND DATA STRUCTURES [As per Choice Based Credit System (CBCS) scheme]

The C Language Reference Manual

Binghamton University. CS-120 Summer Introduction to C. Text: Introduction to Computer Systems : Chapters 11, 12, 14, 13

Main Program. C Programming Notes. #include <stdio.h> main() { printf( Hello ); } Comments: /* comment */ //comment. Dr. Karne Towson University

Axivion Bauhaus Suite Technical Factsheet MISRA

Continued from previous lecture

CS Programming In C

Typescript on LLVM Language Reference Manual

Laboratory 2: Programming Basics and Variables. Lecture notes: 1. A quick review of hello_comment.c 2. Some useful information

3. Java - Language Constructs I

C Language, Token, Keywords, Constant, variable

Types, Operators and Expressions

Character Set. The character set of C represents alphabet, digit or any symbol used to represent information. Digits 0, 1, 2, 3, 9

BCA-105 C Language What is C? History of C

C: How to Program. Week /Mar/05

File Handling in C. EECS 2031 Fall October 27, 2014

Review of the C Programming Language

I BCA[ ] SEMESTER I CORE: C PROGRAMMING - 106A Multiple Choice Questions.

Types, Operators and Expressions

The Waite Group's. New. Primer Plus. Second Edition. Mitchell Waite and Stephen Prata SAMS

C Language Summary. Chris J Michael 28 August CSC 4103 Operating Systems Fall 2008 Lecture 2 C Summary

Computer Science & Information Technology (CS) Rank under AIR 100. Examination Oriented Theory, Practice Set Key concepts, Analysis & Summary

CS313D: ADVANCED PROGRAMMING LANGUAGE

CSCE 110 PROGRAMMING FUNDAMENTALS

C++ Quick Guide. Advertisements

The Design of C: A Rational Reconstruction: Part 2

UNIT - I. Introduction to C Programming. BY A. Vijay Bharath

3. Except for strings, double quotes, identifiers, and keywords, C++ ignores all white space.

Chapter 2 - Introduction to C Programming

Data Types and Variables in C language

Binghamton University. CS-211 Fall Syntax. What the Compiler needs to understand your program

Motivation was to facilitate development of systems software, especially OS development.

ITC213: STRUCTURED PROGRAMMING. Bhaskar Shrestha National College of Computer Studies Tribhuvan University

Q1. Multiple Choice Questions

XSEDE Scholars Program Introduction to C Programming. John Lockman III June 7 th, 2012

COMP1917: Computing 1 1. Introduction

EL2310 Scientific Programming

CMSC 246 Systems Programming

C - Basics, Bitwise Operator. Zhaoguo Wang

Model Viva Questions for Programming in C lab

edunepal_info

Practical C++ Programming

University of Technology. Laser & Optoelectronics Engineering Department. C++ Lab.

Programming in C. What is C?... What is C?

1. Introduction. Course Web Site. COMP1917: Computing 1. Textbook. Occupational Health and Safety (OHS)

EL2310 Scientific Programming

CHAPTER 1 Introduction to Computers and Programming CHAPTER 2 Introduction to C++ ( Hexadecimal 0xF4 and Octal literals 031) cout Object

+2 Volume II OBJECT TECHNOLOGY OBJECTIVE QUESTIONS R.Sreenivasan SanThome HSS, Chennai-4. Chapter -1

>B<82. 2Soft ware. C Language manual. Copyright COSMIC Software 1999, 2001 All rights reserved.

PART I. Part II Answer to all the questions 1. What is meant by a token? Name the token available in C++.

C Fundamentals & Formatted Input/Output. adopted from KNK C Programming : A Modern Approach

Question No: 1 ( Marks: 1 ) - Please choose one One difference LISP and PROLOG is. AI Puzzle Game All f the given

B.V. Patel Institute of Business Management, Computer & Information Technology, Uka Tarsadia University

Preview from Notesale.co.uk Page 6 of 52

Fundamental Data Types. CSE 130: Introduction to Programming in C Stony Brook University

Transcription:

Structure of this course Programming in C: types, variables, expressions & statements functions, compilation, pre-processor pointers, structures extended examples, tick hints n tips Programming in C++: references, overloading, namespaces,c/c++ interaction operator overloading, streams, inheritance exceptions and templates standard template library CandC++ 1. Types Variables Expressions & Statements Stephen Clark University of Cambridge (heavily based on last year s notes (Andrew Moore) with thanks to Alastair R. Beresford and Bjarne Stroustrup) Michaelmas Term 2011 2/23 1/23 Past Exam Questions 1993 Paper 5 Question 5 1993 Paper 6 Question 5 1994 Paper 5 Question 5 1994 Paper 6 Question 5 1995 Paper 5 Question 5 1995 Paper 6 Question 5 1996 Paper 5 Question 5 (except part (f) setjmp) 1996 Paper 6 Question 5 1997 Paper 5 Question 5 1997 Paper 6 Question 5 1998 Paper 6 Question 6 * 1999 Paper 5 Question 5 * (first two sections only) 2000 Paper 5 Question 5 * 2006 Paper 3 Question 4 * 2007 Paper 3 Question 4 2007 Paper 11 Question 3 2008 Paper 3 Question 3 2008 Paper 10 Question 4 2009 Paper 3 Question 1 2010 Paper 3 Question 6 2011 Paper 3 Question 3 * denotes CPL questions relevant to this course. 4/23 Text books There are literally hundreds of books written about C and C++; five you might find useful include: Eckel, B. (2000). Thinking in C++, Volume 1: Introduction to Standard C++ (2nd edition). Prentice-Hall. (http://www.mindview.net/books/ticpp/thinkingincpp2e.html) Kernighan, B.W. & Ritchie, D.M. (1988). The C programming language (2nd edition). Prentice-Hall. Stroustrup, B. (2000). The C++ Programming Language Special Edition (3rd edition). Addison Wesley Longman Stroustrup, B. (1994). The design and evolution of C++. Addison-Wesley. Lippman, S.B. (1996). Inside the C++ object model. Addison-Wesley. 3/23

Cisa low-level language Cuseslow-levelfeatures:characters,numbers&addresses Operators work on these fundamental types No C operators work on composite types e.g. strings, arrays, sets Only static definition and stack-based local variables heap-based storage is implemented as a library There are no read and write primitives instead, these are implemented by library routines There is only a single control-flow no threads, synchronisation or coroutines Context: from BCPL to Java 1966 Martin Richards developed BCPL 1969 Ken Thompson designed B 1972 Dennis Ritchie s C 1979 Bjarne Stroustrup created C with Classes 1983 C with Classes becomes C++ 1989 Original C90 ANSI C standard (ISO adoption 1990) 1990 James Gosling started Java (initially called Oak) 1998 ISO C++ standard 1999 C99 standard (ISO adoption 1999, ANSI, 2000) 201? C++0x - the next ISO C++ standard 6/23 5/23 Basic types C has a small and limited set of basic types: type description (size) char characters ( 8bits) int integer values ( 16 bits, commonly one word) float single-precision floating point number double double-precision floating point number Precise size of types is architecture dependent Various type operators for altering type meaning, including: unsigned, long, short, const, static This means we can have types such as long int and unsigned char 8/23 Classic first example 1 #include <stdio.h> 2 Compile with: $ cc example1.c 3 int main(void) 4 { 5 printf("hello, world\n"); 6 return 0; 7 } Execute program with: $./a.out Hello, world $ 7/23

Defining constant values An enumeration can be used to specify a set of constants; e.g.: enum boolean {FALSE, TRUE}; By default enumerations allocate successive integer values from zero It is possible to assign values to constants; for example: enum months {JAN=1,FEB,MAR} enum boolean {F,T,FALSE=0,TRUE,N=0,Y} Names for constants in different enums must be distinct;values in the same enum need not The preprocessor can also be used (more on this later) 10 / 23 Constants Numeric constants can be written in a number of ways: type style example char none none int number, character or escape seq. 12 A \n \007 long int number w/suffix l or L 1234L float number with., e or E 1.234e3F or 1234.0f and suffix f or F double number with., e or E 1.234e3 1234.0 long double number., e or E and suffix l or L 1.234E3l or 1234.0L Numbers can be expressed in octal by prefixing with a 0 and hexadecimal with 0x ; for example: 52=064=0x34 9/23 Operators All operators (including assignment) return a result Most operators are similar to those found in Java: type operators arithmetic + - * / ++ -- % logic ==!= > >= < <= &&! bitwise & << >> ^ ~ assignment = += -= *= /= %= <<= >>= &= = ^= other sizeof 12 / 23 Variables Variables must be defined (i.e. storage set aside) exactly once A variable name can be composed of letters, digits and underscore (_); a name must begin with a letter or underscore Variables are defined by prefixing a name with a type, and can optionally be initialised; for example: long int i = 28L; Multiple variables of the same basic type can be defined together; for example: char c,d,e; 11 / 23

Expressions and statements An expression is created when one or more operators are combined; for example x *= y % z Every expression (even assignment) has a type and a result Operator precedence provides an unambiguous interpretation for every expression An expression (e.g. x=0) becomes a statement when followed by a semicolon (i.e. x=0;) Several expressions can be separated using a comma, ; expressions are then evaluated left to right; for example: x=0,y=1.0 The type and value of a comma-separated expression is the type and value of the result of the right-most expression 14 / 23 Type conversion Automatic type conversion may occur when two operands to a binary operator are of a different type Generally, conversion widens a variable (e.g. short int) However narrowing is possible and may not generate a compiler warning; for example: 1 int i = 1234; 2 char c; 3 c = i+1; /* i overflows c */ Type conversion can be forced by using a cast, which is written as: (type) exp; for example: c = (char) 1234L; 13 / 23 Variable scope Variables can be defined outside any function, in which case they: are often called global or static variables have global scope and can be used anywhere in the program consume storage for the entire run-time of the program are initialised to zero by default Variables defined within a block (e.g. function): are often called local or automatic variables can only be accessed from definition until the end of the block are only allocated storage for the duration of block execution are only initialised if given a value; otherwise their value is undefined 16 / 23 Blocks or compound statements A block or compound statement is formed when multiple statements are surrounded with braces ({ }) A block of statements is then equivalent to a single statement In ANSI/ISO C90, variables can only be declared or defined at the start of a block (this restriction was lifted in ANSI/ISO C99) Blocks are typically associated with a function definition or a control flow statement, but can be used anywhere 15 / 23

Scope and type example 1 #include <stdio.h> 2 3 int a; /*what value does a have? */ 4 unsigned char b = A ; 5 extern int alpha; /* safe to use this? */ 6 7 int main(void) { 8 extern unsigned char b; /* is this needed? */ 9 double a = 3.4; 10 { 11 extern a; /*why is this sloppy? */ 12 printf("%d %d\n",b,a+1); /*what will this print? */ 13 } 14 15 return 0; 16 } 18 / 23 Variable definition versus declaration A variable can be declared but not defined using the extern keyword; for example extern int a; The declaration tells the compiler that storage has been allocated elsewhere (usually in another source file) If a variable is declared and used in a program, but not defined, this will result in a link error (more on this later) 17 / 23 Control flow Control flow is similar to Java: exp? exp : exp if (exp) stmt1 else stmt2 switch(exp) { case exp 1 : stmt1... default: } stmtn+1 while (exp) stmt for ( exp 1 ; exp 2 ; exp 3 ) stmt do stmt while (exp); The jump statements break and continue also exist 20 / 23 Arrays and strings One or more items of the same type can be grouped into an array; for example: long int i[10]; The compiler will allocate a contiguous block of memory for the relevant number of values Array items are indexed from zero, and there is no bounds checking Strings in C are usually represented as an array of chars, terminated with a special character \0 There is compiler support for string constants using the " character; for example: char str[]="two strs mer" "ged and terminated" String support is available in the string.h library 19 / 23

Goto (considered harmful) The goto statement is never required It often results in code which is hard to understand and maintain Exception handling (where you wish to exit or break from two or more loops) may be one case where a goto is justified: 1 for (...) { 2 for (...) { 3... 4 if (critical_problem) 5 goto error; 6 } 7 } 8... 9 error: fix problem, or abort Control flow and string example 1 #include <stdio.h> 2 #include <string.h> 3 4 char s[]="university of Cambridge Computer Laboratory"; 5 6 int main(void) { 7 8 char c; 9 int i, j; 10 for (i=0,j=strlen(s)-1;i<j;i++,j--) /* strlen(s)-1? */ 11 c=s[i], s[i]=s[j], s[j]=c; 12 13 printf("%s\n",s); 14 return 0; 15 } 22 / 23 21 / 23 Exercises 1. What is the difference between a and "a"? 2. Will char i,j; for(i=0;i<10,j<5;i++,j++) ; terminate? If so, under what circumstances? 3. Write an implementation of bubble sort for a fixed array of integers. (An array of integers can be defined as int i[] = {1,2,3,4}; the 2nd integer in an array can be printed using printf("%d\n",i[1]);.) 4. Modify your answer to (3) to sort characters into lexicographical order. (The 2nd character in a character array i can be printed using printf("%c\n",i[1]);.) 23 / 23