ZC_C++类函数指针_模拟_Delphi类函数指针_Qt例子
qt-opensource-windows-x86-msvc2010_opengl-5.3.2.exe
ZC: “const QString” 作传入参数的时候,不太会弄... 貌似 还是在进行构建等的操作,按照暂时的水平这种情况还不太会弄... 于是 用“QString&”或“QString*”作参数
ZC: Qt调试 比较麻烦,还是使用 VS2010 来调试 看汇编的...
1、mainwindows.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h" MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
} MainWindow::~MainWindow()
{
delete ui;
} #include <QDebug>
#include "TClassFuncPtr.h" void MainWindow::on_pbtnTest01_clicked()
{
//*
CTest test; void *pFunc = pointer_cast<void*>(&CTest::GetString); Tcfp_Qs_II cfp;
cfp.Set(&test, pFunc);
QString str = cfp.Call(, );
qDebug() << str;
//*/
/*
CTest test;
QString str = test.GetString(1, 3);
//*/
} void MainWindow::on_pbtnTest02_clicked()
{
QString str = "";
//*
CTest test; void *pFunc = pointer_cast<void*>(&CTest::GetIntFromString); Tcfp_I_CQs cfp;
cfp.Set(&test, pFunc);
int iRtn = cfp.Call(str);
qDebug() << str;
//*/
/*
CTest test;
int iRtn = test.GetIntFromString(str);
qDebug() << iRtn;
//*/
} void MainWindow::on_pbtnTest03_clicked()
{
QString str = "";
//*
CTest test; void *pFunc = pointer_cast<void*>(&CTest::GetIntFromString01); Tcfp_I_Qs cfp;
cfp.Set(&test, pFunc);
int iRtn = cfp.Call(str);
qDebug() << iRtn;
} void MainWindow::on_pbtnTest04_clicked()
{
QString str = "";
//*
CTest test; void *pFunc = pointer_cast<void*>(&CTest::GetIntFromString02); Tcfp_I_Qsp cfp;
cfp.Set(&test, pFunc);
int iRtn = cfp.Call(&str);
qDebug() << iRtn;
}
2、TClassFuncPtr.h
#ifndef TCLASSFUNCPTR_H
#define TCLASSFUNCPTR_H #include <QString> // ZC: 子类 命名规则:“Tcfp_返回值类型_各个传入参数类型()” class TClassFuncPtr
{
public:
TClassFuncPtr()
{
FpObj = NULL;
FpFunc = NULL;
} protected:
void* FpObj; // ZC: 对象指针
void* FpFunc; // ZC: 类函数的 函数地址(统一使用stdcall调用约定,函数传参/调用的时候 方便一点) public:
void Set(void *_pObj, void *_pFunc)
{
FpObj = _pObj;
FpFunc = _pFunc;
} bool IsValid()
{
return ( (FpObj != NULL) && (FpFunc != NULL) );
}
}; class Tcfp_Qs_II :public TClassFuncPtr
{
public:
QString __stdcall Call(int _i, int _j);
}; class Tcfp_I_CQs :public TClassFuncPtr
{
public:
int __stdcall Call(const QString _str);
}; class Tcfp_I_Qs :public TClassFuncPtr
{
public:
int __stdcall Call(QString &_str);
}; class Tcfp_I_Qsp :public TClassFuncPtr
{
public:
int __stdcall Call(QString *_pstr);
}; // ZC: 获取 类函数指针(地址)
template<typename dst_type,typename src_type>
dst_type pointer_cast(src_type src)
{
return *static_cast<dst_type*>(static_cast<void*>(&src));
}
#endif // TCLASSFUNCPTR_H class CTest
{
private:
int Fi;
public:
QString __stdcall GetString(int _i, int _j); int __stdcall GetIntFromString(const QString _str);
int __stdcall GetIntFromString01(QString &_str);
int __stdcall GetIntFromString02(QString *_pstr);
};
3、TClassFuncPtr.cpp
#include "TClassFuncPtr.h" #pragma optimize( "", off )
QString __stdcall Tcfp_Qs_II::Call(int _i, int _j)
{
if (IsValid())
{
_asm
{
push _j
push _i
mov eax,dword ptr [ebp+0xC]
push eax
mov eax,[this] // ZC: 貌似和语句“mov eax,this”是一样的效果...
// [eax] ==> FpObj
// [eax+4] ==> FpFunc
push [eax]
call [eax+]
}
}
} int __stdcall Tcfp_I_CQs::Call(const QString _str)
{
if (IsValid())
{
void *p = (void*)&_str;
_asm
{
push p
mov eax,[this] // ZC: 貌似和语句“mov eax,this”是一样的效果...
// [eax] ==> FpObj
// [eax+4] ==> FpFunc
push [eax]
call [eax+]
}
}
} int __stdcall Tcfp_I_Qs::Call(QString &_str)
{
if (IsValid())
{
_asm
{
mov eax,[ebp+0xC]
push eax
mov eax,[this] // ZC: 貌似和语句“mov eax,this”是一样的效果...
// [eax] ==> FpObj
// [eax+4] ==> FpFunc
push [eax]
call [eax+]
}
}
} int __stdcall Tcfp_I_Qsp::Call(QString *_pstr)
{
if (IsValid())
{
_asm
{
mov eax,[ebp+0xC]
push eax
mov eax,[this] // ZC: 貌似和语句“mov eax,this”是一样的效果...
// [eax] ==> FpObj
// [eax+4] ==> FpFunc
push [eax]
call [eax+]
}
}
} //#pragma optimize( "", on ) //#pragma optimize( "", off )
QString __stdcall CTest::GetString(int _i, int _j)
{
__asm
{
mov eax,eax
mov eax,eax
mov eax,eax
}
Fi = ;
return ( QString::number(_i)+","+QString::number(_j)+","+QString::number(Fi) );
} int __stdcall CTest::GetIntFromString(const QString _str)
{
return _str.toInt();
} int __stdcall CTest::GetIntFromString01(QString &_str)
{
return _str.toInt();
} int __stdcall CTest::GetIntFromString02(QString *_pstr)
{
return (*_pstr).toInt();
} #pragma optimize( "", on )
4、mainwindow.ui
4.1、
4.2、
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>MainWindow</class>
<widget class="QMainWindow" name="MainWindow">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>400</width>
<height>300</height>
</rect>
</property>
<property name="windowTitle">
<string>MainWindow</string>
</property>
<widget class="QWidget" name="centralWidget">
<widget class="QPushButton" name="pbtnTest01">
<property name="geometry">
<rect>
<x>50</x>
<y>40</y>
<width>75</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Test01</string>
</property>
</widget>
<widget class="QPushButton" name="pbtnTest02">
<property name="geometry">
<rect>
<x>50</x>
<y>70</y>
<width>75</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Test02</string>
</property>
</widget>
<widget class="QPushButton" name="pbtnTest03">
<property name="geometry">
<rect>
<x>50</x>
<y>100</y>
<width>75</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Test03</string>
</property>
</widget>
<widget class="QPushButton" name="pbtnTest04">
<property name="geometry">
<rect>
<x>50</x>
<y>130</y>
<width>75</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Test04</string>
</property>
</widget>
</widget>
<widget class="QMenuBar" name="menuBar">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>400</width>
<height>17</height>
</rect>
</property>
</widget>
<widget class="QToolBar" name="mainToolBar">
<attribute name="toolBarArea">
<enum>TopToolBarArea</enum>
</attribute>
<attribute name="toolBarBreak">
<bool>false</bool>
</attribute>
</widget>
<widget class="QStatusBar" name="statusBar"/>
</widget>
<layoutdefault spacing="6" margin="11"/>
<resources/>
<connections/>
</ui>
5、
ZC_C++类函数指针_模拟_Delphi类函数指针_Qt例子的更多相关文章
- ZC_C++类函数指针_模拟_Delphi类函数指针
ZC: C++的类函数指针 不像 Delphi的类函数指针,前者 需要规定死 是哪个类的函数的指针,后者就不需要 很灵活. 测试环境: Win7x64 cn_visual_studio_2010_ul ...
- C++第四篇--重载_指针_引用
C++第四篇--重载_指针_引用 1. 基础知识 重载:函数名相同,根据参数不同(类型.数量.顺序不同)调用同名函数 指针和引用:引用就是别名,引用时必须初始化,引用你定义的变量. int a; in ...
- ca71a_c++_指向函数的指针_通过指针调用函数txwtech
/*ca71a_c++_指向函数的指针_通过指针调用函数用typedef简化函数指针的定义简化前: bool(*pf)(const string&, const string &); ...
- c语言中较常见的由内存分配引起的错误_内存越界_内存未初始化_内存太小_结构体隐含指针
1.指针没有指向一块合法的内存 定义了指针变量,但是没有为指针分配内存,即指针没有指向一块合法的内浅显的例子就不举了,这里举几个比较隐蔽的例子. 1.1结构体成员指针未初始化 struct stude ...
- C语言_初步了解一下指针
指针的基本概念 在计算机中,所有的数据都是存放在存储器中的. 一般把存储器中的一个字节称为一个内存单元, 不同的数据类型所占用的内存单元数不等,如整型量占2个单元,字符量占1个单元等.为了正确地访问这 ...
- 零基础逆向工程24_C++_01_类_this指针_继承本质_多层继承
1 类内的成员函数和普通函数的对比 1.1 主要是从参数传递.压栈顺序.堆栈平衡来总结. 1.参数传递:成员函数多传一个this指针 2.压栈顺序:成员函数会将this指针压栈,在函数调用取出 3.堆 ...
- 【c实现,vc6调试通过】给出一字符串指针,计算出字符串指针中单词数
#include <stdio.h> /* 给出一字符串指针,计算出字符串指针中单词数, 单词不包括'.',',',';','?','_','"',由0-9数字或26个字母组成 ...
- Qt 智能指针学习(7种指针)
Qt 智能指针学习 转载自:http://blog.csdn.net/dbzhang800/article/details/6403285 从内存泄露开始? 很简单的入门程序,应该比较熟悉吧 ^_^ ...
- 不可或缺 Windows Native (18) - C++: this 指针, 对象数组, 对象和指针, const 对象, const 指针和指向 const 对象的指针, const 对象的引用
[源码下载] 不可或缺 Windows Native (18) - C++: this 指针, 对象数组, 对象和指针, const 对象, const 指针和指向 const 对象的指针, con ...
随机推荐
- 浅谈Android View的定位
引言 今天我们来介绍Android坐标系统和View的定位,当然也会介绍View的滑动相关话题.下面让我们开始介绍吧. View的基础知识 View是Android中所有控件的基类,无论是TextVi ...
- 问题排查之'org.apache.rocketmq.spring.starter.core.RocketMQTemplate' that could not be found.- Bean method 'rocketMQTemplate' in 'RocketMQAutoConfiguration' not loaded.
背景 今天将一个SpringBoot项目的配置参数从原有的.yml文件迁移到Apollo后,启动报错“Bean method 'rocketMQTemplate' in 'RocketMQAutoCo ...
- windows系统和进程内存基础知识
- 用python实现一个简单的socket网络聊天通讯 (Linux --py2.7平台与windows--py3.6平台)
windows --> windows 写法均在py3.6 客户端写法 import socket client = socket.socket() client.connect(('192 ...
- python 命令执行文件传递参数
import os,sys for root,dirs,files in os.walk(sys.argv[1]): for name in files: print(os.path.join(roo ...
- 【百度统计】设置页面元素点击事件转化pv、uv
html元素点击事件内添加代码:_hmt.push(['_trackEvent', category, action, opt_label, opt_value]); 1. '_trackEvent' ...
- LLVM/Clang编译相关研究
https://blog.csdn.net/guojin08/article/details/54310858 https://juejin.im/entry/5c64da44518825620b45 ...
- Django框架----Web框架本质
Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...
- python之路----面向对象进阶一
一.isinstance和issubclass isinstance(obj,cls)检查是否obj是否是类 cls 的对象 class Foo(object): pass obj = Foo() i ...
- Js/html格式化在线工具
Js/html格式化在线工具 Js/html格式化在线工具:http://tool.chinaz.com/Tools/jsformat.aspx