模板template和宏定义define一起的例子

本文探讨了C++中模板template与宏定义#define的结合使用,以`HEAP_MEM_PTR`为例,解释了其在类`CBaseImg`中的应用。同时,文章通过举例介绍了不同类型的指针声明,并解析了一个复杂的函数指针调用表达式`(*(void (*)())0)()`,帮助理解函数指针的用法和强制类型转换。

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

#define HEAP_MEM_PTR(a) a*

template<typename T> class CBaseImg

{

    /* ………………*/

     HEAP_MEM_PTR(T)* m_ppColPointer;  //这是啥啊???直接懵逼了好不好??????

   /* ………………*/

}


通过上两篇其实就是 T**  m_ppColPointer;//T就把它当普通类型变量就好了,这接下来就是指针的问题了

以下转载的地址

http://www.cnblogs.com/xufeiyang/archive/2011/11/05/2237070.html

1.int *p;

2.int **p;

3.int *p[10];

4.int (*p)[10];

5.int *p(int);

6.int (*p)(int);

7.int (*p[10])(int);

这七个难度还不是很大,相信大多数读者都能够答的出来。

答案:

1.一个指向整型数据的指针

2.一个指针的指针,它指向的指针指向一个整型数据

3.一个有十个指针的数组,该指针指向整型数据

4.一个指向有十个整型数据数组的指针

5.就一个函数(不是函数指针),该函数有一个整型参数,返回值为一个指向整型的指针

6.一个函数指针,该函数有一个整型的参数,返回值为整型类型

7.一个有十个指针的数组,该数组中的指针指向一个函数,该函数有一个整型参数并返回一个整型数

题目是这样的:

请解析 (*(void (*)())0)() 的含义。

分析问题:

有些微处理器从0地址启动,有时为了模拟开机时的情形,需要设计一条C 语句,去执行0地址的内容,于是就有了(*(void (*)())0)() 这条语句。

这条语句一眼看上去让人头疼,但分析之后还是挺简单的。

首先,当有如下函数声明时:

void fun(param);

这个函数的调用形式为:fun(param);

题目的函数没有参数,所以就简化成fun();

而0是这个函数的入口地址,即0就是这个函数的指针值,指针的函数声明为:

void (*pFun)(param);

调用形式为:(*pFun)(param);

对于本题可以写成:( *0 ) ();

但是函数指针变量不能是个常数,所以还要把0强制转换成函数指针,根据原题可以元函数的函数指针原型为 void (*)();

于是(*(void (*)())0)()可以这样来分析,首先用void (*)()把0强制转换成了函数指针,然后再调用函数指针0所指向的函数。

可以用typedef来加深对本句的理解,如下:

typedef void (*pFun)();

((*pFun)0)();

这两句和(*(void (*)())0)()是等价的,但是这样更有助于加深对本句的理解。

总结:(*(void (*)())0)()就是 *(void (*)())0 所对应的函数的调用。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值