Re: Frasncis Glassboro wrote.
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
On 01/07/2011 08:55 PM, Paul wrote:
"Garrett Hartshaw" <ghartshaw@gmail.com> wrote in message
news:ig855p$ec1$1@speranza.aioe.org...
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
On 01/07/2011 02:06 PM, Paul wrote:
"James Kanze" <james.kanze@gmail.com> wrote in message
news:7148a492-1586-4421-bc6c-4afa38770f53@w29g2000vba.googlegroups.com...
On Jan 7, 2:07 pm, "Paul" <pchris...@yahoo.co.uk> wrote:
"James Kanze" <james.ka...@gmail.com> wrote in message
[...]
I can understand the concept you express but
a) how do you get the address of a member function?
&ClassName::functionName
Concretely:
struct C { void f(); };
void (C::*pf)() = &C::f;
b) what happens if this member function is virtual?
It works correctly. That's why pointer to member functions are
often larger than any other pointer types (but there are other
ways of solving the problem).
What would your pointer point to ?
That's the compiler writers problem, not mine:-).
It certainly is a problem for the compiler, and perhaps the program too.
Especially if you didn't initialised the empty pointer.
Let me put it another way, where would you get the address for the
virtual function?
You cannot do this with virtual functions and you are wrong
to suggest it works correctly.
It does work, and I've done it. More than once.
It simply can't be done as the concept of virtual functions only lives
in the world of objects.
Please show some basic code. I guarantee you cannot.
#include <iostream>
class C1 {
public:
virtual void f() {
std::cout << "C1::f" << std::endl;
}
};
class C2 : public C1 {
public:
virtual void f() {
std::cout << "C2::f" << std::endl;
}
};
int main () {
void (C1::*p)() = &C1::f; //create a pointer to a member function
C1 a; //create a object of type C1
C1 * b; //create a object of type pointer to C1
The challenge put forward was to invoke a virtual function without
creating an object. Here you have created an object.
I applaud your abilities nonetheless, assuming the code is correct.
b = new C2(); //allocate a object of type C2
(a.*p)(); //call the member function pointed to
//by p, with &a as this
(b->*p)(); //call the member function pointed to
//by p (virtually), with b as this
return 0;
}
This code prints the following.
C1::f
C2::f
The very nature of virtual functions require objects and perhaps you
have demostrated this.
This was what i was referring when I initially stated 'it won't work
with virtual functions':
"You can take the address of a member function (and assign it to a
function pointer of the proper type), and it will *not* be tied to any
specific object."
The (virtual) member function was *not* tied to a specific object, as it
(the same function) was used by two different objects. If it was *a part
of* the object, you would not be able to have a pointer to it.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.16 (GNU/Linux)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org/
iQIcBAEBAgAGBQJNJ9I/AAoJEO0SzzQOdchNNt8QAIt7B8Hfsc+2iYiN1wanHNxQ
2rWmra66snapd+37ZO3efBkuaBEpggJrwiGYr7zmRV6+kmGSff0f5HoITBQxv0wP
IR9AahmQdD0bBRDpMXFM+W2TW/2BFCIfYxxNkHe7PZaiKYOhSCBsIcOEH7kc87YZ
dOYVtdEYQrLVyBF+cJhIZgCt8zfbhMUi24c0qwrdsC/ZLdTmWfPqnCRKgUw5bcuy
3UPygLpq+9LEsUUzW/VpG/CnNGj6Ftke+2xXVJFcJsEtb8YWQLHJEy0F3xqRperP
HBN5Bt1kiLN/NBmy9d+3nUsvBf5T6PHGtoPvgABIOORD2uUD+8Nk1bpKqHvYN6O8
pXRUdnkdRhiAPpjNKpAQ9ofcnkwbHbyq5+clEPCdf734vuea2aK+Llt8rLFcEqsC
w5NDbrQ5/4lFxQPRushBZqxDaSgCW33w+YEtBmrQIx8BYC63Dx6sDPKyQBfgBZDj
xr/Os/y1zPVFQS3waG5a+GO2bsduUqFBVNNkoFmvvIqeXoES/hUTrkfmD6T8UasY
dSbwihNm+QL8Tx/iNQ95KwWC5C6XrOrgXfR23DwbQOtw6Sehzcx7pldE/O9F4GAF
a98GPBZd1gat4m6ON+oj68yOudXJurjjDEb+s2DQHgwHgasIld1LMoy+IbXtBosT
twwDeuyGBgd0PRLaOi7e
=d+WZ
-----END PGP SIGNATURE-----