【zz】将成员函数指针强制转换成void指针

本文详细介绍了如何使用成员函数指针及其转换技术,通过将成员函数指针强制转换为不同类型的指针,从而实现对类中成员函数的灵活调用。通过实例演示了获取成员函数地址的方法,并验证了转换后的指针的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

采用取成员函数指针的地址的方法,先把指向成员函数指针的指针强制转化为别的类型,如unsigned*,当然同样可以通过此转化后的指针经过相反的变换来调用成员函数。于是乎要转化为void*的问题也随之可解,如下示例:

 

/* VS2003下编译运行 */

class AbstractMethod

{

public:

 virtual void show(){}  // = 0;  // 可以是纯虚函数,这里为了测试方便不使用纯虚函数!

 void fun()

 {

  cout << "I was called!" << endl;

 }

 

 void fun1()

 {

  cout << "I was called!" << endl;

 }

};

 

int main()

{

 // 定义成员函数指针类型

 typedef void (AbstractMethod::*MFP)(void);

 

 // 转化函数指针为别的指针

 MFP mfp1 = &AbstractMethod::show;  

 unsigned* tmp =  (unsigned*)&mfp1;

 cout << hex << *tmp << endl;

 

 MFP mfp2 = &AbstractMethod::fun;

 tmp = (unsigned*)&mfp2;

 cout << hex << *tmp << endl;

 

 MFP mfp3 = &AbstractMethod::fun1;

 tmp = (unsigned*)&mfp3;

 cout << hex << *tmp << endl;

 

 // 通过转化后的指针调用成员函数

 AbstractMethod am;

 MFP* addr = (MFP*)tmp;

 (am.*mfp3)();

 (am.*(*addr))();

 

 return 0;

}

 

    验证上述方法取得的成员函数地址是否正确:

    1. 在调试是查看临时变量函数指针的值和输出的是否一样。

    2. 可以根据调试时的反汇编进行结果验证。

    3. 最好的办法就是如上例子通过转化后的指针来调用成员函数。

 

补全代码 先来先服务进程调度算法 运行环境: Dev c++ 算法思想:  先来先服务进程 (FCFS)调度算法则是从当前就绪队列中选出一个最先来的进程,将处理机分配给它,使它立即执行并一直执行到完成 核心数据结构: typedef struct data{ int hour; int min; }time; typedef struct node{ int id;//编号 char name[20];//名字 time arrive;//到达间 int zx;//执行间; time start;//开始间 time finish;//完成间 int zz;//周转间=执行完成间-到达就绪队列间 double zzxs;//带权周转间=周转间/执行间 struct node* next; }linknode; typedef linknode* linklist; typedef struct{ linklist front; linklist rear; }queue; //队列 程序主体框架: //函数名:init 参数:无 queue* init(){ //函数功能:初始化队列,返回队列指针 } //函数名:insert 参数:Queue *cc, node *x void enqueue(queue* cc,linklist s){ //函数功能:尾插入队 } //函数名:dele 参数:Queue *cc void dequeue (queue* cc){ //功能:队首结点出队 } //函数名:input 参数:Queue *cc void input(queue* cc){ //功能:实现作业队列的输入 } //函数名:sort参数:Queue *cc void sort(queue* cc){ //函数功能:对到达间进行排序 } //函数名:solve_FCFS参数:Queue *cc void solve_FCFS(queue* cc){ //函数功能:实现先来先服务调度算法 } int main() { while(true) { int op; printf("请输入操作(1:开始进程调度;0:结束进程)"); scanf("%d",&op); if(op==0) break; queue *cc; linklist ll; cc = init(cc); input(cc); ll=sort(cc); enqueuer(cc,ll) solve_FCFS(cc); } return 0; } 测试用例1: 5001 p1 9:40 20 5004 p4 10:10 10 5005 p5 10:05 30 5002 p2 9:55 15 5003 p3 9:45 25 测试用例2: 5001 p1 19:40 20 5002 p4 10:10 10 5003 p5 10:05 30 5004 p2 9:55 15 5005 p3 9:45 25 5006 p6 11:40 20 5007 p8 12:10 10 5008 p9 13:05 30 5009 p10 19:55 15 5010 p7 7:15 15
最新发布
04-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值