C++强制类型转换
2015-06-30 16:47
225 查看
在表达式中不同类型的数据会自动地转换类型,以进行运算。有时程序编制者还可以利用强制类型转换运算符将一个表达式转换成所需类型。例如:
(double)a (将a转换成double类型)
(int)(x+y) (将x+y的值转换成整型)
(float)(5%3) (将5%3的值转换成float型)
强制类型转换的一般形式为:
(类型名)(表达式)
注意:如果要进行强制类型转换的对象是一个变量,该变量可以不用括号括起来。如果要进行强制类型转换的对象是一个包含多项的表达式,则表达式应该用括号括起来。如果写成
(int)x+y
则只将x转换成整型,然后与y相加。
以上强制类型转换的形式是原来C语言使用的形式,C++把它保留了下来,以利于兼容。C++还增加了以下形式:
类型名(表达式)
如
int(x)
或
int(x+y)
类型名不加括号,而变量或表达式用括号括起来。这种形式类似于函数调用。但许多人仍习惯于用第一种形式,把类型名包在括号内,这样比较清楚。
需要说明的是在强制类型转换时,得到一个所需类型的中间变量,但原来变量的类型未发生变化。例如:
(int)x
如果x原指定为float型,值为3.6,进行强制类型运算后得到一个int型的中间变量,它的值等于3,而x原来的类型和值都不变。
【例2.4】强制类型转换。
运行结果如下:
x=3.6,i=3
x的型仍为float型,值仍等于3.6。
由上可知,有两种类型转换,一种是在运算时不必用户指定,系统自动进行的类型转换,如3+6.5。第二种是强制类型转换。当自动类型转换不能实现目的时,可以用强制类型转换。此外,在函数调用时,有时为了使实参与形参类型一致,可以用强制类型转换运算符得到一个所需类型的参数。
(double)a (将a转换成double类型)
(int)(x+y) (将x+y的值转换成整型)
(float)(5%3) (将5%3的值转换成float型)
强制类型转换的一般形式为:
(类型名)(表达式)
注意:如果要进行强制类型转换的对象是一个变量,该变量可以不用括号括起来。如果要进行强制类型转换的对象是一个包含多项的表达式,则表达式应该用括号括起来。如果写成
(int)x+y
则只将x转换成整型,然后与y相加。
以上强制类型转换的形式是原来C语言使用的形式,C++把它保留了下来,以利于兼容。C++还增加了以下形式:
类型名(表达式)
如
int(x)
或
int(x+y)
类型名不加括号,而变量或表达式用括号括起来。这种形式类似于函数调用。但许多人仍习惯于用第一种形式,把类型名包在括号内,这样比较清楚。
需要说明的是在强制类型转换时,得到一个所需类型的中间变量,但原来变量的类型未发生变化。例如:
(int)x
如果x原指定为float型,值为3.6,进行强制类型运算后得到一个int型的中间变量,它的值等于3,而x原来的类型和值都不变。
【例2.4】强制类型转换。
#include <iostream> using namespace std; int main( ) { float x; int i; x=3.6; i=(int)x; cout<<"x="<<x<<",i="<< i<<endl; return 0; }
运行结果如下:
x=3.6,i=3
x的型仍为float型,值仍等于3.6。
由上可知,有两种类型转换,一种是在运算时不必用户指定,系统自动进行的类型转换,如3+6.5。第二种是强制类型转换。当自动类型转换不能实现目的时,可以用强制类型转换。此外,在函数调用时,有时为了使实参与形参类型一致,可以用强制类型转换运算符得到一个所需类型的参数。
相关文章推荐
- 最小二乘法拟合多项式原理以及c++实现
- C++自增和自减运算符(--和++)
- C++编程中虚函数的作用
- 牛客网(c++专项练习)
- C++ 虚函数表解析
- (转)C++常用函数汇总
- GCC单独编译host/examples/ tx_waveforms.cpp
- C++ Primer Plus 第10章 对象和类
- C++算术运算符与算术表达式
- C++的运算符
- C/C++预处理 ISO/ANSI C标准译文与注解
- C++中this指针的用法详解
- C++常变量
- Sum Root to Leaf Numbers : 精简实现方式
- C++变量(C++变量定义、变量赋值、命名规则)
- 【C语言】求两个数中不同的位的个数
- KMP算法——C++优化实现
- 【C语言】判断一个数是否为2的n次方
- 【C语言】判断一个数的奇偶(位操作)
- 【c语言】 给一组数,有两个数只出现了一次,其他所有数都是成对出现的。找出这两个数