浅析C++的特殊工具与技术

一、优化内存
1、策略:预先分配用于创建对象的内存,需要时在预先分配的内存中构造每人新对象。

2、allocator类;a.destroy(p),运行T*指针p所指对象的析构函数。注意,运行析构函数并不释放对象所在的内存,要想释放内存就要调用函数a.deallocate(p,n),释放然为p的T*指针中包含的地址处保存T类型的n个对象。

3、operator new函数与operator delete函数;注意与new和delete表达式区别。operator new和operator delete是函数,而new和delete是表达式。它们都返回void*指针而不是类型化的指针。使用allocator比直接使用operator new和operator delete函数更为类型安全。标准库函数operator new和operator delete可以说是allocator的allocate和deallocate成员的低级版本,它们分配但不初始化内存。注意,调用operator delete函数不会运行析构函数,它只释放指定的内存。

4、定位new表达式;定位new表达式在已分配的原始内存中初始化一个对象,它与new的其他版本的不同之外在于,它不分配内存。相反,它接受指向已分配但未构造内存的指针,并在该内存中初始化一个对象。定位new表达式使我们能够在特定的、预分配的内存地址构造一个新对象。表达式为new (place_address) type或new (place_address) type(initialzer-list),place_address必须是一个指针,initial-list是一个可为空的初始化列表,例如:new (sp)string(b,e)。定位new表达式初始化一个对象的时候,它可以使用任何构造函数,并直接建立对象。

5、创建新的对象的时候,可以在这个预先分配的空间构造对象。释放对象的时候,将它们放回预先分配对象的块中,而不是将内存真正返回给系统。所以可以通过定义(或继承)自己的名为operator new和operator delete的成员,来管理自身类型的内存,否则,调用这些函数的标准库版本。因为在构造对象前要使用operator new在对象撤销后使用operator delete所以,成员new和delete函数必须是静态的。

二、运行时类型识别
1、通过运行时类型识别(RTTI),程序能够使用基类的指针或引用来检索这些指针或引用所指对象的实际派生类型。通过两个操作符提供RTTI:

*typeid 操作符,返回指针或引用所指对象的实际类型
*dynamic_cast操作符,将基类类型的指针或引用安全地转换为派生类型的指针或引用

2、dynamic_cast操作符;用法:dynamic_cast<Type */&>(val),Type是转换的目标类型,val是基类类型的对象。
如,if(Derived *derivedPtr==dynamic_cast<Derived*>(basePtr){...}。

dynamic_cast操作符执行的验证必须在运行时进行。如果转换到指针类型失败,则dynamic_cast的结果为0;如果转换到引用类型的dynamic_cast失败,则抛出一个bad_cast类型的异常。

3、typeid操作符;表达式:typeid(e),e是任意表达式或者是类型名。typeid操作符可以与任何类型的表达式一起使用。typeid最常见的用途是比较两个表达式的类型,或者将表达式的类型与特定类型相比较。例如:if(typeif(*derivedPtr)==typeid(Derived);

三、类成员的指针
1、声明成员指针。成员指针只应用于非static成员,static成员指针是普通指针。

2、定义数据成员的指针。既要表明成员的类型,又要表明成员所属的类。
如string Screen::*,是指向Screen类的string成员的指针。

3、定义成员函数的指针。

一致的匹配要求:
*函数形参的类型和数目,包括成员是否为const
*返回类型
*所属类的类型
如:char (Screen::*)()const

4、使用类成员的指针;
*成员指针解引用操作符(.*)从对象或引用获取成员
*成员指针箭头操作符(->*)通过对象的指针获取成员
可以定义一个数组保存指向每个光标移动函数的指针。

更多内容,见上篇:指向类成员的指针并非指针。或参考《C++必知必会》

四、嵌套类
在一个类内部定义另一个类。嵌套类是独立的类,基本上与它们的外围类不相关,因此,外围类和嵌套类是互相独立的。外围类对嵌套类的成员特殊访问权,并且嵌套类对其外围类的成员也没有特殊访问权。嵌套类的名字在其外围类的作用域中可见,但在其他类作用域或定义外围类的作用域中不可见。嵌套类可以具有与非嵌套类相同种类的成员。

1、嵌套在类模板内部的类是模板;

2、定义;在其类外部定义的嵌套类的成员,不能定义在外围类内部,嵌套类的成员不是外围类的成员。为了在外围类的外部定义类体,必须用外围类的名字既定嵌套类的名字。注意,我们仍然必须在外围类的定义体中声明嵌套类。嵌套类中声明的静态成员的定义也放在外层作用域中。

3、嵌套类型对象只包含嵌套类型的成员,不能使用this获取外围类的成员。外围类也不能直接调用嵌套类中的成员。嵌套类可以直接引用外围类的静态成员、类型名和枚举成员。

五、联合:节省空间的类;
1、一个union对象可以有多个数据成员,但在任何时刻,只有一个成员可以有值。

2、为union对象分配的存储量至少与union的最大烦数据成员一样大。

3、union不能作为基类使用,成员能为虚函数,也不能定义构造函数、析构函数或赋值操作符的类类型成员。

4、为了知道union对象中的值,通常会把一个枚举型的变量作为union对象的判别式。

(0)

相关推荐

  • 浅析C++的特殊工具与技术

    一.优化内存1.策略:预先分配用于创建对象的内存,需要时在预先分配的内存中构造每人新对象. 2.allocator类:a.destroy(p),运行T*指针p所指对象的析构函数.注意,运行析构函数并不释放对象所在的内存,要想释放内存就要调用函数a.deallocate(p,n),释放然为p的T*指针中包含的地址处保存T类型的n个对象. 3.operator new函数与operator delete函数:注意与new和delete表达式区别.operator new和operator delet

  • 浅析Android企业级开发数据绑定技术

    这篇文章通过发文的方式让大家知道什么是数据绑定,以及为什么要用数据绑定等问题,有助于大家理解Android企业级开发数据绑定技术. 首先要了解什么是数据绑定?为什么要用数据绑定?怎么用数据绑定? 语法的使用 简单例子,数据绑定textview控件,一般情况下我们都是些一个布局文件,然后布局文件里放一些textview,然后通过Activity来findviewbyid来获取id,然后对象.setText("").现在我们学了数据绑定,就可以不用之前的方法了. 把库加载进来:因为这个东西

  • 浅析Linux下利用coredump技术追查进程崩溃原因

    最近项目中出现了一个问题,服务器端程序会突然崩溃退出,我们采取了coredump技术以找到崩溃原因,即确定进程退出时正在执行的函数是哪个,其状态如何. 如果系统开启了coredump,准确的说如果当前的shell环境开启了coredump,当前shell环境下的程序崩溃退出时,会把当时进程的栈的内存状态写入core文件.使用gdb可以查看这个core文件中保存的栈的状态,gdb a.out core.(关于coredump的开启和对shell的理解,请参考本人另一篇博客<使用dotnet-dum

  • 浅析JSONP技术原理及实现

    跨域问题一直是前端中常见的问题,每当说到跨域,第一浮现的技术必然就是JSONP JSONP在我的理解,它并不是ajax,它是在文档中插入一个script标签,创建_callback方法,通过服务器配合执行_callback方法,并传入一些参数 JSONP的局限就在于,因为是通过插入script标签,所以参数只能通过url传入,因此只能满足get请求,特别jQuery的ajax方法时,即使设置type: 'POST',但是只要设置了dataType: 'jsonp',在请求时,都会自动使用GET请

  • 浅析Linux中的零拷贝技术的使用

    本文探讨Linux中主要的几种零拷贝技术以及零拷贝技术适用的场景.为了迅速建立起零拷贝的概念,我们拿一个常用的场景进行引入: 引文## 在写一个服务端程序时(Web Server或者文件服务器),文件下载是一个基本功能.这时候服务端的任务是:将服务端主机磁盘中的文件不做修改地从已连接的socket发出去,我们通常用下面的代码完成: while((n = read(diskfd, buf, BUF_SIZE)) > 0) write(sockfd, buf , n); 基本操作就是循环的从磁盘读入

  • 浅析Spring Boot单体应用熔断技术的使用

    壹.入围方案 Sentinel github地址:https://sentinelguard.io/zh-cn/docs/introduction.html 阿里出品,Spring Cloud Alibaba限流组件,目前持续更新中 自带Dashboard,可以查看接口Qps等,并且可以动态修改各种规则 流量控制,直接限流.冷启动.排队 熔断降级,限制并发限制数和相应时间 系统负载保护,提供系统级别防护,限制总体CPU等 主要核心:资源,规则(流量控制规则.熔断降级规则.系统保护规则.来源访问控

  • 容器化技术架构jenkins docker k8s脚本浅析

    目录 前言碎语 浅谈docker 浅谈k8s的部署脚本 最后聊聊jenkinspipeline 前言碎语 基于kubernetes容器化技术架构能够带来诸多好处,诸如,弹性伸缩,自动修复等,在比如蓝绿部署,灰度发布等.近几年容器化技术飞速发展,了解服务网格 的人可能会发现,新兴技术 istio 等service mesh技术没有容器化的技术环境根本就没法实践. 浅谈docker docker可以类比为jvm,jvm也是虚拟机,然后docker的image可以类比为jar包,jar运行在jvm里面

  • 浅析2004年出现的4种新后门技术

    曾经饱受木马.后门(以下统称后门)侵害的人们都不会忘记机器被破坏后的惨象,于是人们展开了积极的防御工作,从补丁到防火墙,恨不得连网线都加个验证器,在多种多样的防御手法夹攻下,一大批后门倒下了,菜鸟们也不用提心吊胆上网了-- 可是后门会因此罢休吗?答案当然是否定的.君不见,在风平浪静的陆地下,一批新的后门正在暗渡陈仓-- 1.反客为主的入侵者 黑客A连接上了网络,却不见他有任何行动,他在干什么呢?我们只能看见他燃起一支烟,似乎在发呆--过了一会儿,他突然把烟头一丢,双手迅速敲击键盘,透过屏幕,我们

  • Mysql数据表分区技术PARTITION浅析

    在这一章节里, 我们来了解下 Mysql 中的分区技术 (RANGE, LIST, HASH)   Mysql 的分区技术与水平分表有点类似, 但是它是在逻辑层进行的水平分表, 对于应用而言它还是一张表, 换句话说: 分区不是实际真正的对一张表进行拆分,分区之后表还是一个表,它是把存储文件进行拆分. 在 Mysql 5.1(后) 有了几种分区类型:   RANGE分区: 基于属于一个给定连续区间的列值, 把多行分配给分区 LIST分区: 类似于按 RANGE 分区, 区别在于 LIST 分区是基

  • 浅析Windows 2000/XP服务与后门技术

    一.序言 Windows下的服务程序都遵循服务控制管理器(SCM)的接口标准,它们会在登录系统时自动运行,甚至在没有用户登录系统的情况下也会正常执行,类似与UNIX系统中的守护进程(daemon).它们大多是控制台程序,不过也有少数的GUI程序.本文所涉及到的服务程序仅限于Windows2000/XP系统中的一般服务程序,不包含Windows9X. 二.Windows服务简介 服务控制管理器拥有一个在注册表中记录的数据库,包含了所有已安装的服务程序和设备驱动服务程序的相关信息.它允许系统管理员为

随机推荐