Difference between revisions of "OOP Class7"

esse quam videri
Jump to: navigation, search
(Review)
(Home Work)
Line 279: Line 279:
  
 
<pre>
 
<pre>
Test Student()
+
CourseName:Object Oriented Programming CoureseNumber:36-2600
 
+
Hello my name is Jeff Meyers my ID is 47167
Jeff Meyers says hello.
+
I'm teaching:
StudentDiagram.Student Jeff Meyers
+
CourseName:Object Oriented Programming CoureseNumber:36-2600
StudentID = 0000
+
Hello my name is Sean  my ID is 666
0 Courses
+
I'm taking:
 
+
CourseName:Object Oriented Programming CoureseNumber:36-2600
Test Student("Matina" , "Navratilova" )
+
CourseName:Writing and Retoric CoureseNumber:42-1000
 
+
ConsoleApplicationExtreemeCourse.Pencil is sharp
Matina Navratilova says hello.
+
ConsoleApplicationExtreemeCourse.Pencil is not sharp
StudentDiagram.Student Matina Navratilova
 
StudentID = 0000
 
0 Courses
 
 
 
Test Student("Dan", "Rockwood")
 
 
 
Dan Rockwood says hello.
 
StudentDiagram.Student Dan Rockwood
 
StudentID = 0000
 
0 Courses
 
 
 
Make Some Course
 
CourseName: Object Oriented Programming CourseName: 36-1300
 
 
 
Add Course
 
StudentDiagram.Student Dan Rockwood
 
StudentID = 0000
 
5 Courses
 
CourseName: Object Oriented Programming CourseName: 36-1300
 
CourseName: Media Theory and Design 1 CourseName: 36-1000
 
CourseName: Media Theory and Design 2 CourseName: 36-2000
 
CourseName: English 101 CourseName: 52-1000
 
CourseName: Gym 101 CourseName: 11-1111
 
StudentDiagram.Student Dan Rockwood
 
StudentID = 0000
 
4 Courses
 
CourseName: Object Oriented Programming CourseName: 36-1300
 
CourseName: Media Theory and Design 1 CourseName: 36-1000
 
CourseName: English 101 CourseName: 52-1000
 
CourseName: Gym 101 CourseName: 11-1111
 
StudentDiagram.Student Dan Rockwood
 
StudentID = 0000
 
5 Courses
 
CourseName: Object Oriented Programming CourseName: 36-1300
 
CourseName: Media Theory and Design 1 CourseName: 36-1000
 
CourseName: test 101 CourseName: 00-0000
 
CourseName: English 101 CourseName: 52-1000
 
CourseName: Gym 101 CourseName: 11-1111
 
 
 
Test Instructor
 
StudentDiagram.Instructor Edna Krabappel
 
FacultyID = 0000
 
1 Course
 
CourseName: English 101 CourseName: 52-1000
 
 
 
Test Pencil
 
StudentDiagram.Pencil.isSharp = True
 
Dan has no pencil
 
StudentDiagram.Pencil.isSharp = True
 
All work and no play makes Dan a dull student.
 
StudentDiagram.Pencil.isSharp = False
 
All work and no play makes Dan a dull student.
 
StudentDiagram.Pencil.isSharp = False
 
 
</pre>
 
</pre>
 
 
Cat thingy
 
 
http://iam.colum.edu/oop/classsource/class6/CatConatnamntAndAssoc.zip
 

Revision as of 15:12, 20 October 2015

OOP Arrays

Review

  • OOP Class1 Introduction to .NET and C#
    • Compliled vs Interpreted Languages
  • OOP Class2 C# fundamentals
    • Basic Data Types
    • Operators
    • Conversion Casting
    • Constants
    • Arrays
      • Single Arrays
      • Multi Dimensianal Arrays
      • Jagged Arrays
      • Enumerators
  • OOP Class3 CSharp Control Structures
    • Operators
    • Branching Statements
      • Branching
        • If
        • Switch
      • Looping
        • for
        • foreach
        • do
        • while
  • OOP Class4 Classes and Objects
    • Encapsulation
    • Classes
      • Fields
      • Methods
      • Constuctor
    • Overloading
  • OOP Class5 Object Relationships
    • Access Modifiers
    • Accessors
    • Static Members
    • Relationships
      • Association 'Uses a'
      • Containment 'Has a'
      • Inhertance 'Is a'
  • OOP Class6 Object Relation Ships 2 / UML
    • UML
    • Inheritance 'Is A'
    • Virual Functions Override
    • Polymorphism
    • Structs
  • OOP Class7 Polymorphism / Visual Studio 2005
    • Fancy Arrays
    • Colections
    • Polymorphism

Cat app with multiple toys

Course App in console and windows

Structs

Lightweight alternatives to classes. Structs do not support inheritance or destructors. Don't worry if you don't understand structs yet it hard cuz the book teaches them before classes. We will talk more about stucts after we talk about classes Syntax

[ attributes] [access-modifiers] struct identifier [:interface-list {struct members}

<csharp>struct Dog {

public string name;
public string weight;
public int age;

}</csharp>

Enumerators

Enumerators are used to set predefined list of named constants. Syntax

[ attributes] [modifiers] enum identifier [:base-type {enumerator-list};

<csharp>//An enumerator for ServingSizes at BK enum ServingSizes : uint {

 Small = 0,
 Regular = 1,
 Large = 2,
 SuperSize = 3

}</csharp>

<csharp>//another more useful example // forced sequence to start // from 1 instead of 0 (default) enum Months

 {
   January = 1, February , March, April ,
   May , June , July , August , Sept , Oct , Nov , Dec 
 }</csharp>

Enumerator Example Enum.cs


Fancy Arrays

Arrays

Regular Array objects are like list collections

Arrays are groups of variables of the same type

Syntax
        type [] identifier

single dimension arrays

<csharp>string [] aryNames = new string[5];

aryNames [0] = "Feta"; aryNames [1] = "Colby"; aryNames [2] = "Gruyere"; aryNames [3] = "Edam"; aryNames [4] = "Colby";</csharp>

Arrays are actually objects and support various methods.

  • GetValue
  • IndexOf
  • LastIndexOf
  • SetValue
  • Reverse
  • Sort

GetValue

<csharp>string s = aryNames.GetValue(1).ToString();</csharp>

s="Colby"

IndexOf

<csharp>int i = Array.IndexOf(aryNames, "Colby");</csharp>

i=1

LastIndexOf

<csharp>int Lasti= Array.LastIndexOf(aryNames, "Colby");</csharp>

Lasti=4

SetValue <csharp>

   aryNames.SetValue("Gouda", 1);
   string setValue = aryNames.GetValue(1).ToString();</csharp>

Now Array(1) == "Gouda"

Reverse

Reverse reverses the array

<csharp>Array.Reverse(aryNames);</csharp>

The Reversed array looks like Reverse

0 Colby
1 Edam
2 Gruyere
3 Gouda
4 Feta

Sort

The Sort method sort the array. Arrays are sorted accourding to how objects compare to each other usually implemented using the IComparer interface

<csharp>Array.Sort(aryNames);</csharp>

The Sorted Array List Looks like

0 Colby
1 Edam
2 Feta
3 Gouda
4 Gruyere

Array Example 2

Array2.cs

Pros and Cons of working with arrays pros

  • East to use
  • Fast to alter
  • Flast to iterate though
  • Specific type of elements ( single type)

cons

  • Fixed size
  • Insterting is difficult

Collections

Collections are groups of objects. types of collections

  • set - no index
  • list - has index
  • map - has key/value pair

Set is like storing a bunch of objects in a bag. The order they are removed from the bag has nothing to do with the order they are removed. Set collections do not have a unique identifier.

List types of collections have an integer for an indexer. This gives them a unique identifier and an order.

Map types also have an index but it is not necessarily an integer. It could be anything unique.

List

The List of now part of System.Collections. In order to user it you must add a using statement <csharp>using System.Collections.Generic;</csharp>

create an arraylist

<csharp>List<String> myList = new List<String>();</csharp>

add and element or two <csharp> myList.Add("Feta"); myList.Add("Colby"); myList.Add("Gruyere"); myList.Add("Edam"); myList.Add("Colby"); </csharp> This produces and List like

Feta
Colby
Gruyere
Edam
Colby

Insert an element

<csharp>myList.Insert(1,"Gouda");</csharp>

Now our ArrayList Looks like

Feta
Gouda
Colby
Gruyere
Edam
Colby

Remove an element

<csharp>//remove by index myList.RemoveAt(1); //remove by data myList.Remove("Colby"); //removes first occurance of Colby </csharp>

Now our List looks like

Feta
Gruyere
Edam
Colby

Pros and con of Generic Lists Pros

  • No fixed size
  • Insert and Remove

Cons

  • Slower than arrays
  • Inefficient with memory (when the array size exceeds the upper bound .NET doubles the size of the array.

ArrayList Example

ArrayList.cs

Polymorphism

Arrays and Collections of objects allow for polymorphism.

foreach

<csharp>foreach (string n in aryNames) {

aryDropDown.Items.Add(n);

}</csharp>

Pair Programming

Pair Programming

We are going to pair off to do our next assignment. Many of the paired programming principles come from XP (http://www.extremeprogramming.org/ Extreeme Progamming)

Pairs are good because

  • Pairs keep each other on track
  • A partner can help when you are stuck
  • Keep each other accountable


Some XP Principles

Fail - If you are having trouble succeeding fail.

Baby Steps - Do the smallest thing that you possible can that moves you in the right direction

Integrate and communicate your code often. Try posting up your code and emailing or plan on meeting several times.

When two pair programmers are together one you should sit a one computer (yeah that right two of you at one computer) and one should type while the other watches and reflects. Feel free to slide the keyboard back and forth when someone get tired, stuck or has a new idea.

I would like you and your paired partner to create and demonstrate classes in c# from the diagram below.

Home Work

OOP Students Classes Diagram

If you need to add any supporting methods or properties that are not on the diagram feel free.


CourseName:Object Oriented Programming CoureseNumber:36-2600
Hello my name is Jeff Meyers my ID is 47167
I'm teaching:
CourseName:Object Oriented Programming CoureseNumber:36-2600
Hello my name is Sean  my ID is 666
I'm taking:
CourseName:Object Oriented Programming CoureseNumber:36-2600
CourseName:Writing and Retoric CoureseNumber:42-1000
ConsoleApplicationExtreemeCourse.Pencil is sharp
ConsoleApplicationExtreemeCourse.Pencil is not sharp