Sponsored Content
Top Forums Programming C++ : Base class member function not accessible from derived class Post 302910005 by anand.shah on Tuesday 22nd of July 2014 02:02:14 AM
Old 07-22-2014
C++ : Base class member function not accessible from derived class

Hello All,
I am a learner in C++. I was testing my inheritance knowledge with following piece of code.

Code:
#include <iostream>

using namespace std;

class base
{
	public :
		void display()
		{
			cout << "In base display()" << endl;
		}
		void display(int k)
		{
			cout << "In base display(int k)" << endl;
		}
};

class derived : public base
{
	public :
		void display()
		{
			cout << "In derive display()" << endl;
		}
};

int main()
{
	derived der;	
	der.display(50);
}


As far as I know it should compile without giving any error. But that is not the case as it is giving compilation error saying :-

Code:
StaticMember_1.cpp: In function ‘int main()':
StaticMember_1.cpp:30: error: no matching function for call to ‘derived::display(int)'
StaticMember_1.cpp:21: note: candidates are: void derived::display()

Can you guys help me out in finding why its giving error. there must be some concept here which I am missing.
Thanks in advance all of you.

Regards,
Anand Shah
 

9 More Discussions You Might Find Interesting

1. Programming

How to make a function friend to both base and derived class

Hi, I have a base class and derived a class from the base class, i want to print & read the data for the object created for the derived class,so i have overloaded both the << and >> operators and also have done the foward declaration. Below is the code snippet, #include <iostream> class... (3 Replies)
Discussion started by: ennstate
3 Replies

2. Programming

Handling a signal with a class member function

Hello, i am using the sigaction function to handle the SIGCHLD signal.Is it possible to use a class member function as the handler function (the sa_handler member of the sigaction structure)? The function's signature is: void (*sa_handler)(int);so i don't think i can use a static member function... (2 Replies)
Discussion started by: Zipi
2 Replies

3. Programming

C++ class definition with a member of the same class

Hi, i have a question about C++. Is it possible to declare a class with a member ot the same class? For example, a linked list or i want to convert this C code to C++ class (Elemento) typedef struct elemento { char name; char value; List<struct elemento> ltElementos; ... (7 Replies)
Discussion started by: pogdorica
7 Replies

4. Programming

Base class's variables not accessible????

Hi friends, The derived class cannot access the base class's variables in my program. You can have a look at my code, I am actually using class templates. #include <iostream> using namespace std; template <class T> class Sum { friend void Check(Sum &s, T a, T b) { T x,... (2 Replies)
Discussion started by: gabam
2 Replies

5. Programming

Writing C++ class and member functions

I have the following class and thought that when I call the set command to set a member, I always use value. Would that be fine? class ModMisfit { protected: Real dtau; Real mdacc; Real mindist; bool hw; Source** src; public: void ... (7 Replies)
Discussion started by: kristinu
7 Replies

6. UNIX for Advanced & Expert Users

Get pointer for existing device class (struct class) in Linux kernel module

Hi all! I am trying to register a device in an existing device class, but I am having trouble getting the pointer to an existing class. I can create a class in a module, get the pointer to it and then use it to register the device with: *cl = class_create(THIS_MODULE, className);... (0 Replies)
Discussion started by: hdaniel@ualg.pt
0 Replies

7. Programming

Size of Derived class, upon virtual base class inheritance

I have the two class definition as follows. class A { public: int a; }; class B : virtual public A{ }; The size of class A is shown as 4, and size of class B is shown as 16. Why is this effect ?. (2 Replies)
Discussion started by: techmonk
2 Replies

8. Programming

Restricting member of a class non-inheritable in C++

There is base class B, and two derived classes D1 and D2 derived from Base. Base class B, have two data members ( public or protected or private or if any). D1 should inherit both these data members, and D2 should be deriving only one member from Base class. Is this kind of design possible without... (1 Reply)
Discussion started by: techmonk
1 Replies

9. Programming

Size of derived class, in case of multiple inheritance

Why, here the size of class 'Derived' is 8 ? class Base1 { public: virtual void f() { } }; class Base2 { public: virtual void f() { } }; class Derived : public Base1, Base2 { public: virtual void f() { } }; (1 Reply)
Discussion started by: techmonk
1 Replies
FBB::MultiStreambuf(3bobcat)				     Writing multiple streams				      FBB::MultiStreambuf(3bobcat)

NAME
FBB::MultiStreambuf - Selectively writes multiple streams SYNOPSIS
#include <bobcat/multistreambuf> Linking option: -lbobcat DESCRIPTION
The FBB::MultiStreambuf class is a specialization of std::streambuf. It can be used to write selectvely to multiple std::ostreams. Each std::ostream that is associated with an FBB::MultiStreambuf is given a mode-tag indicating whether the stream should always be used when information is inserted into the FBB::MultiStreambuf, just once, or not at all. Each of the stream's mode-tags may be set to any of the defined tag-values. When the address of a FBB::MultiStreambuf is used to initialize a std::ostream the constructed std::ostream becomes an output-multiplexer: by inserting information into the std::ostream object, all std::ostream objects added to its FBB::MultiStreambuf buffer which have an active mode will receive that information. An FBB::MultiStreambuf object should be outlived by all active streams that are associated with it. No assumptions should be made about the order in which the std::ostream objects that are associated with the FBB::MultiStreambuf objects are visited when information is inserted. NAMESPACE
FBB All constructors, members, operators and manipulators, mentioned in this man-page, are defined in the namespace FBB. INHERITS FROM
std::streambuf ENUMERATION
In the Mode enumeration the following values are defined: o OFF: A std::ostream having this mode will not be used when information is inserted into an FBB::MultiStreambuf o ON: A std::ostream having this mode will be used when information is inserted into an FBB::MultiStreambuf o ONCE: A std::ostream having this mode will be used once, until the next flushing operation, when information is inserted into an FBB::Mul- tiStreambuf o RESET: A std::ostream having this mode will not be used when information is inserted into an FBB::MultiStreambuf. At a flush operation all ONCE modes will be set to RESET TYPES
The following subtypes are defined in the class FBB:MultiStreambuf: o iterator: This is a synonym of std::vector<stream>::iterator o const_iterator: This is a synonym of std::vector<stream>::const_iterator NESTED CLASS
The class FBB::MultiStreambuf::stream is defined as a nested class of FBB::MultiStreambuf. It offers the following constructor and public members: o stream(std::ostream &os, Mode mode = ON): The constructor stores a std::ostream object, and associates a Mode value with it. o void setMode(Mode mode): This member is used to redefine the stream's Mode value. o void mode() const: This member returns the stream's Mode value. o operator std::ostream &(): This member returns the stream's std::ostream. CONSTRUCTORS
o MultiStreambuf(): The default constructor creates a FBB::MultiStreambuf object which contains no associated std::ostream objects. o MultiStreambuf(std::ostream &os, Mode mode = ON): This constructor creates a FBB::MultiStreambuf object which is immediately associated with the std::ostream specified as its first argument. o MultiStreambuf(std::vector<MultiStreambuf::stream> const &osvector): This constructor creates a FBB::MultiStreambuf object which is immediately associated with all std::ostream objects that are stored in the MultiStreambuf::stream elements of the specified vector. The copy constructor is available. MEMBER FUNCTIONS
All members of std::ostringstream and std::exception are available, as FBB::MultiStreambuf inherits from these classes. o iterator begin(): This member returns an iterator to the first stream element that is stored in a FBB::MultiStreambuf object. o const_iterator begin(): This member returns an iterator to the first (unmodifiable) stream element that is stored in a FBB::MultiStreambuf object. o iterator end(): This member returns an iterator pointing beyond the last stream element that is stored in a FBB::MultiStreambuf object. o iterator end(): This member returns an iterator pointing beyond the last (unmodifiable) stream element that is stored in a FBB::MultiStreambuf object. o void insert(std::ostream &os, Mode mode = ON): This member adds the specified std::ostream using the specified Mode to the current set of stream objects. o void insert(std::vector<stream> const &os): This member adds all stream objects stored in the os vector to the current set of stream objects. o void void setOnce(): This member will reset all the RESET Mode values of the stored stream objects to ONCE. PROTECTED MEMBER FUNCTION
The member listed in this section implements the tasks of the comparably named virtual function in the class's private interface. This sep- arates the redefinable interface from the user-interface. The class MultiStreamBuf can, in accordance with Liskov's Substitution Principle, be used as a std:streambuf; but it also offers a facility for classes deriving from MultiStreamBuf. This facility is listed here. o int pSync(): The contents of the MultiStreamBuf's internal buffer is written to each of the std::ostream objects to which the MultiStreamBuf object has access. EXAMPLE
#include <iostream> #include <fstream> #include <bobcat/multistreambuf> using namespace std; using namespace FBB; int main() { MultiStreambuf msb(cout); ostream os(&msb); ofstream out("out"); msb.insert(out, MultiStreambuf::ONCE); os << "This is on cout and out" << endl; os << "This is on cout only" << endl; msb.setOnce(); os << "This is on cout and out" << endl; os << "This is on cout only" << endl; return 0; } FILES
bobcat/multistreambuf - defines the class interface SEE ALSO
bobcat(7) BUGS
None Reported. DISTRIBUTION FILES
o bobcat_3.01.00-x.dsc: detached signature; o bobcat_3.01.00-x.tar.gz: source archive; o bobcat_3.01.00-x_i386.changes: change log; o libbobcat1_3.01.00-x_*.deb: debian package holding the libraries; o libbobcat1-dev_3.01.00-x_*.deb: debian package holding the libraries, headers and manual pages; o http://sourceforge.net/projects/bobcat: public archive location; BOBCAT
Bobcat is an acronym of `Brokken's Own Base Classes And Templates'. COPYRIGHT
This is free software, distributed under the terms of the GNU General Public License (GPL). AUTHOR
Frank B. Brokken (f.b.brokken@rug.nl). libbobcat1-dev_3.01.00-x.tar.gz 2005-2012 FBB::MultiStreambuf(3bobcat)
All times are GMT -4. The time now is 03:36 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy