session 04: c# oop 2 oop in c#: object-oriented design. realisation of object associations: 1-1,...

Post on 14-Dec-2015

220 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

TRANSCRIPT

AK IT: Softwarekonstruktion 1

Session 04:C# OOP 2

OOP in C#:Object-Oriented Design.

Realisation of Object Associations:1-1, 1-n, n-m.

UML Class Diagram.More about Object Interaction.

Collections of Objects

FEN 2013-01-27

FEN 2013-01-27 AK IT: Softwarekonstruktion 2

The Anatomy of a Class

Classes are usually written by this pattern:

class ClassName {

declaration of attributesconstructorspropertiesmethods

}

FEN 2013-01-27 AK IT: Softwarekonstruktion 3

The Class BankAccount- attributes and constructor

namespace Banking{

public class BankAccount{

private double balance;private int accNo;private int interestRate;

public BankAccount(int no, int ir){

balance = 0;accNo = no;intrestRate = ir;

}

FEN 2013-01-27 AK IT: Softwarekonstruktion 4

Methods

public bool Withdraw(double amount)

public void Deposite(double amout)

public void GiveInterest()

FEN 2013-01-27 AK IT: Softwarekonstruktion 5

Properties

public int InterestRate{

get{return interestRate;}set{if( value>=0) interestRate = value;}

}

Object Interaction

• Objects may be connected in different ways:– Association (“know-of-relation”).

One object uses another.

– Aggregation (“part-of-relation”).One object is a part of another.

• The distinction is not always clear .

FEN 2013-01-27 AK IT: Softwarekonstruktion 6

Means aggregation

Cardinality or Multiplicity• Tells how many other objects an

object may be associated with:– One customer may have one

account, an account must belong to a customer.

– One customer may have many accounts, an account must belong to one customer.

– A customer may one or more accounts, an account may belong to one or more customers.

FEN 2013-01-27 AK IT: Softwarekonstruktion 7Goes for

aggregation as well.

Object Interaction: 1 - 1

• The Banking example shows object interaction:– The classes are connected – in UML:

FEN 2013-01-27 AK IT: Softwarekonstruktion 8

In the Code

public class Customer{//…private BankAccount account;//…

account= new BankAccount(no, ir, bal);

FEN 2013-01-27 AK IT: Softwarekonstruktion 9

Customer is responsible for creating BankAccount objects.

The association is implemented by an

object reference (attribute).

In the Code

public class Program{ //… Customer c = new Customer(1, "Peter Thomsen"); //…

Console.WriteLine("Customer: "+ c.Name +" has DKK “ + c.Account.Balance + " in the bank");

FEN 2013-01-27 AK IT: Softwarekonstruktion 10

Methods in the other class is called using the reference.

Forest Exercise

• Solution?

FEN 2013-01-27 AK IT: Softwarekonstruktion 11

Implementing 1 - n• One customer may have many

accounts, an account must belong to one customer.

• Possible solution: A collection of BankAccounts in Customer (accounts)

FEN 2013-01-27 AK IT: Softwarekonstruktion 12

In the Code

public class Customer{ //…

private List<BankAccount> accounts; //… public Customer(int cNo, string n){

//… accounts = new List<BankAccount>();

}public void AddAccount(BankAccount acc){

accounts.Add(acc);}

//…

FEN 2013-01-27 AK IT: Softwarekonstruktion 13

View Source

AK IT: Softwarekonstruktion 14

Pair Programming(an eXtreme Programming practice)

• A well known and widely used technique:– Two programmers – one workstation– Programmer one is at the keyboard and have

focus on the details that are being typed.– Programmer two supervises programmer one’s

work and has the broader perspective and keeps focus on structure and what’s going to happen next.

– After a period (10 – 15 min.) programmer one and two swop roles.

FEN 2013-01-27

AK IT: Softwarekonstruktion 15

Exercise

• Do the Forest exercise (1 – 3) on Session04.docx.

• Use pair programming.

FEN 2013-01-27

Implementing n - m• A customer may have one or more

accounts, an account may belong to one or more customers.

• Possible solution: A collection of BankAccounts in Customer (accounts) and a collection of Customers (owners) in BankAccount.

FEN 2013-01-27 AK IT: Softwarekonstruktion 16

In the Code

public class BankAccount{ //…

private List<Customer> owners; //… public BankAccount(int no, double ir, double bal){ //… owners = new List<Customer>(); } public void AddOwner(Customer c) { owners.Add(c); }//…

FEN 2013-01-27 AK IT: Softwarekonstruktion 17

View Source

Exercise

• Do part 4 and 5 (Banking) of the exercises on Session04.docx

• Use pair programming.

FEN 2013-01-27 AK IT: Softwarekonstruktion 18

Implementing Associations Design Choices

• Several possibilities for the different cardinalities.

• The choice mostly depends on business logic (use cases)

FEN 2013-01-27 AK IT: Softwarekonstruktion 19

1 – 1:

• One of the objects must have a reference to the other.

• But which one?• Depends of business logic:

– Is access typically from Customer

– or

– from BankAccount?

FEN 2013-01-27 AK IT: Softwarekonstruktion 20

In Banking1

1 – n (1..*)

• Again – it depends on business logic:

– A collection of references on the 1-side?

– A single reference on the n-side?

FEN 2013-01-27 AK IT: Softwarekonstruktion 21

In Banking2

n - m (*..*)

• Here we have no choice:– There must be a collection in at least one of the classes:

FEN 2013-01-27 AK IT: Softwarekonstruktion 22

• But this is often a problematic solution:• Complicated to maintain.• Lots of coding is required for doing updates, inserts and deletes.

In Banking3

n - m (*..*)

FEN 2013-01-27 AK IT: Softwarekonstruktion 23

• But this is often a problematic solution:• Complicated to maintain.• Lots of coding is required for doing updates, inserts and deletes.

• Often it is a good design to introduce a connection object:

• And replace the n – m association by two 1 – n associations.• The designs for 1 – n may then be applied.• If there are any information on the association, this is necessary:

Example: Project Management

• Lets look at an other example:– An employee may work on several projects.– A project may have several employees working on it.– We need to record the number of hours a given

employee has spent on a given project:

FEN 2013-01-27 AK IT: Softwarekonstruktion 24

Let’s dive into the code

Exercises• Do part 6 (EmpProjV1) on Session04.docx

• Do part 7 (Banking3) on Exercises03.pdf.

• Use pair programming.

FEN 2013-01-27 AK IT: Softwarekonstruktion 25

top related