450 likes | 559 Views
CS-362: Data Structures Week 6 Part 2. Dr. Jesús Borrego. Topics. Dynamic Data Pointers Address Pointers to different data types Sample programs. Pointer Data Type/Pointer Variables. 325. The type is integer The Name of the integer is A The address is 10280
E N D
CS-362: Data StructuresWeek 6Part 2 Dr. Jesús Borrego
Topics • Dynamic Data • Pointers • Address • Pointers to different data types • Sample programs
Pointer Data Type/Pointer Variables 325 The type is integer The Name of the integer is A The address is 10280 The value stored in A is 325 int A = 325; 10280 A
Declaring Pointer Variables • Syntax: • Examples: int *p; char *ch; • These statements are equivalent: int *p; int* p; int * p;
What happened? The swap did not work? The before and after are the same Need to make sure we get the values back to the calling program It is calling by Value How do we fix it?
Address of Operator (&) The ampersand, &, is called the address of operator The address of operator is a unary operator that returns the address of its operand
stores 25 into the first memory location stores 35 into the second memory location Dynamic Arrays • Dynamic array: array created during the execution of a program • Example: int *p; p = new int[10]; *p = 25; p++; //to point to next array component *p = 35;
Dynamic Arrays (cont'd.) • C++ allows us to use array notation to access these memory locations • The statements: p[0] = 25; p[1] = 35; store 25 and 35 into the first and second array components, respectively
Dynamic Arrays (cont'd.) • The value of list (1000) is constant • Cannot be altered during program execution • The increment and decrement operations cannot be applied to list • If p is a pointer variable of type int, then: p = list; copies the value of list, the base address of the array, into p • We can perform ++ and -- operations on p • An array name is a constant pointer
Functions and Pointers • A pointer variable can be passed as a parameter either by value or by reference • To make a pointer a reference parameter in a function heading, use &: void pointerParameters(int* &p, double *q) { . . . }
Pointers and Function Return Values • A function can return a value of type pointer: int* testExp(...) { . . . }
declares board to be an array of four pointers wherein each pointer is of type int creates the rows of board declares board to be a pointer to a pointer Dynamic Two-Dimensional Arrays • You can create dynamic multidimensional arrays • Examples:
Resources • Can search the internet for tutorials on pointers • On YouTube: • http://www.youtube.com/watch?v=eFWCQexfaeg • From Google, search for • “C++ pointer tutorial“