Re: problem using self built DLL



You are confusing code loading strategy with compilation strategy; they are only vaguely
related. While it is true that the CODE that IMPLEMENTS the class is not loaded until
runtime, the compiler still has to know about the class and all its methods, members, its
size, etc., AT COMPILE TIME or it can't connect to that code.
joe

On 22 Apr 2007 15:22:53 -0700, wanwan <ericwan78@xxxxxxxxx> wrote:

On Apr 22, 1:03 pm, Joseph M. Newcomer <newco...@xxxxxxxxxxxx> wrote:
See below...
On 20 Apr 2007 11:47:16 -0700, wanwan <ericwa...@xxxxxxxxx> wrote:

I made an MFC extension DLL, but I couldn't get it working on the
client application. Can somebody please tell me what I did wrong in
the procedure:

1. I started an MFC extension DLL project called "MyDll". I added a
class called "MyClass" and added the keyword AFX_EXT_CLASS in the
class declaration in the header file.

2. I built the project and copied the files "MyDll.dll" and
"MyDll.lib" to the client project folder.

3. In the client project settings, I added the file MyDll.lib in the
linker - input section.

4. I made a MyDll.h file with the line: class AFX_EXT_CLASS MyClass;

*****
So right there, you have made a serious error. You have declared that there is a class
called MyClass, AND YOU HAVE SAID NOTHING MORE ABOUT IT! This is a "forward"
declaration, wherein you promise to say something later.
*****

5. I used #include "MyDll.h" in the cpp files where I need MyClass.

With the above steps, I expect MyClass to be defined. But when I use
the imported class it gave me the error:

error C2079: 'CClientApp::myobject' uses undefined class 'MyClass'

*****
You get this error because it IS an undefined class. You promised to say something about
it later, and never did, so there is no possible way for the compiler to know what the
class does. It does not know what size it is, what members it has, or anything other than
its name (of course, had you wanted to give a meaningful error message, you would have
shown the line that this erorr complains about. It would be obvious; it would be a
declaration of a MyClass variable, or an attempt to use any method or access any member of
the class).

Your .h file must contain the entire class declaration. If you do not want the
implementation visible, then the .h file declares the class, and your implementation will
declare a derived subclass of that class.
joe
*****
*****

Please advise.

Joseph M. Newcomer [MVP]
email: newco...@xxxxxxxxxxxx
Web:http://www.flounder.com
MVP Tips:http://www.flounder.com/mvp_tips.htm

My impression is that the class MyClass is loaded from the DLL after I
specify the library file in linker.
In my test program, MyClass has no member function or member
variable. I thought I would start to add them after I get the DLL
working.

If I'm supposed to give the details of MyClass in source code, what's
the point of building a DLL?
Joseph M. Newcomer [MVP]
email: newcomer@xxxxxxxxxxxx
Web: http://www.flounder.com
MVP Tips: http://www.flounder.com/mvp_tips.htm
.



Relevant Pages

  • Re: problem using self built DLL
    ... called MyClass, AND YOU HAVE SAID NOTHING MORE ABOUT IT! ... declaration, wherein you promise to say something later. ... MyClass has no member function or member ... I thought I would start to add them after I get the DLL ...
    (microsoft.public.vc.mfc)
  • Re: Privacy and scope and love
    ... > class MyClass ... > struct MyStruct ... on "Access to Base Classes" states that "The members of a member class have ... I suppose that you could make a forward declaration of the MyStruct class ...
    (comp.lang.cpp)
  • Re: problem using self built DLL
    ... says to the compiler, "I will tell you about this class in detail before you need it". ... which says "This is a class with no member variables and no methods". ... class declaration in the header file. ... called MyClass, AND YOU HAVE SAID NOTHING MORE ABOUT IT! ...
    (microsoft.public.vc.mfc)
  • Re: How to solve the error "The local variable may not have been instantiated"?
    ... maybe it has to do with settings of compiler. ... I know regards to warnings, user can make selections so that somethings are considered as warnings, some not. ... real program, after myClass object was created, the object was used several times. ... that has an initial value in its declaration, ...
    (comp.lang.java.programmer)
  • Re: problem using self built DLL
    ... called MyClass, AND YOU HAVE SAID NOTHING MORE ABOUT IT! ... declaration, wherein you promise to say something later. ... specify the library file in linker. ... MyClass has no member function or member ...
    (microsoft.public.vc.mfc)