1 / 23

Modeling Tax Hierarchy for Mail Order Business

Implementing class hierarchy to handle tax calculation for different merchandise types with varying rates based on state and cost. Includes discussion on interfaces, relationships, object serialization, and safety considerations in Java.

ros
Download Presentation

Modeling Tax Hierarchy for Mail Order Business

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Discussion E Class Hierarchy II

  2. Hierarchy A mail order business sells catalog merchandise all over the country. The rules for taxation on the merchandise vary from state to state. Also, the rate of taxation can be different based on the type of merchandise. For simplicity, we will consider three types of merchandise, clothing, pharmaceutical, and beauty products. Suggest a class hierarchy to model the tax on a merchandise.

  3. Merchandise Tax Merchandise Clothing Tax Clothing

  4. public abstract class Merchandise { Tax tax; public int getCost() {} public int getTax(int zipCode) { return tax.getTax(zipCode); } } public class Clothing extends Merchandise { public Clothing () { tax = new ClothingTax(this); } public int getCost() {} }

  5. public abstract class Tax { Merchandise article; public Tax(); public int getTax(int zipCode); } public class ClothingTax extends Tax { //imagine a static zipcode indexed table for looking //up taxation public ClothingTax(Clothing article) {this.article=article;} public int getTax(int zipCode); } We may want to model zip code explicitly using a Location class.

  6. Interfaces Tax Merchandise Clothing

  7. Extension • assumed that tax rate was flat for a type • it may depend on cost of item • clothes > $250 may be taxed differently

  8. Detailed Location Tax Merchandise MA Clothing Tax Clothing 01003

  9. Relationships • Is-A • inheritence • Has-A • composition • Uses • parameters, calls • Is-Used-By • Uses of other classes

  10. Ellipse and Circle b r a x2 + y2 -- -- = 1 a2 b2 x2 + y2 =r2 public class Circle { int r; } public class Ellipse { int a; int b; }

  11. Object Serialization • Applications need to save data • Saving an object may require saving of a sub-graph • Object graph converted in series of bytes • De-Serialization recreates objects from these bytes

  12. Example (1) public class X { int x; } public class Y { int y; X xobj; } public class App { Y yobj; } x y Y: y X: x

  13. Serialization • java.io.Serializable • Marker interface, has no methods • java.io.ObjectInputStream, java.io.ObjectOutputStream define default methods to read and write objects

  14. Example (2) public class X implements Serializable { int x; } public class Y implements Serializable { int y; X xobj; } public class App { Y yobj; public void save() {} public void restore() {} }

  15. Example (3) public void save { FileOutputStream fs = new FileOutputStream("y.save"); ObjectOutputStream out = new ObjectOutputStream(fs); out.writeObject(yobj); out.close(); }

  16. Example (4) public void restore { FileInputStream fs = new FileInputStream("y.save"); ObjectInputStream in = new ObjectInputStream(fs); yobj = (Y) in.readObject(); in.close(); }

  17. Safety • Java generates a serialVersionUID for each class • Matched for correctness at de-serialization • You can override by defining you own field in class • static final long serialVersionUID = XXXX

  18. Limitation • No control on what gets written • Class info, fields stored as<name, value>pair • Designed for generality • Customization • readObject(),call defaultReadObject()first • writeObject(), call defaultWriteObject()first • Optimization: fields markedtransientare not serialized

  19. Externalizable • Lightweight • does not store name-value pair • order is important, serialization allows reading in any order • explicitly handle class hierarchy • no argument constructor needed • Allows complete control on what gets written • Methods defined in ObjectInputObjectOutput can be used

  20. Example (5) public class X implements Externalizable { int x; void readExternal(ObjectInput in) throws IOEx,CNFEx{} void writeExternal(ObjectOutput out) throws IOEx {} } public class Y implements Externalizable { int y; X xobj; void readExternal(ObjectInput in) throws IOEx,CNFEx{} void writeExternal(ObjectOutput out) throws IOEx {} }

  21. Example (6) public class X implements Externalizable { int x; void readExternal(ObjectInput in) throws IOEx, CNFEx { super.readExternal(in); x = in.readInt(); } void writeExternal(ObjectOutput out) throws IOEx { super.writeExternal(); out.writeInt(x); } }

  22. Example (7) public class Y implements Externalizable { int y; X xobj; void readExternal(ObjectInput in) throws IOEx, CNFEx{ super.readExternal(in); y = in.readInt(); xobj = in.readObject(); } void writeExternal(ObjectOutput out) throws IOEx { super.writeExternal(); out.writeInt(y); out.writeObject(xobj); } }

  23. Example (8) public class App { Y yobj; public void save { FileOutputStream fs= new FileOutputStream("y.save"); ObjectOutput out = new ObjectOutput(fs); yobj.writeExternal(out); out.close(); } public void restore { FileInputStream fs = new FileInputStream("y.save"); ObjectInput in = new ObjectInput(fs); Y nyobj = new Y(); nyobj.readExternal(in); in.close(); } }

More Related