1 Chapter 11 Structured Data. 2 Topics 10.1 Abstract Data Types 10.2 Combining Data into Structures 10.3 Accessing Structure Members 10.4 Initializing.

Slides:



Advertisements
Similar presentations
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7: Introduction to Classes and Objects Starting Out with C++ Early.
Advertisements

Copyright © 2012 Pearson Education, Inc. Chapter 11: Structured Data.
Lesson 11 Structured Data CS1 Lesson John Cole1.
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Eighth Edition by Tony Gaddis,
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Sixth Edition Chapter 10: Pointers by.
Operator Overloading in C++ Systems Programming. Systems Programming: Operator Overloading 22   Fundamentals of Operator Overloading   Restrictions.
Starting Out with C++: Early Objects 5/e © 2006 Pearson Education. All Rights Reserved Copyright 2004 Scott/Jones Publishing Starting Out with C++: Early.
Starting Out with C++: Early Objects 5th Edition
Starting Out with C++ Early Objects Eighth Edition by Tony Gaddis, Judy Walters, and Godfrey Muganda Chapter 10: Pointers.
Chapter 7: Introduction to Classes and Objects
Chapter 11 – Structured Data
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7: Introduction to Classes and Objects Starting Out with C++ Early.
Copyright 2003 Scott/Jones Publishing Standard Version of Starting Out with C++, 4th Brief Edition Chapter 10 Structured Data.
Chapter 11: Structured Data. Slide Introduction An array makes it possible to access a list or table of data of the same data type by using a single.
More About Classes Chapter Instance And Static Members instance variable: a member variable in a class. Each object has its own copy. static variable:
Starting Out with C++ Early Objects Seventh Edition by Tony Gaddis, Judy Walters, and Godfrey Muganda Modified by use by the MSU CMPS Dept. Chapter 10:
Chapter 6 Structures and Classes. Copyright © 2006 Pearson Addison-Wesley. All rights reserved. 6-2 Structures  2 nd aggregate data type: struct  Recall:
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.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Seventh Edition by Tony Gaddis, Judy.
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7: Introduction to Classes and Objects Starting Out with C++
Copyright 2003 Scott/Jones Publishing Standard Version of Starting Out with C++, 4th Edition Chapter 13 Introduction to Classes.
Copyright 2003 Scott/Jones Publishing Standard Version of Starting Out with C++, 4th Edition Chapter 11 Structured Data.
Programmer Defined Structures (Records)
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7: Introduction to Classes and Objects Starting Out with C++
Copyright 2004 Scott/Jones Publishing Alternate Version of STARTING OUT WITH C++ 4 th Edition Chapter 7 Structured Data and Classes.
Chapter 14 More About Classes. Chapter 13 slide 2 Topics 13.1 Instance and Static Members 13.2 Friends of Classes 13.3 Memberwise Assignment 13.4 Copy.
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Sixth Edition Chapter 7: Introduction.
Chapter 7: Introduction to Classes and Objects Starting Out with C++ Early Objects Seventh Edition by Tony Gaddis, Judy Walters, and Godfrey Muganda Modified.
Copyright © 2012 Pearson Education, Inc. Chapter 11: Structured Data.
Structured Data and Classes Chapter 7. Combining Data into Structures Structure: C++ construct that allows multiple variables to be grouped together Structure.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 11: Structured Data.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 11: Structured Data.
Copyright © 2012 Pearson Education, Inc. Chapter 11: Structured Data.
Structured Data Chapter 11. Combining Data Into Structures Structure: C++ construct that allows multiple variables to be grouped together Format: struct.
Chapter 7 A Data Types – Structures Structures Structure: C++ construct that allows multiple variables to be grouped together Structure Declaration.
1 Chapter 7 Arrays. 2 Topics 7.1 Arrays Hold Multiple Values 7.2 Accessing Array Elements 7.3 No Bounds Checking in C Array Initialization 7.5 Processing.
+ Structures and Unions. + Introduction We have seen that arrays can be used to represent a group of data items that belong to the same type, such as.
Chapter 7: Arrays. Outline Array Definition Access Array Array Initialization Array Processing 2D Array.
Structured Data and Classes
1 Chapter 12 Arrays. 2 C++ Data Types structured array struct union class address pointer reference simple integral enum char short int long bool floating.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7: Introduction to Classes and Objects Starting Out with C++ Early.
1 Classes II Chapter 7 2 Introduction Continued study of –classes –data abstraction Prepare for operator overloading in next chapter Work with strings.
Slide 1 Chapter 6 Structures and Classes. Slide 2 Learning Objectives  Structures  Structure types  Structures as function arguments  Initializing.
Copyright © 2015, 2012, 2009 Pearson Education, Inc., Publishing as Addison-Wesley All rights reserved. Chapter 11: Structured Data.
Copyright © 2015, 2012, 2009 Pearson Education, Inc., Publishing as Addison-Wesley All rights reserved. Chapter 11: Structured Data.
Struct s (7.4) Used as data aggregates for an entity can be different types of data e.g. for student id, name, GPA, address,... Similar to classes, but.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Seventh Edition by Tony Gaddis, Judy.
C Programming Structured Data.
1 1  Lecture 11 – Structured Data FTMK, UTeM – Sem /2014.
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7. 12: Structures Starting Out with C++ Early Objects Eighth.
Chapter Structured Data 11. Combining Data into Structures 11.2.
Lecture 2 Arrays. Topics 1 Arrays hold Multiple Values 2 Accessing Array Elements 3 Inputting and Displaying Array Contents 4 Array Initialization 5 Using.
Copyright © 2014, 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7: Introduction to Classes and Objects Starting Out with C++
Pointers Lecture: 5. Topics 1 Pointers and the Address Operator 2 Pointer Variables 3 The Relationship Between Arrays and Pointers 4 Pointer Arithmetic.
Chapter 7: Introduction to Classes and Objects
11 Chapter Structured Data
Chapter 7: Introduction to Classes and Objects
Abstract Data Types Programmer-created data types that specify
Chapter 7: Introduction to Classes and Objects
Chapter 10: Pointers Starting Out with C++ Early Objects
Chapter 11: Structured Data.
Chapter 7: Introduction to Classes and Objects
Chapter 7: Introduction to Classes and Objects
Chapter 10: Pointers Starting Out with C++ Early Objects
Data Types – Structures
Data Types – Structures
Chapter 11: Structured Data.
Standard Version of Starting Out with C++, 4th Edition
Programming Fundamental
Presentation transcript:

1 Chapter 11 Structured Data

2 Topics 10.1 Abstract Data Types 10.2 Combining Data into Structures 10.3 Accessing Structure Members 10.4 Initializing a Structure 10.5 Arrays of Structures 10.6 Nested Structures

3 Topics 10.7 Structures as Function Arguments 10.8 Returning a Structure from a Function 10.9 Pointers to Structures When to Use., When to Use ->, and When to Use * Unions

Abstract Data Types A data type that specifies values that can be stored (range or domain) operations that can be done on the values User of an abstract data type does not need to know the implementation of the data type, e.g., how the data is stored ADTs are created by programmers

5 Abstraction and Data Types Abstraction: a definition that captures general characteristics without details Ex: An abstract triangle is a 3-sided polygon. A specific triangle may be scalene, isosceles, or equilateral Data Type defines the values that can be stored in a variable and the operations that can be performed on it

Combining Data into Structures Structure: C++ construct that allows multiple variables to be grouped together into a single item Format: struct { type1 field1; type2 field2;... };

7 Example struct Declaration struct Student { int studentID; string name; short yearInSchool; float gpa; }; structure tag structure members

8 struct Declaration Notes Must have ; after closing } struct names commonly begin with uppercase letter Multiple fields of same type can be in comma- separated list: string name, address;

9 Defining Variables struct declaration does not allocate memory or create variables To define variables, use structure tag as type name: Student stu1; studentID name yearInSchool gpa stu1

Accessing Structure Members Use the dot (.) operator to refer to members of struct variables: cin >> stu1.studentID; getline(cin, stu1.name); stu1.gpa = 3.75; Member variables can be used in any manner appropriate for their data type

11 Displaying a struct Variable To display the contents of a struct variable, must display each field separately, using the dot operator: cout << stu1; // won’t work cout << stu1.studentID << endl; cout << stu1.name << endl; cout << stu1.yearInSchool; cout << " " << stu1.gpa;

12 Comparing struct Variables Cannot compare struct variables directly: if (stu1 == stu2) // won’t work Instead, must compare on a field basis: if (stu1.studentID == stu2.studentID)... Examples: Progs 10-1, 10-2,

Initializing a Structure struct variable can be initialized when defined: Student stu2 = {11465, "Joan", 2, 3.75}; Can also be initialized member-by-member after definition: stu2.name = "Joan"; stu2.gpa = 3.75;

14 More on Initializing a Structure May initialize only some members: Student stu3 = {14579}; Cannot skip over members: Student stu4 = {1234, "John",, 2.83}; // illegal Cannot initialize in the structure declaration, since this does not allocate memory Examples: Prog Ex.

Arrays of Structures Structures can be defined in arrays Can be used in place of parallel arrays Student stuList[20]; Individual structures accessible using subscript notation Fields within structures accessible using dot notation: cout << stuList[5].studentID; Examples: Prog

Nested Structures A structure can contain another structure as a member: struct PersonInfo { string name, address, city; }; struct Student {int studentID; PersonInfo pData; short yearInSchool; float gpa; };

17 Members of Nested Structures Use the dot operator multiple times to refer to fields of nested structures: Student stu5; stu5.pData.name = "Joanne"; stu5.pData.city = "Tulsa"; Examples: Prog Ex.

Structures as Function Arguments May pass members of struct variables to functions: computeGPA(stu1.gpa); May pass entire struct variables to functions: showData(stu5); Can use reference parameter if function needs to modify contents of structure variable

19 Structures as Function Arguments - Notes Using value parameter for structure can slow down a program, waste space Using a reference parameter will speed up program, but function may change data in structure Using a const reference parameter allows read-only access to reference parameter, does not waste space, speed Prog

Returning a Structure from a Function Function can return a struct : Student getStuData(); // prototype stu1 = getStuData(); // call Function must define a local structure for internal use for use with return statement

21 Returning a Structure from a Function - Example Student getStuData() { Student tmpStu; cin >> tmpStu.studentID; getline(cin, tmpStu.pData.name); getline(cin, tmpStu.pData.address); getline(cin, tmpStu.pData.city); cin >> tmpStu.yearInSchool; cin >> tmpStu.gpa; return tmpStu; } Examples: Prog Ex.

Pointers to Structures A structure variable has an address Pointers to structures are variables that can hold the address of a structure: Student *stuPtr; Can use & operator to assign address: stuPtr = & stu1; Structure pointer can be a function parameter

23 Accessing Structure Members via Pointer Variables Must use () to dereference pointer variable, not field within structure: cout << (*stuPtr).studentID; Can use structure pointer operator to eliminate () and use clearer notation: cout studentID;

When to Use., When to Use ->, and When to Use * Consider the following: struct Xmpl { int *intPtr; }; Xmpl xmpl1, *xmplPtr = &xmpl1; *xmpl1.intPtr accesses the value pointed at by intPtr *xmplPtr->intPtr does the same thing

Unions Similar to a struct, but all members share a single memory location, and only 1 member of the union can be used at a time Declared using union, otherwise the same as struct Variables defined as for struct variables

26 Anonymous Union A union without a union tag: union {... }; Must use static if declared outside of a function Allocates memory at declaration time Can refer to members directly without dot operator Uses only 1 memory location, saves space