473,398 Members | 2,088 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,398 software developers and data experts.

HELP! Design ideas for an inheritance problem.

I have a Person object and from that I'm inheriting other objects
including Client, Carer, Doctor (and others). The Person object has a
large number of properties and methods that I want available in
Client, Carer and Doctor.

Person <- Client
Person <- Carer
Person <- Doctor

My problem however is an individual can be a Client and a Carer so in
this situation I want multiple inheritance.

Person <- Client
<- Carer

Another time an individual might be a Carer and a Doctor.

Person <- Carer
<- Doctor

Obviously I can't do this. I need some design that allows me to test
whether a Person is a Carer, Client or Docotor and then get the object
for it.

Any ideas?

Thanks,
Darren.
Nov 16 '05 #1
3 1075
Hello!

"Darren" <wa********@hotmail.com> wrote in message
news:cd**************************@posting.google.c om...
I have a Person object and from that I'm inheriting other objects
including Client, Carer, Doctor (and others). The Person object has a
large number of properties and methods that I want available in
Client, Carer and Doctor.

Person <- Client
Person <- Carer
Person <- Doctor

My problem however is an individual can be a Client and a Carer so in
this situation I want multiple inheritance.

Person <- Client
<- Carer

Another time an individual might be a Carer and a Doctor.

Person <- Carer
<- Doctor

Obviously I can't do this. I need some design that allows me to test
whether a Person is a Carer, Client or Docotor and then get the object
for it.

Any ideas?


I would define interfaces for non-instrinsic features.
Instread of defining classes like Doctor and Carer, you may define
interfaces like IDoctor and ICarer (or with better names).
Now you inherit from Person and implement both IDoctor and ICarer.
At least, this is how you mimic multiple inheritance.
Sam
Nov 16 '05 #2
No, you DON'T want multiple inheritance. If there are naming collisions or -
worse - redundant implementations (you're gonna get update anomalies, just
because it's in memory you aren't off the hook for normalising your data
model) then how are you going to determine precedence?

Don't inherit. Aggregate.

Give Person a collection of Roles. That way you can add Role instances till
the cows come home and access all of them with no semantic ambiguity. If
there is a many to many relation between Person and Role then do the same as
you would in an on-disk database and relate them with another table
PersonRole. You're gonna need either doubly-linked-lists or two hashtables
for each relation (so you can traverse both ways).
Nov 16 '05 #3
Luckily I readed your text before I started typing.

Just to tell that I agree with you.

Cor
Nov 16 '05 #4

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

21
by: Dave | last post by:
After following Microsofts admonition to reformat my system before doing a final compilation of my app I got many warnings/errors upon compiling an rtf file created in word. I used the Help...
9
by: Tom | last post by:
A question for gui application programmers. . . I 've got some GUI programs, written in Python/wxPython, and I've got a help button and a help menu item. Also, I've got a compiled file made with...
4
by: Sarir Khamsi | last post by:
Is there a way to get help the way you get it from the Python interpreter (eg, 'help(dir)' gives help on the 'dir' command) in the module cmd.Cmd? I know how to add commands and help text to...
2
by: Sudheer Kareem | last post by:
Dear All Please tell me how to assosiate help files with my Vb.net Project. Regards Sudheer
6
by: wukexin | last post by:
Help me, good men. I find mang books that introduce bit "mang header files",they talk too bit,in fact it is my too fool, I don't learn it, I have do a test program, but I have no correct doing...
6
by: d.warnermurray | last post by:
I am doing a project for school that involves creating help files for a html authoring tool. If you could help me with answers to some questions it would really help. 1. What tasks do you expect...
0
by: tbatwork828 | last post by:
If you were like me trying to figure out how to launch context sensitive help topic by the context id, here is the link: http://weblogs.asp.net/kencox/archive/2004/09/12/228349.aspx and if...
5
by: Steve | last post by:
I have written a help file (chm) for a DLL and referenced it using Help.ShowHelp My expectation is that a developer using my DLL would be able to access this help file during his development time...
10
by: JonathanOrlev | last post by:
Hello everybody, I wrote this comment in another message of mine, but decided to post it again as a standalone message. I think that Microsoft's Office 2003 help system is horrible, probably...
1
by: trunxnirvana007 | last post by:
'UPGRADE_WARNING: Array has a new behavior. Click for more: 'ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?keyword="9B7D5ADD-D8FE-4819-A36C-6DEDAF088CC7"' 'UPGRADE_WARNING: Couldn't resolve...
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.