我的一点关于把WndProc指向类的成员函数的看法

  我以前经常考虑使用WNDCLASS、CreateThread之类的Windows API时如何在类里面调用,传入函数参数地址时如何使用成员函数的地址。为了研究,写了一个示例代码:

#include <iostream>
#include <stdio.h>

using namespace std;

typedef int (__stdcall *XSSH_SAY_HELLO)(int);

class XTestMethod
{
	typedef int (__stdcall XTestMethod::*XSayHello)(int);
public:
	XSayHello say;
	int hi;
public:
	XTestMethod();
	virtual ~XTestMethod();
	int sayhello(int arg);
};

XTestMethod::XTestMethod()
{
	say=&XTestMethod::sayhello;
	hi=1000;
}

XTestMethod::~XTestMethod()
{

}

int XTestMethod::sayhello(int arg)
{
	printf("\r\nsay:%d%d\r\n",arg,this->hi);
}

int main(int argc, char *argv[])
{
	XTestMethod t;
	XSSH_SAY_HELLO call=*(XSSH_SAY_HELLO*)&t.say;
	call(0);
	system("pause");
	return 0;
}

  调试的时候发现在调用类的成员之前堆栈里的this指针是空的,输入之后输出结果的值前者是随机的,后者直接访问出错(空引用)。

  对于成员函数与成员变量而言,同一类型的不同对象的同一成员变量的偏移地址是相同的,访问成员变量时它们的地址是基于对象的地址叠加计算的,如果用上述方法进入成员函数进而方问成员变量,那么访问出错。就算在访问成员变量之前把对象指针压入堆栈,不仅要考虑压入哪个对象的地址,而且这样使用成员函数实际上把它当成了全局函数来用,与静态成员函数使用在使用目的上没有区别,失去了面象对象的意义。

我的一点关于把WndProc指向类的成员函数的看法

时间: 2024-08-24 21:53:20

我的一点关于把WndProc指向类的成员函数的看法的相关文章

如何使用指向类的成员函数的指针(详解!)

我们首先复习一下"指向函数的指针"如何使用? [cpp] view plain copy print? void print() { } void (*pfun)(); //声明一个指向函数的指针,函数的参数是 void,函数的返回值是 void pfun = print;   //赋值一个指向函数的指针 (*pfun)();    //使用一个指向函数的指针 比较简单,不是吗?为什么*pfun需要用()扩起来呢? 因为*的运算符优先级比()低,如果不用()就成了*(pfun()).

c++: 指向类成员函数的指针

指向函数的指针有和指向类成员函数的指针的有什么不同? int f(char a, float b);如果它是普通函数,则它的类型是 int (*)(char, float);如果它是非静态成员函数,则它的类型是 int(ClassName::*)(char, float);如果它是静态成员函数,则它的类型是和普通函数一样. 如何把一个类的成员函数传递给event handler, 线程启动函数等? 类的成员函数必须和一个类的实例结合起来才有意义.可以写一个函数来包装类的成员函数. class X

指向类成员函数的指针

//类中的普通成员变量,类名::变量名,在栈上 //类名 *指针名=new 类名,在堆上 //类的静态成员变量,在静态区 //函数都在代码区,类的函数.静态函数都是共享的 void(myclass::*p1)() = myclass::run;//指向类成员函数的指针 void(*p2)() = myclass::go;//指向静态成员函数的指针 1 #include <iostream> 2 3 class myclass 4 { 5 public: 6 int num; 7 int dat

c++ 指向类成员函数的函数指针

// ConsoleApplication34.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> using namespace std; class Parent { public: Parent() { //cout << "我是爹" << endl; } virtual void print() { cout << "我是爹&

指向类成员的指针

c++语言中,可以说明指向类的数据成员的指针和指向类的成员函数的指针. 这两种指针必须与对象或指向对象的指针结合使用. 1.指向类的数据成员的指针定义格式为: 类型名 类名:: *指针; 这种说明不是说指针属于类的,而是说明指针只能指向指定类的指定类型的成员. 2.指向类的成员函数的指针 类型名 (类名:: *指针)(参数表); 同样的道理,函数指针并不属于类,而是只能指向类的指定原型的函数. #include<iostream.h> class A {public: int a; int b

c++对象模型是什么,对象的内存布局和结构问题

在c++发明的初期对于c++对象模型的争论从来没有停止过直到标准委员会通过了最终的c++对象模型这件事情才变得尘埃落定.C++对象模型可能是最不需要去解释的,但是又是不得不去说的因为c++的入门最先接触的就是c++对象.在上个世纪一共有三种c++对象模型,它们的出现可以说是一个不断优化的过程最终只有我们目前看到的c++对象模型在使用.了解c++对象模型非常重要,了解之后对于对象的内存布局,内存大小,虚函数以及静态数据成员和成员函数的理解有非常巨大的帮助.言归正传,下面就来分别讨论c++的三种对象

&lt;转&gt;C++继承中虚函数的使用

转自:http://blog.csdn.net/itolfn/article/details/7412364 一:继承中的指针问题. 1. 指向基类的指针可以指向派生类对象,当基类指针指向派生类对象时,这种指针只能访问派生对象从基类继承 而来的那些成员,不能访问子类特有的元素 ,除非应用强类型转换,例如有基类B和从B派生的子类D,则B *p;D  dd; p=&dd;是可以的,指针p只能访问从基类派生而来的成员,不能访问派生类D特有的成员.因为基类不 知道派生类中的这些成员. 2. 不能使派生类

C/C++面试题目一

C/C++开发工程师面试题目(一)(附答案分析) 推荐:自己根据在面试中碰到做过的一些题目以及总结的题目,希望对面试的同学有所帮助. 一. 选择题 1. 下列类中(  )不是输入输出流类iostream的派生类. A. fstream      B. ofstream     C. strstream    D. ostrstream 答案:BD 解析:ofstream和ostrstream派生自ostream,而不是iostream.                              

恼人的函数指针(二)

原文链接:http://www.cnblogs.com/AnnieKim/archive/2011/12/04/2275589.html 前面曾写过一篇恼人的函数指针(一),总结了普通函数指针的声明.定义以及调用,还有函数指针数组,函数指针用作返回值等.但是作为C++的研读,我发现我漏掉了一个最重要的内容,就是指向类成员的指针,这里将做相应补充(相关代码测试环境为vs 2010). 指向类成员的指针总的来讲可以分为两大类四小类(指向数据成员还是成员函数,指向普通成员还是静态成员),下面一一做介绍