模板template和宏定义define一起的例子
来源:互联网 发布:本科做网络维护 编辑:程序博客网 时间:2024/06/06 00:59
#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 所对应的函数的调用。
- 模板template和宏定义define一起的例子
- 模板类的申明和定义为什么要放一起
- 模板类的定义和声明为何要写在一起
- 模板的声明和定义一般放一起
- #define宏定义的优点和缺点
- const和#define宏定义的区别
- template模板的声明及定义
- define宏定义和const常量定义之间的区别
- define宏定义和const常量定义之间的区别
- define宏定义和const常量定义之间的区别
- define宏定义和const常量定义之间的区别
- define宏定义和const常量定义之间的区别
- define宏定义和const定义之间的区别
- define宏定义和const常量定义之间的区别
- 【define宏定义和const常量定义之间的区别】
- define宏定义和const定义之间的区别
- 宏定义(const)和常量定义(#define)的区别
- define宏定义和const常量定义之间的区别
- gnuplot画图
- oracle11g的七个服务
- spark架构总结
- linux中的一条重要命令:find
- Linux Qt编程-在程序中启动其他应用、脚本
- 模板template和宏定义define一起的例子
- JZOJ 5050. 【GDOI2017模拟一试4.11】颜色树
- 微信群管理机器人
- java设计模式——适配器模式二
- JQuery选中select组件被选中的值
- 从linux进程机制到TopwiseProp的分析
- C++ windows API获取驱动器根路径和属性(-)
- 获取CheckBoxList当前选择项
- 2017-4-22:实用类总结