Solved

Layering or Private Inheritance

Posted on 1998-04-06
7
376 Views
Last Modified: 2008-03-03
I am currently developing a basic database application using CodeBase 6.3.  I want to access all Codebase classes via my own classes in order to abstract(??) the majority of my code from CodeBase so that in the event that I change database engines down the track, switching over will be a relatively easy task.

Codebase uses a number of classes, one of which (Code4) is a class controlling data on a global basis, maintaining error codes and general determining the way data files will behave.  Another class (Data4) controls the data files themselves.  Data4 requires access to the Code4 class for certain functions however I do not want the Code4 member to be visible on a public basis.

Let's call my classes Class A (my equivalent of Code4) and Class B (my equivalent of Data4).  I am unsure as to which of the following methods to use:

a) Private Inheritance: Class A derived privately from Code4 and declaring Class B as a friend to allow access to Code4 members.
b) Layering: Class A contains a private member variable Code4 and declaring Class B as a friend.
c) A better method I have missed.

Any advice would be greatly appreciated.  Please reply via private email to woodster@wantree.com.au as well as to the newsgroup as my newsfeed is not the best.

Thanks in advance.

Sean Hannan
0
Comment
Question by:spearhead
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
7 Comments
 
LVL 1

Expert Comment

by:GregL
ID: 1184087
What you are trying to acheive is database independance.  THe proposed methods you describe cannot achieve this because your implementation is using knowledge that Code4 needs Data4.  My suggestion is to write a single wrapper class that uses Code4 and Data4, but exports a simple public interface for the eventual application to use.  With this approach a new database just means you rewrite one class.

Greg L.
0
 
LVL 11

Expert Comment

by:alexo
ID: 1184088
I'd suggest:
c) Write a single class X that has Code4 and Data4 as members.
0
 

Author Comment

by:spearhead
ID: 1184089
Unfortunately, CodeBase has a number of classes in addition to the Code4 and Data4 classes meaning that wrapping all of the functionality into a single class would be cumbersome and (I believe) inefficient.  I am not "recoding classes" on a 1 for 1 basis but grouping multiple classes into one of my own where possible.  The Code4 and Data4 classes were used in the example as this is the starting point for CodeBase files.  The fact that Data4 needs Code4 will not (I believe) be a problem as ClassA and ClassB are accessed publicly and the use of the Data4 and Code4 members is internal to these new classes.
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 

Author Comment

by:spearhead
ID: 1184090
By the way - Don't worry about the private email/news feed comment at the bottom of the original question.  I just noticed it still there and as you can probably guess, this question was also posted on USENET . . . Ooops.
0
 
LVL 1

Expert Comment

by:slinky
ID: 1184091
I would create a separate a proxy class to represent the interface to your database classes i.e. abstract the database access to a higher level so that the application only accesses the database via the proxy view. a proxy is a standard pattern for this sort of job.
0
 
LVL 5

Accepted Solution

by:
yonat earned 150 total points
ID: 1184092
Take a look at http://www.kinetica.com/ootips/persistent-objects.html . There is some discussion, links to products that do this (so you don't have to write it yourself) and links to articles (in case you insist on writing this yourself).

As you can see, this is never simple. The proxy solutions is correct, but a just saying "proxy" does not explain how to create a full solution. If you want to write such a thing, you really need to read at least one or two articles about this subject.

BTW, one of the easiest ways to do such things is explained at http://www.sigs.com/publications/docs/cppr/9605/cppr9605.f.cohen.html . I am metioning this here since there is no link to it from the page I mantioned above.

Good luck!
0
 

Author Comment

by:spearhead
ID: 1184093
Although the answer didn't detail anything specific, I was able to take some information from the links you gace and then search for some more information to finally obtain relevant information for my requirements.

Thanks for the help
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Excel/Word Add-in in what language? 5 163
Find Visual Studio Tools 2 135
DCT of  2D array using fftw in c++ 9 133
Bitwise and to sum elements 2 53
Errors will happen. It is a fact of life for the programmer. How and when errors are detected have a great impact on quality and cost of a product. It is better to detect errors at compile time, when possible and practical. Errors that make their wa…
Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
The goal of the tutorial is to teach the user how to use functions in C++. The video will cover how to define functions, how to call functions and how to create functions prototypes. Microsoft Visual C++ 2010 Express will be used as a text editor an…
The goal of the video will be to teach the user the concept of local variables and scope. An example of a locally defined variable will be given as well as an explanation of what scope is in C++. The local variable and concept of scope will be relat…

739 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question