C++ casts那些事儿

简介:

C++ casts那些事儿

 

C/C++编译器类型隐式转换我想大家都一定很熟悉了。写C++的程序,要么是依靠编译器进行类型隐式转换,要么自己显示将类型进行转换,但是很少用到cast。最近看到一些代码经常使用cast来进行显示转换。自己研究下,发现cast这东西还是很有意思。

 

C++中cast关键字有:static_cast, dynamic_cast, const_cast, reinterpret_cast四种

cast的语法:

 

cast-name<type>(expressiong)

后面的expression不管是一个变量还是一个表达式,都需要使用括号。

 

const_cast:

将const变量转换成非const变量

 

#include <iostream> using namespace std; void func(char *str){ /... } int main(){ const char *mystr = "hello tan haiyan"; func(mystr); }

 

上面这段代码肯定会编译报错。无法将const char * 转换成char *

这个时候const_cast就可以起到作用了:

作出以下更改之后,就没问题了。

#include <iostream> using namespace std; void func(char *str){ /... } int main(){ const char *mystr = "hello tan haiyan"; func(const_cast<char *>(mystr)); }

 

 

只有const_cast才具有将const转换成非const类型

 

 

static_cast:

显示类型转换。这种cast的主要目的是让程序员和编译器知道这段代码作出的转换就是我想要的结果而不是失误或者偶然,这样可以去掉编译器误认为是因为程序员操作失误而产生的类型转换的警告。

 

double d_data = 3.14; int i_data = static_cast<int>(d_data);//这样显示转换,编译器不会有警告

 

 

double d_data = 3.14 void *ptr = &d_data /** 如果我们已经知道void 指针指向的是一个double数据。我们就可以作出这种强制转换*/ double *ptmp_data = static_const<double *>(ptr);

 

 

reinterpreter_cast:

reinterpreter_cast比较不好理解。它只进行一种简单的bit位复制而不进行二进制数据分析。

这种盲目的复制而不进行数据分析的强制转换在使用过程中一定要谨慎。

 

 

/** 仅仅是简单的复制了n的bit位到变量d,不进行任何数据分析 */ int n=9;    double d=reinterpret_cast<double & > (n);

 

 

dynamic_cast:

除了转换之外,多了一步安全检查,检查转换是否可行。依赖于RTTI

 

struct A { virtual void f() { } }; struct B : public A { }; struct C { }; void f () { A a; B b; A* ap = &b; B* b1 = dynamic_cast<B*> (&a); // NULL, because 'a' is not a 'B' B* b2 = dynamic_cast<B*> (ap); // 'b' C* c = dynamic_cast<C*> (ap); // NULL. A& ar = dynamic_cast<A&> (*ap); // Ok. B& br = dynamic_cast<B&> (*ap); // Ok. C& cr = dynamic_cast<C&> (*ap); // std::bad_cast }

 

 

 

 


版权申明:
转载文章请注明原文出处http://blog.csdn.net/feiyinzilgd/archive/2010/12/30/6108417.aspx
并请联系谭海燕 本人或者前往谭海燕个人主页 留言

目录
相关文章
|
1天前
|
存储 关系型数据库 MySQL
数据管理的艺术:PolarDB开源版详评与实战部署策略(一)
PolarDB-X是阿里巴巴自研的高性能云原生分布式数据库,基于共享存储的Shared-nothing架构,支持MySQL生态,具备金融级高可用、分布式水平扩展、HTAP混合负载等能力。它通过CN(计算节点)和DN(存储节点)实现计算与存储分离,保证数据强一致性,并支持全局二级索引和多主多写。PolarDB-X开源版提供更高程度的定制化和控制权,适合追求技术自主性和成本优化的开发者。部署方式包括RPM包、PXD工具和Kubernetes,其中PXD工具提供了一键部署的便利性。
44731 10
|
5天前
|
关系型数据库 Serverless 分布式数据库
高峰无忧,探索PolarDB PG版Serverless的弹性魅力
在数字经济时代,数据库成为企业命脉,面对爆炸式增长的数据,企业面临管理挑战。云原生和Serverless技术革新数据库领域,PolarDB PG Serverless作为阿里云的云原生数据库解决方案,融合Serverless与PostgreSQL,实现自动弹性扩展,按需计费,降低运维成本。它通过计算与存储分离技术,提供高可用性、灾备策略和简化运维。PolarDB PG Serverless智能应变业务峰值,实时监控与调整资源,确保性能稳定。通过免费体验,用户可观察其弹性性能和价格力,感受技术优势。
|
15天前
|
存储 缓存 监控
你的Redis真的变慢了吗?性能优化如何做
本文先讲述了Redis变慢的判别方法,后面讲述了如何提升性能。
102248 5
|
15天前
|
机器学习/深度学习 并行计算 算法
Transformer 一起动手编码学原理
学习Transformer,快来跟着作者动手写一个。
94256 8
|
14天前
|
存储 SQL Apache
阿里云数据库内核 Apache Doris 基于 Workload Group 的负载隔离能力解读
阿里云数据库内核 Apache Doris 基于 Workload Group 的负载隔离能力解读
阿里云数据库内核 Apache Doris 基于 Workload Group 的负载隔离能力解读
|
19天前
|
人工智能 弹性计算 算法
一文解读:阿里云AI基础设施的演进与挑战
对于如何更好地释放云上性能助力AIGC应用创新?“阿里云弹性计算为云上客户提供了ECS GPU DeepGPU增强工具包,帮助用户在云上高效地构建AI训练和AI推理基础设施,从而提高算力利用效率。”李鹏介绍到。目前,阿里云ECS DeepGPU已经帮助众多客户实现性能的大幅提升。其中,LLM微调训练场景下性能最高可提升80%,Stable Difussion推理场景下性能最高可提升60%。
124036 50
|
15天前
|
存储 弹性计算 Cloud Native
1 名工程师轻松管理 20 个工作流,创业企业用 Serverless 让数据处理流程提效
为应对挑战,语势科技采用云工作流CloudFlow和函数计算FC,实现数据处理流程的高效管理与弹性伸缩,提升整体研发效能。
64755 2
|
21天前
|
消息中间件 安全 API
Apache RocketMQ ACL 2.0 全新升级
RocketMQ ACL 2.0 不管是在模型设计、可扩展性方面,还是安全性和性能方面都进行了全新的升级。旨在能够为用户提供精细化的访问控制,同时,简化权限的配置流程。欢迎大家尝试体验新版本,并应用在生产环境中。
187613 38
|
17天前
|
存储 关系型数据库 数据库