chapter 5

Post on 13-Feb-2016

64 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

DESCRIPTION

CHAPTER 5. STRUCTURE. User Defined Data Types. Objectives: In this chapter you will learn about, Introduction Declaring Structure Type & Structure Variables Referring and initializing structure elements Passing structures to a function Using typedef Example using structure - PowerPoint PPT Presentation

TRANSCRIPT

CHAPTER 5STRUCTURE

1

Objectives: In this chapter you will learn about, Introduction Declaring Structure Type & Structure Variables Referring and initializing structure elements Passing structures to a function Using typedef Example using structure Enumeration constants

2

User Defined Data Types

So far we have only used data types which have been defined by C such as int, double and char.

It is also possible to create our own data types. A user defined data type is called a structure. A structure can contain both built-in data types

and another structure. The concept of structure is pretty much the

same as arrays except that in an array, all the data is of the same types but in a structure, the data can be of different types.

3

Introduction

General syntax:struct structure_name {

data_type element1;data_type element2;. . .

}; Example:

struct student {char name[20];int studentID;char major[50];

};

4

Declaring Structure TypeAlso called as structure tag

Components / members

After declaring a structure type, we may declare variables that are of that type. A structure variable declaration requires:◦ The keyword struct◦ The structure type name◦ A list of members (variable names) separated by

commas◦ A concluding semicolon

Then, assume that variable of structure type student is my_student. So the declaration should be written as;

struct student my_student;

5

Declaring Structure Variables

By including this declaration in our program, we are informing the compiler about a new data type which is a user defined data type.

The declaration just makes the compiler aware of existent of new data type but does not take an action yet.

Based on the declaration ofstruct student my_student;

causes the compiler to reserve memory space for variable my_student and the components of its structure.

6

Based on example: struct student

7

Based on example: struct student cont…

Structure variable Components Values

name

majorstudentID

Simon0078CS

my_student

Conceptual memory structure variable my_student of type student

It is possible to combine the declarations of a structure type and a structure variable by including the name of the variable at the end of the structure type declaration.

8

Based on example: struct student cont…

struct student {char name[20];

int studentID;char major[50];

}; struct student my_student;

struct student {char name[20];

int studentID;char major[50];

} my_student;

=

Members of a structure declaration can be of any type, including another structure variable.

Suppose we have the following structure declaration which this struct will be as a member of struct type student:

struct address { int no; char street[20]; int zipcode;

}addr;

9

Declaring Nested Structure

We can rewrite the structure student declaration as follow:

This structure type student can be written as;

10

Declaring Nested Structure cont…

struct student {char name[20];int studentID;char major[50];struct address addr;

} my_student;

struct student {char name[20];int studentID;char major[50];struct address{ int no; char street[20]; int zipcode;}addr;

} my_student;

11

Declaring Nested Structure cont…

A structure contains many elements. Each members of a structure can be referred to / accessed by using the operator “.” (dot)

Let us use the structure student which we have seen before as an example:

12

Referring and Initializing Structure Members

struct student {char name[20];

int studentID;char major[50];

} my_student;

There for to refer to the element of a structure, we may write as follow;

my_student.name;my_student.studentID;my_student.major;

Therefore, we can initialize each elements of a structure individually such as:

struct student my_student;my_student.studentID = 10179;

13

Referring and Initializing Structure Members

Or we can initialize the structure while we are creating an instance of the structure:struct student my_student = {“Ahmad”, 10179, “IT”}

Notice that it is possible to use the ‘=’ operator on a struct variable. When the ‘=’ sign is used, each elements of the structure at the right hand side is copied into the structure at the left hand side.

14

Referring and Initializing Structure Members

struct birthdate {int month;int day;int year;

}Picasso;struct birthdate Picasso = {10, 25, 1881};printf(“Picasso was born : %d/%d/%d\n”, Picasso.day,

Picasso.month, Picasso.year);

Output :Picasso was born : 25/10/1881

15

Example 1

We can pass the student structure that we have created before to a function called Read( ) as follows:

void Read (struct student s1); In the function above, a copy of the student

structure will be created locally for the use of the function. But any changes to the structure inside the function will not affect the actual structure.

It is also possible to use pointers and pass the reference of the structure to the function. This way, any changes inside the function will change the actual structure as well.

17

Passing Structures to a Function

To pass a reference, the Read( ) function can be written this way:void Read(struct student *s1);

Take note that when a structure is declared as a pointer, the elements in the structure cannot be referred to using the ‘.’ operator anymore. Instead, they need to be accessed using the ‘->’ operator.

For example:void Read(struct student *s1) {s1->studentID = 10179;scanf(“%s”, &(s1->name));scanf(“%s”, &(s1->major));}

18

Passing Structures to a Function

#include <stdio.h>struct car {

char maker[20];char model[20];int year;

};void input(struct car *sp);void output(struct car *sp);

void main(){struct car firstcar;input (&firstcar);output(&firstcar);printf("End of my act!\n");

}

19

Example 3

void input(struct car *sp){printf("What is the maker of your car? ");scanf("%s", &sp->maker);printf("What is the model of your car? ");scanf("%s", &sp->model);printf("What year is your car? ");scanf("%d", &sp->year);

}

void output(struct car *sp){printf("Your car is : %s, %s, %d\n", sp->maker, sp->model, sp->year);printf("Nice car\n");

}

20

Cont…

/* Sample outputWhat is the maker of your car? HondaWhat is the model of your car? IntegraWhat year is your car? 2004Your car is : Honda, Integra, 2004Nice carEnd of my act!Press any key to continue*/

21

Cont…

The keyword typedef provides a mechanism for creating synonyms (aliases) for previously defined data types.

Typedefs give a way to provide consistent type names◦ Let user-defined types declare associated types◦ Let you create type names for other purposes, convenience

Here is an example on how to use typedef when declaring a structure:

typedef struct student { char name[20];int studentID;char major[50];struct address addr;

} StudentData;

22

Using typedef in Structure Declarations

By using typedef, we now do not have to write the word “struct” before declaring a struct variable. Instead of writing:

struct student my_student;we can now write:

StudentData my_student; Same thing with passing the structure to a

function:void Read(StudentData *s1);

23

Using typedef in Structure Declarations

24

Example Using typedef#include <stdio.h>#define NUM_STUDENTS 10typedef struct pelajar {

int studentID;char name[20];int score;char grade;

}StudentData;void Read (StudentData student[]);void CountGrade (StudentData student[]);

void main ( ) {

StudentData student[NUM_STUDENTS];Read(student);CountGrade(student);

}

25

void Read (StudentData student[]) {

int i;for (i = 0; i < NUM_STUDENTS; i++) {

printf("Enter the studentID: ");scanf("%d", &student[i].studentID);printf("Enter the name: ");scanf("%s", &student[i].name);printf("Enter the score: ");scanf("%d", &student[i].score);printf("\n");

}}

Example Using typedef

26

void CountGrade (StudentData student[]) {

int i;for (i = 0; i < NUM_STUDENTS; i++) { if (student[i].score > 90) student[i].grade = 'A'; else if (student[i].score > 80)

student[i].grade = 'B'; else if (student[i].score > 65)

student[i].grade = 'C'; else if (student[i].score > 50)

student[i].grade = 'D'; else

student[i].grade = 'F';printf("The grade for %s is %c\n", student[i].name, student[i].grade);printf("\n");}

}

Example Using typedef

27

/* Sample OutputEnter the studentID: 789654Enter the name: SimaonEnter the score: 88

Enter the studentID: 741258Enter the name: JackEnter the score: 79:::The grade for Simaon is B

The grade for Jack is C::Press any key to continue*/

Example Using typedef

28

How to Parse and Define C TypesAt this point we have seen a few basic types, arrays, pointer types, and structures. So far we’ve glossed over how types are named.

int x; /* int; */ typedef int T; int *x; /* pointer to int; */ typedef int *T; int x[10]; /* array of ints; */ typedef int T[10]; int *x[10]; /* array of pointers to int; */ typedef int *T[10]; int (*x)[10]; /* pointer to array of ints; */ typedef int (*T)[10];

C type names are parsed by starting at the type name and working outwards according to the rules of precedence:

int (*x)[10]; x isa pointer toan array ofint

int *x[10];

x is an array ofpointers toint Arrays are the primary source

of confusion. When in doubt, use extra parens to clarify the expression.

typedef defines a new type

An enumeration, introduced by the keyword enum, is a set of integer constants represented by identifiers. (to specify one after another)

Example:enum islamic_months {

muharam, safar, rabiulawal, rabiulakhir, jamadilawal, jamadilakhir, rejab, syaaban, ramadhan, syawal, zulkaedah, zulhijjah

}; Each of the identifiers actually has a value,

starting with 0 (unless specified otherwise). Therefore, we can treat them as integers.

29

Enumeration Constants

If we want the enumeration to start with a value other than 0, we can assign the value to the first identifier:enum islamic_months {

muharam = 1, safar, rabiulawal, rabiulakhir,

jamadilawal, jamadilakhir, rejab, syaaban, ramadhan, syawal, zulkaedah, zulhijjah

}; Same as with the other data types, before an

enum can be used, a variable needs to be declared:

enum islamic_months months;30

Enumeration Constants

There are cases where it is appropriate for us to use an enum. This is an example of such a case:

enum islamic_months months;GetMonth (&months);switch (months) {

case muharam:. . .

break;case safar:

. . .break;. . .

}

31

Enumeration Constants

This is another case where it is appropriate to use an enum:

enum Boolean {FALSE, TRUE};void main ( ) {

int list[];Boolean found;

Read(list);found = Search(list);if (found == TRUE)

printf(“FOUND!!”);else

printf(“Cannot find the requested item”);

}

32

Enumeration Constants

33

#include <stdio.h>

enum months {JAN = 1, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV, DEC};

void main ( ) {enum months month;char *monthsName[] = {“January”, “February”,

“March”, “April”, “May”, “June”, “July”, “August”,

“September”, “October”, “November”, “December”};

for (month = JAN; month <= DEC; month++)printf(“%d %s\n”, month,

monthName[month-1]);}

Enumeration Constants

34

Output: 1 January2 February3 March4 April5 May6 June7 July8 August9 September10 October11 November12 December

Enumeration Constants

This chapter you learned about structures◦ Structure type and variable declarations◦ How structure members can be accessed◦ How they can be initialized

You learned that structures can be passed between function

Introduced you to another user defined data type which is enumeration

T.H.E E.N.D

35

SUMMARY

top related