enum可以做索引
enum可以做索引
enum可以做索引, 配上虚函数,或者函数指针,可以实现上层的统一封装和快速索引。
点击(此处)折叠或打开
- MoTbl.cpp
- #include <stdio.h>
- #include <stdlib.h>
- enum {
- eA=0,
- eB,
- eC,
- eD,
- eMax
- };
- class Bs{
- public:
- virtual void say(){ printf("Bs\n"); }
- };
- class A: public Bs{
- int aa[1];
- public:
- void say(){printf("A\n");}
- void call(){printf("A::call\n");}
- };
- class B: public Bs{
- int aa[3];
- public:
- void say(){printf("B\n");}
- void sing(){printf("B::sing\n");}
- };
- class C: public Bs{
- int aa[10];
- public:
- void say(){printf("C\n");}
- };
- class D: public Bs{
- int aa[100];
- public:
- void say(){printf("D\n");}
- };
- class MoTbl{
- public:
- union{
- struct{
- A *a;
- B *b;
- C *c;
- D *d;
- }t;
- void *tv[eMax];
- };
- };
- int
- main ( int argc, char *argv[] )
- {
- int i = 0;
- MoTbl mt;
- A a;
- B b;
- C c;
- D d;
- printf("A:%d\n",sizeof(MoTbl));
- for(i=0; i<eMax; i++)
- printf("%p\n",mt.tv[i]);
- printf("--------------\n");
- mt.tv[eA] = &a;
- mt.tv[eB] = &b;
- mt.tv[eC] = &c;
- mt.tv[eD] = &d;
- for(i=0; i<eMax; i++)
- printf("%p\n",mt.tv[i]);
- printf("--------------\n");
- mt.t.a->say();
- printf("--------------\n");
- for(i=0; i<eMax; i++){
- switch(i){enum 做索引 2012-10-11 18:17:14
分类: C/C++
enum可以做索引, 配上虚函数,或者函数指针,可以实现上层的统一封装和快速索引。
点击(此处)折叠或打开
- MoTbl.cpp
- #include <stdio.h>
- #include <stdlib.h>
- enum {
- eA=0,
- eB,
- eC,
- eD,
- eMax
- };
- class Bs{
- public:
- virtual void say(){ printf("Bs\n"); }
- };
- class A: public Bs{
- int aa[1];
- public:
- void say(){printf("A\n");}
- void call(){printf("A::call\n");}
- };
- class B: public Bs{
- int aa[3];
- public:
- void say(){printf("B\n");}
- void sing(){printf("B::sing\n");}
- };
- class C: public Bs{
- int aa[10];
- public:
- void say(){printf("C\n");}
- };
- class D: public Bs{
- int aa[100];
- public:
- void say(){printf("D\n");}
- };
- class MoTbl{
- public:
- union{
- struct{
- A *a;
- B *b;
- C *c;
- D *d;
- }t;
- void *tv[eMax];
- };
- };
- int
- main ( int argc, char *argv[] )
- {
- int i = 0;
- MoTbl mt;
- A a;
- B b;
- C c;
- D d;
- printf("A:%d\n",sizeof(MoTbl));
- for(i=0; i<eMax; i++)
- printf("%p\n",mt.tv[i]);
- printf("--------------\n");
- mt.tv[eA] = &a;
- mt.tv[eB] = &b;
- mt.tv[eC] = &c;
- mt.tv[eD] = &d;
- for(i=0; i<eMax; i++)
- printf("%p\n",mt.tv[i]);
- printf("--------------\n");
- mt.t.a->say();
- printf("--------------\n");
- for(i=0; i<eMax; i++){
- switch(i){
- case eA: mt.t.a->say(); break;
- case eB: mt.t.b->say(); break;
- case eC: mt.t.c->say(); break;
- case eD: mt.t.d->say(); break;
- }
- }
- printf("--------------\n");
- for(i=0; i<eMax; i++)
- ((Bs *)mt.tv[i])->say();
- printf("--------------\n");
- for(i=0; i<eMax; i++){
- switch(i){
- case eA: mt.t.a->call(); break;
- case eB: mt.t.b->sing(); break;
- }
- }
- printf("--------------\n");
- }
输出
点击(此处)折叠或打开
- A:16
- 0xb7726ff4
- 0xb77238e4
- (nil)
- 0xb7615ff4
- --------------
- 0xbff0cd98
- 0xbff0cd88
- 0xbff0cd5c
- 0xbff0cbc8
- --------------
- A
- --------------
- A
- B
- C
- D
- --------------
- A
- B
- C
- D
- --------------
- A::call
- B::sing
- --------------
- case eA: mt.t.a->say(); break;
- case eB: mt.t.b->say(); break;
- case eC: mt.t.c->say(); break;
- case eD: mt.t.d->say(); break;
- }
- }
- printf("--------------\n");
- for(i=0; i<eMax; i++)
- ((Bs *)mt.tv[i])->say();
- printf("--------------\n");
- for(i=0; i<eMax; i++){
- switch(i){
- case eA: mt.t.a->call(); break;
- case eB: mt.t.b->sing(); break;
- }
- }
- printf("--------------\n");
- }
输出
点击(此处)折叠或打开
- A:16
- 0xb7726ff4
- 0xb77238e4
- (nil)
- 0xb7615ff4
- --------------
- 0xbff0cd98
- 0xbff0cd88
- 0xbff0cd5c
- 0xbff0cbc8
- --------------
- A
- --------------
- A
- B
- C
- D
- --------------
- A
- B
- C
- D
- --------------
- A::call
- B::sing
- --------------
enum可以做索引的更多相关文章
- redis为何单线程 效率还这么高 为何使用跳表不使用B+树做索引(阿里)
如果想了解 redis 与Memcache的区别参考:Redis和Memcache的区别总结 阿里的面试官问问我为何redis 使用跳表做索引,却不是用B+树做索引 因为B+树的原理是 叶子节点存储数 ...
- python中list不能做索引
先看python中内置的list不能作为字典的key. 可将list或者ndarray转化为tuple再做索引. list不能进行hash: import numpy as np a1 = np.ar ...
- 2020-05-18:MYSQL为什么用B+树做索引结构?平时过程中怎么加的索引?
福哥答案2020-05-18:此答案来自群员:因为4.0成型那个年代,B树体系大量用于文件存储系统,甚至当年的Longhorn的winFS都是基于b树做索引,开源而且好用的也就这么个体系了.B+树的磁 ...
- MySQL用B+树(而不是B树)做索引的原因
众所周知,MySQL的索引使用了B+树的数据结构.那么为什么不用B树呢? 先看一下B树和B+树的区别. B树 维基百科对B树的定义为"在计算机科学中,B树(B-tree)是一种树状数据结构, ...
- 为什么Mysql用B+树做索引而不用B-树或红黑树
B+树做索引而不用B-树 那么Mysql如何衡量查询效率呢?– 磁盘IO次数. 一般来说索引非常大,尤其是关系性数据库这种数据量大的索引能达到亿级别,所以为了减少内存的占用,索引也会被存储在磁盘上. ...
- 用xapian来做索引
最近一个项目需要正则搜索MongoDB,400多万的数据一次查询要20s以上,需要建立一个前端索引服务.本着部署简单.开发容易的原则,找到了xapian这个索引库. 我使用的是Python的接口,xa ...
- 为什么用B+树做索引&MySQL存储引擎简介
索引的数据结构 为什么不是二叉树,红黑树什么的呢? 首先,一般来说,索引本身也很大,不可能全部存在内存中,因此索引往往以索引文件的方式存在磁盘上.然后一般一个结点一个磁盘块,也就是读一个结点要进行一次 ...
- MySQL用B+树做索引
索引这个词,相信大多数人已经相当熟悉了,很多人都知道MySQL的索引主要以B+树为主,但是要问到为什么用B+树,恐怕很少有人能把前因后果讲述的很完整.本文就来从头到尾介绍下数据库的索引. 索引是一种数 ...
- mysql为什么用b+树做索引
关键字就是key的意思 一.B-Tree的性质 1.定义任意非叶子结点最多只有M个儿子,且M>2: 2.根结点的儿子数为[2, M]: 3.除根结点以外的非叶子结点的儿子数为[M/2, M]: ...
随机推荐
- 02-IOSCore - NSFileHandle、合并文件、文件指针、文件查看器
[day0201_NSFileHandle]:文件句柄 1 NSFileHandle 文件对接器.文件句柄 常用API: - (NSData *)readDataToEndOfFile;读取数据到最后 ...
- Windows Service的官方描述,抄下来(不写obj就是LocalSystem)
How to create a Windows service by using Sc.exe Email Print Support for Windows XP has ended Micro ...
- log翻硬币
若果有一组硬币,(假定有十个),每一个硬币仅仅有两个面,正面用以表示.反面用零表示. 给定目标(初始状态)1111100000 正正正正正反反反反反 (目标状态) 1000011101 正反反反反 ...
- xcode APP 打包以及提交apple审核详细流程(新版本更新提交审核)
链接地址:http://blog.csdn.net/mad1989/article/details/8167529 打包发布APP流程真机测试和APP发布流程APP提交审核流程真机测试打包发布上传出错 ...
- winform利用代码将控件置于顶端底端
有时,我们可能动态的添加控件,并准备将其置于对顶层或最底层.实现的方法有两个: 一种方法是在WinForm窗体中使用Controls控件集的SetChildIndex方法,该方法将子控件设定为指定的索 ...
- delphi模态窗体最小化会隐藏的问题
在使用delphi创建模态窗体的时候最小化窗体会导致最小化的窗体不可见,再次点击主窗体才会显示. 在这个模态窗体中增加以下函数 procedure WmSysCommand(var msg: TMes ...
- HDU3572_Task Schedule(网络流最大流)
解题报告 题意: 工厂有m台机器,须要做n个任务.对于一个任务i.你须要花费一个机器Pi天,并且,開始做这个任务的时间要>=Si,完毕这个任务的时间<=Ei. 对于一个任务,仅仅能由一个机 ...
- [课堂实践与项目]NavigationController与TabBarController的综合使用及易错点分析(包含消息提醒,app更新)
陈述:我们在使用tabbarController的时候,我们总会和NavagationController联合起来.但是不联合的时候又是什么样的一种pool的情况呢?我们就单单的 TabBarCont ...
- Fragment与FragmentActivity通信封装
在项目里面会经常用到Fragment与FragmentActivity,比如Fragment之间的界面切换与Fragment之间的值传递等等,为了方便起见我把Fragment和FragmentActi ...
- c# 文件/文件夹操作
1.判断文件夹是否存在并创建 if (!Directory.Exists(tempFolderName)) { Directory.CreateDirectory(tempFolderName); }