1 CSE1301 Computer Programming Lecture 16 Pointers.

Slides:



Advertisements
Similar presentations
1 Chapter Thirteen Pointers. 2 Pointers A pointer is a sign used to point out the direction.
Advertisements

Data Structures (Second Part) Lecture 2 : Pointers Bong-Soo Sohn Assistant Professor School of Computer Science and Engineering Chung-Ang University.
CPT: Pointers/ Computer Programming Techniques Semester 1, 1998 Objective of these slides: –to introduce pointer variables (pointers)
Pointers Discussion 5 Section Housekeeping HW 1 Issues Array Issues Exam 1 Questions? Submitting on Time!
Pointers and Output Parameters. Pointers A pointer contains the address of another memory cell –i.e., it “points to” another variable cost:1024.
Topic 2 Pointers CSE1303 Part A, Summer Semester,2002 Data Structures and Algorithms.
Kymberly Fergusson CSE1303 Part A Data Structures and Algorithms Summer Semester 2003 Lecture A2 – Pointers (Revision)
1 CSE1301 Computer Programming Lecture 16 Pointers 2.
Starting Out with C++: Early Objects 5/e © 2006 Pearson Education. All Rights Reserved Copyright 2004 Scott/Jones Publishing Starting Out with C++: Early.
Pointers Ethan Cerami Fundamentals of Computer New York University.
M-1 University of Washington Computer Programming I Lecture 13 Pointer Parameters © 2000 UW CSE.
Pointers. Topics Pointers Pointer Arithmetic Pointers and Arrays.
© Janice Regan, CMPT 102, Sept CMPT 102 Introduction to Scientific Computer Programming Pointers.
1 Chapter 9 Pointers. 2 Topics 8.1 Getting the Address of a Variable 8.2 Pointer Variables 8.3 Relationship Between Arrays and Pointers 8.4 Pointer Arithmetic.
Pointers Example Use int main() { int *x; int y; int z; y = 10; x = &y; y = 11; *x = 12; z = 15; x = &z; *x = 5; z = 8; printf(“%d %d %d\n”, *x, y, z);
1 CSE1301 Computer Programming Lecture 16 Pointers.
1 Review of Chapter 6: The Fundamental Data Types.
Computer Skills2 for Scientific Colleges 1 Pointers in C++ Topics to cover: Overview of Pointers Pointer Declaration Pointer Assignment Pointer Arithmetic.
Pointers CSE 2451 Rong Shi.
Engineering H192 - Computer Programming Gateway Engineering Education Coalition Lect 14P. 1Winter Quarter Pointers Lecture 14.
Chapter 9 Pointers Fall 2005 Csc 125 Introduction to C++
Pointers Chapter 9. Getting The Address Of A Variable Each variable in program is stored at a unique address Use address operator & to get address of.
1 Programming with Pointers Turgay Korkmaz Office: SB Phone: (210) Fax: (210) web:
CSC 2400 Computer Systems I Lecture 5 Pointers and Arrays.
Chapter 7: Pointers Basic concept of pointers Pointer declaration Pointer operator (& and *) Parameter passing by reference.
CPSC 252 Dynamic Memory Allocation Page 1 Dynamic memory allocation Our first IntVector class has some serious limitations the capacity is fixed at MAX_SIZE.
1 Pointers and Strings Chapter 5 2 What You Will Learn...  How to use pointers Passing arguments to functions with pointers See relationship of pointers.
Nirmalya Roy School of Electrical Engineering and Computer Science Washington State University Cpt S 122 – Data Structures Pointers.
Problem Solving and Program Design in C (5th Edition) by Jeri R. Hanly and Elliot B. Koffman Chapter 6 (Pointers) © CPCS
19&20-2 Know how to declare pointer variables. Understand the & (address) and *(indirection) operators. Dynamic Memory Allocation Related Chapter: ABC.
Pointers Programming Applications. Pointer A pointer is a variable whose value is a memory address representing the location of the chunk of memory on.
1 CSE1301 Computer Programming Lecture 13 Functions (Part 1)
CSEB 114: PRINCIPLE OF PROGRAMMING Chapter 7: Pointers.
Functions: Part 2 of /11/10: Lecture 16 CMSC 104, Section 0101 John Y. Park 1.
C Programming - Structures. Structures containing arrays A structure member that is an array does not ‘behave’ like an ordinary array When copying a structure.
M-1 University of Washington Computer Programming I Lecture 13 Pointer Parameters © 2000 UW CSE.
+ Pointers. + Content Address of operator (&) Pointers Pointers and array.
Chapter 8 Characters and Strings. Objectives In this chapter, you will learn: –To be able to use the functions of the character handling library ( ctype).
Pointers PART - 2. Pointers Pointers are variables that contain memory addresses as their values. A variable name directly references a value. A pointer.
Introduction to Computing Lecture 12 Pointers Dr. Bekir KARLIK Yasar University Department of Computer Engineering
Dr. Yang, QingXiong (with slides borrowed from Dr. Yuen, Joe) LT9: Pointer I CS2311 Computer Programming.
Computer Programming Lecture 12 Pointers Assist.Prof.Dr. Nükhet ÖZBEK Ege University Department of Electrical & Electronics Engineering
POINTERS IN C Pointer Basics, Pointer Arithmetic, Pointer to arrays and Pointer in functions.
Pointers (Revision). 2 Overview Revision of Pointers Pointers and structs Basic Pointer Arithmetic Pointers and Arrays.
Basic Concepts:- Invalid use of Address Operator &75 &(‘a’) &(a+b)
Chapter 8 Arrays, Strings and Pointers
Computer Skills2 for Scientific Colleges
“Studying C programming excluding pointers is meaningless.” d0m3z
CSE 220 – C Programming Pointers.
Pointers.
Standard Version of Starting Out with C++, 4th Edition
POINTERS.
INC 161 , CPE 100 Computer Programming
Pointer.
Lecture 6 C++ Programming
CSI-121 Structured Programming Language Lecture 16 Pointers 2
CSI-121 Structured Programming Language Lecture 16 Pointers
Programming fundamentals 2 Chapter 2:Pointer
INC 161 , CPE 100 Computer Programming
Topics discussed in this section:
Alternate Version of STARTING OUT WITH C++ 4th Edition
بنام خدا زبان برنامه نویسی C (21814( Lecture 11 Pointers
Programming with Pointers
Computer Skills2 for Scientific Colleges
Pointers Lecture 1 Thu, Jan 15, 2004.
POINTER CONCEPT 4/15/2019.
Standard Version of Starting Out with C++, 4th Edition
Arrays and Pointers CSE 2031 Fall May 2019.
POINTER CONCEPT 8/3/2019.
Programming fundamentals 2 Chapter 3:Pointer
Presentation transcript:

1 CSE1301 Computer Programming Lecture 16 Pointers

2 Topics Introduction to pointers Pointers and function parameters

3 char ch = ’A’; ’A’ 0x2000 ch: Memory Address of a Variable The value of the variable ch The memory address of the variable ch

4 The & Operator Gives the memory address of an object Also known as the “address operator” &ch yields the value 0x2000 char ch = ’A’; ’A’ 0x2000

5 “conversion specifier” for printing a memory address char ch; printf(“%p”, &ch); Example:

6 Pointers ch 0x1FFF0x20000x20010x20020x1FFE etc ‘B’ 0x2000 chPtr 0x3A15 A variable which can store the memory address of another variable

7 Pointers A pointer is a variable Contains a memory address Points to a specific data type Pointer variables are usually named varPtr

8 cPtr: char* cPtr; Example: We say cPtr is a pointer to char 0x2004 Can store an address of variables of type char

9 Pointers and the & Operator Example: A c: 0x2000 char c = ’A’; char *cPtr; cPtr: 0x2004 cPtr = &c; 0x2000 Assigns the address of c to cPtr

10 Notes on Pointers int* numPtr; float* xPtr; Example: We can have pointers to any data type int *numPtr; float * xPtr; Example: The * can be anywhere between the type and the variable

11 Notes on Pointers (cont) You can print the address stored in a pointer using the %p conversion specifier printf(“%p”, numPtr); Example: You can assign the address of a variable to a “compatible” pointer using the & operator intaNumber; int*numPtr; numPtr = & aNumber; Example:

12 Notes on Pointers (cont) int *numPtr; Beware of pointers which are not initialized! ??? numPtr

13 Notes on Pointers (cont) int *numPtr = NULL; NULL numPtr When declaring a pointer, it is a good idea to always initialize it to NULL (a special pointer constant)

14 The * Operator Allows pointers to access variables they point to Also known as “dereferencing operator” Should not be confused with the * in the pointer declaration

15 A c: 0x2000 B Pointers and the  Operator Example: char c = ’A’; char *cPtr = NULL; cPtr = &c; *cPtr = ’B’; Changes the value of the variable which cPtr points to cPtr: 0x2004 NULL 0x2000

16 Easy Steps to Pointers Step 1: Declare the variable to be pointed to intnum; charch = ‘A’; float x; num: ‘A’ ch: x:

17 Easy Steps to Pointers (cont) Step 2: Declare the pointer variable int* numPtr = NULL; char *chPtr = NULL; float * xPtr = NULL; intnum; charch = ‘A’; float x; numPtr: chPtr: xPtr: num: ‘A’ ch: x: NULL

18 Easy Steps to Pointers (cont) Step 3: Assign address of variable to pointer int* numPtr = NULL; char *chPtr = NULL; float * xPtr = NULL; intnum; charch = ‘A’; float x; numPtr = # numPtr: chPtr: xPtr: num: ‘A’ ch: x: A pointer’s type has to correspond to the type of the variable it points to chPtr = &ch; xPtr = &x; addr of x addr of ch addr of num

19 Easy Steps to Pointers (cont) Step 4: De-reference the pointers int* numPtr = NULL; char *chPtr = NULL; float * xPtr = NULL; intnum; charch = ‘A’; float x; numPtr = # chPtr = &ch; xPtr = &x; *xPtr = 0.25; num: ‘A’ ch: x: numPtr: addr of num addr of ch chPtr: addr of x xPtr: *numPtr = *chPtr;

20 Pointers and Function Parameters Example: Function to swap the values of two variables x: 1 y: 2 swap x: 2 y: 1

21 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } Bad swap

22 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: Bad swap

23 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: 1 2 a: b: tmp: Bad swap

24 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: 1 2 a: b: 1 tmp: Bad swap

25 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: 2 2 a: b: 1 tmp: Bad swap

26 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: 2 1 a: b: 1 tmp: Bad swap

27 #include void swap1(int a, int b) { int tmp; tmp = a; a = b; b = tmp; return; } int main() { int x = 1, y = 2; swap1(x, y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: 2 1 a: b: 1 tmp: Bad swap

28 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } Good swap

29 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: Good swap

30 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: addr of x addr of y a: b: tmp: Good swap

31 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } 1 2 x: y: addr of x addr of y a: b: 1 tmp: Good swap

32 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } 2 2 x: y: addr of x addr of y a: b: 1 tmp: Good swap

33 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } 2 1 x: y: addr of x addr of y a: b: 1 tmp: Good swap

34 #include void swap2(int* a, int* b) { int tmp; tmp = *a; *a = *b; *b = tmp; return; } int main() { int x = 1, y = 2; swap2(&x, &y); printf(“%d %d\n”, x, y); return 0; } 2 1 x: y: Good swap

35 Pointers and Function Arguments Change the value of an actual parameter variable scanf demystified char ch; intnumx; float numy; scanf(“%c %d %f”, &ch, &numx, &numy);

36 Reading King – Chapter 11 Deitel and Deitel – Chapter 7 ( )