C++超详细讲解强制类型转换
目录
- 1 C 强制类型转换
- 2 C++ 强制类型转转
1 C 强制类型转换
C 方式的强制类型转换的用法如下代码所示:
(Type)(Expression)
- Type:需要转换成的类型
- Expression:对其进行转换
e.g.
int v = 0x12345; // 将 int 类型的变量转换成 char 类型 char c = char(v);
C 方式的强制类型转换存在如下问题:
过于粗暴:任意类型之间都可以进行转换,编译器很难判断其正确性
typedef void(PF)(int); int v = 0x12345; // 将 0x12345 转换成一个函数指针的入口地址 PF* pf = (PF*)v;
上述代码编译器是可以编译通过的,但实际上是不可行的,因此编译器无法判断其正确性
- 潜在的问题不易被发现
- 难于定位:无法快速定位出现错误的强制类型转换语句
2 C++ 强制类型转转
C++ 方式的强制类型转换以 C++ 关键字的方式进行转换,同时将所有转换类型分为4中类型,如下表所示:
类型 | 特点 |
---|---|
static_cast | 用于基本类型之间的转换 不能同于基本类型指针间的转换 可以用于有继承关系的类对象之间的转换和类指针之间的转换 |
const_cast | 用于去除变量的只读属性 强制类型转换的目标类型必须是指针或引用 |
dynamic_cast | 用于有继承关系的类指针间的转换 用于有交叉关系的类指针间的转换 具有类型检查的功能 需要有虚函数的支持 |
reinterpret_cast | 用于指针类型之间的转换 用于整数和指针类型之间的转换 |
C++ 方式的强制类型转换具有如下特点:
- 编译器能够帮助检查潜在的问题
- 可以快速的在代码中进行定位
- 支持动态类型识别
e.g. static_cast
void static_cast_Demo() { int i = 0x12345; char c = 'c'; int* pi = &i; char* pc = &c; c = static_cast<char>(i); // ok,可以用于基本类型之间的转换 pc = static_cast<char*>(pi); // error,不能同于基本类型指针间的转换 }
e.g. const_cast
void const_cast_Demo() { const int& i = 1; int& j = const_cast<int&>(i); // ok const int x = 2; int& y = const_cast<int&>(x); // ok int z = const_cast<int>(x); // error,强制类型转换的目标类型必须是指针或引用 j = 5; printf("j = %d\n", j); printf("i = %d\n", i); y = 8; printf("x = %d\n", x); printf("y = %d\n", y); }
到此这篇关于C++超详细讲解强制类型转换的文章就介绍到这了,更多相关C++强制类型转换内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
相关推荐
-
C++ 强制类型转换详解
目录 一.C强制转换 二.C++强制转换 1.static_cast 静态转换(编译时检查) 2.const_cast 常量转换 3.reinterpret_cast 重新解释转换 4.dynamic_cast 动态转换(运行时检查) 三.要点总结 一.C强制转换 C语言中的强制转换主要用于普通数据类型.指针的强制转换,没有类型检查,转换不安全, 语法为: (type-id)expression//转换格式1 type-id(expression)//转换格式2(基本已经不用了) 二.C++强制
-
C++中4种强制类型转换的区别总结
前言 使用标准C++的类型转换符:static_cast.dynamic_cast.reinterpret_cast和const_cast. const_cast,字面上理解就是去const属性. static_cast,命名上理解是静态类型转换.如int转换成char. dynamic_cast,命名上理解是动态类型转换.如子类和父类之间的多态类型转换. reinterpreter_cast,仅仅重新解释类型,但没有进行二进制的转换. 一.static_cast 用法:static_cast
-
关于C++的强制类型转换浅析
前言 一说起强制类型转换大家都很熟悉,相信很多学习完C++的朋友还在使用C语言的强制类型的方式 (类型)变量. C++其实也具有自己的一套强制类型转换它们分明是:static_cast reinterpret_cast const_cast dynamic_cast四种类型. 那么肯定会有人好奇C++是不是闲,C语言的强制类型用的舒舒服服的,为什么要新推出来这几个? 新类型的强制转换可以提供更好的控制强制转换过程,允许控制各种不同种类的强制转换.C++中风格是static_cast<typ
-
一文搞懂C++中的四种强制类型转换
在了解c++的强制类形转换的时候,先看看在c语言中是怎么进行强制类形转换的. C语言中的强制类形转换分为两种 隐式类型转换 显示类型转换 int main() { int a = 97; char ch = a; // 隐式类型转换 int b = (int)ch; // 显示类型转换 cout << "a = " << a << endl; cout << "ch = " << ch << e
-
解析C++中四种强制类型转换的区别详解
C++的四种强制类型转换,所以C++不是类型安全的.分别为:static_cast , dynamic_cast , const_cast , reinterpret_cast为什么使用C风格的强制转换可以把想要的任何东西转换成合乎心意的类型.那为什么还需要一个新的C++类型的强制转换呢?新类型的强制转换可以提供更好的控制强制转换过程,允许控制各种不同种类的强制转换.C++中风格是static_cast<type>(content).C++风格的强制转换其他的好处是,它们能更清晰的表明它们要干
-
C++强制类型转换(static_cast、dynamic_cast、const_cast、reinterpret_cast)
目录 1. c强制转换与c++强制转换 2. static_cast.dynamic_cast.const_cast.reinterpret_cast dynamic_cast const_cast reinterpret_cast 3. c++强制转换注意事项 1. c强制转换与c++强制转换 c语言强制类型转换主要用于基础的数据类型间的转换,语法为: (type-id)expression//转换格式1 type-id(expression)//转换格式2 c++除了能使用c语言的强制类型转
-
浅谈C++的语句语法与强制数据类型转换
一个程序包含一个或多个程序单位(每个程序单位构成一个程序文件).每一个程序单位由以下几个部分组成: 预处理命令.如#include命令和#define命令. 声明部分.例如对数据类型和函数的声明,以及对变量的定义. 函数.包括函数首部和函数体,在函数体中可以包含若干声明语句和执行语句. 如下面是一个完整的C++程序: #include <iostream>//预处理命令 using namespace std; //在函数之外的声明部分 int a=3; //在函数之外的声明部分 int ma
-
C++中4种强制类型转换的区别详析
前言 C++即支持C风格的类型转换,又有自己风格的类型转换.C风格的转换格式很简单,但是有不少缺点的: 1.转换太过随意,可以在任意类型之间转换.你可以把一个指向const对象的指针转换成指向非const对象的指针,把一个指向基类对象的指针转换成一个派生类对象的指针,这些转换之间的差距是非常巨大的,但是传统的C语言风格的类型转换没有区分这些. 2.C风格的转换没有统一的关键字和标示符.对于大型系统,做代码排查时容易遗漏和忽略. C++风格完美的解决了上面两个问题.1.对类型转换做了细分,提供了四
-
C++强制类型转换的四种方式
目录 1 C++类型转换本质 1.1 自动类型转换(隐式) 1.2 强制类型转换(显式) 1.3 类型转换的本质 1.4 类型转换的安全性 2 四种类型转换运算符 2.1 C语言的强制类型转换与C++的区别 3 static_cast 4 reinterpret_cast 5 const_cast 6 dynamic_cast 6.1 向上转型(Upcasting) 6.2 向下转型(Downcasting) 1 C++类型转换本质 1.1 自动类型转换(隐式) 利用编译器内置的转换规则,或者用
-
C++超详细讲解强制类型转换
目录 1 C 强制类型转换 2 C++ 强制类型转转 1 C 强制类型转换 C 方式的强制类型转换的用法如下代码所示: (Type)(Expression) Type:需要转换成的类型 Expression:对其进行转换 e.g. int v = 0x12345; // 将 int 类型的变量转换成 char 类型 char c = char(v); C 方式的强制类型转换存在如下问题: 过于粗暴:任意类型之间都可以进行转换,编译器很难判断其正确性 typedef void(PF)(int);
-
C++超详细讲解强制类型转换的用法
目录 static_cast dynamic_cast const_cast reinterpret_cast static_cast static_cast<type-id>(expression) 将 expression 转换为 type-id 类型.static_cast 是静态类型转换,发生在编译期.这种转换不会进行运行时的动态检查(RTTI),因而这种转换可能是不安全的.static_cast 典型应用场景如下: 1. 类的层级结构中,基类和子类之间指针或者引用的转换. 上行转换(
-
超详细讲解Java异常
目录 一.Java异常架构与异常关键字 Java异常简介 Java异常架构 1.Throwable 2.Error(错误) 3.Exception(异常) 4.受检异常与非受检异常 Java异常关键字 二.Java异常处理 声明异常 抛出异常 捕获异常 如何选择异常类型 常见异常处理方式 1.直接抛出异常 2.封装异常再抛出 3.捕获异常 4.自定义异常 5.try-catch-finally 6.try-with-resource 三.Java异常常见面试题 1.Error 和 Excepti
-
C语言操作符超详细讲解下篇
目录 前言 赋值操作符 单目操作符 单目操作符介绍 sizeof 和 数组 关系操作符 逻辑操作符 条件操作符 逗号表达式 下标引用与函数调用和结构成员 [ ] 下标引用操作符 ( ) 函数调用操作符 访问一个结构的成员 表达式求值 隐式类型转换-整形提升 算术转换 操作符的属性 总结 前言 本文接着学习操作符的内容. 赋值操作符 赋值操作符就是能够重新赋值 int weight = 120;//体重 weight = 89;//不满意就赋值 double salary = 10000.0; s
-
C语言超详细讲解顺序表的各种操作
目录 顺序表是什么 顺序表的结构体 顺序表的接口函数 顺序表相关操作的菜单 顺序表的初始化 添加元素 陈列元素 往最后加元素 往前面加元素 任意位置加元素 删除最后元素 删除前面元素 删除任意元素 整体代码(fun.h部分) 整体代码(fun.cpp部分) 整体代码(主函数部分) 结果展示 顺序表是什么 顺序表是在计算机内存中以数组的形式保存的线性表,线性表的顺序存储是指用一组地址连续的存储单元依次存储线性表中的各个元素.使得线性表中在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中,即通过数
-
C++超详细讲解模板的使用
目录 一.函数模板 1.1函数模板概念 1.2 函数模板格式 1.3 函数模板的原理 1.4 函数模板的实例化 二.类模板 2.1 类模板的定义格式 2.2类模板的实例化 总结 一.函数模板 1.1函数模板概念 函数模板代表了一个函数家族,该函数模板与类型无关,在使用时被参数化,根据实参类型产生函数的特定类型版本. 1.2 函数模板格式 template<typename T1, typename T2,…,typename Tn> 返回值类型 函数名(参数列表){} template<
-
C++超详细讲解泛型
目录 1.了解泛型编程 2.函数模板 2.1简单示例 2.2多个模板参数 2.3模板实例化 2.4模板和普通函数同时存在 2.5函数模板不支持定义和声明分离 3.类模板 3.1简单示例 3.2成员函数声明和定义分离 1.了解泛型编程 就好比活字印刷术,可以灵活调整印刷的板块和内容,比只能固定印刷某一个内容的雕版印刷术效率更高,也让印刷术由此得到了更广泛的应用. 在C++中,函数重载和模板的出现,让泛型编程得到了实际的应用.其中模板,就是类似活字印刷术一样的存在. 2.函数模板 八八了那么多没用的
-
C++超详细讲解模拟实现vector
目录 1. 模拟实现vector 2. vector常用接口 2.1 reserve 2.2 resize 2.3 push_back 2.4 pop_back() 2.5 insert 2.6 erase 2.7 构造函数的匹配问题 3. 更深层次的深浅拷贝问题 1. 模拟实现vector 我们模拟实现是为了加深对这个容器的理解,不是为了造更好的轮子. 快速搭一个vector的架子 // vector.h #pragma once #include <assert.h> // 模拟实现 --
-
C语言超详细讲解猜数字游戏的实现
目录 rand函数 srand函数 时间戳 完整代码与程序运行图 rand函数 先看一下下面这张图: 通过这张图我们可以了解到rand函数的返回值是int类型,形参为空,它的头文件<stdlib.h>以及它的返回值范围是0到RAND_MAX. 而RAND_MAX在VS中是0x7fff,转换成二进制就是32767.所以rand返回的随机数的范围就是0到32727. 其实我们用rand函数就可以生成随机数了,那为什么我们还要用到srand函数呢? 因为只有第一次生成的随机数是随机的,如果程序执行多
-
C语言可变参数与内存管理超详细讲解
目录 概述 动态分配内存 重新调整内存的大小和释放内存 概述 有时,您可能会碰到这样的情况,您希望函数带有可变数量的参数,而不是预定义数量的参数.C 语言为这种情况提供了一个解决方案,它允许您定义一个函数,能根据具体的需求接受可变数量的参数.下面的实例演示了这种函数的定义. int func(int, ... ) { . . . } int main() { func(2, 2, 3); func(3, 2, 3, 4); } 请注意,函数func()最后一个参数写成省略号,即三个点号(...)
随机推荐
- 在SQL Server中将数据导出为XML和Json的方法
- Java入门基础之Java的基本语法与Java所支持的数据类型
- java连接mysql数据库及测试是否连接成功的方法
- oracle while的用法示例分享
- JavaScript 关键字屏蔽实现函数
- asp.net简单生成XML文件的方法
- php 进度条实现代码
- Mongoose中document与object的区别示例详解
- Linux文件系统的桌面应用
- javascript 层隐藏和显示的代码
- 深入理解数组指针与指针数组的区别
- 基于JQuery实现CheckBox全选全不选
- js实现兼容IE6与IE7的DIV高度
- Java实现排队论的原理
- 浅谈Java中的Filter过滤器
- 新手学习.net的一列好走的路径及方法
- 详解Android中点击事件的几种实现方式
- 用as检测服务器端的某个flv文件是否存在的代码
- layui.js实现的表单验证功能示例
- python编程实现随机生成多个椭圆实例代码