首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言-强制类型转换

经常使用的东西 强制类型转换这个东西非常频繁的被使用,而且如果用的好的话,会非常的爽,我写个简单的例子。.../a.out str:Linux is my world root@ubuntu:~/project# cat 2.c 隐式类型转换 我们写代码的时候,在类型转换的时候,通常在前面加上类型的名字,如果不加的话...,不同的类型进行运算,编译器自己去判断如何进行转换,这种方式就是隐式类型转换。...通常在表达式中存在多个数据类型时发生。在这种情况下,类型转换类型提升)发生以避免数据丢失。 变量的所有数据类型都升级为具有最大数据类型的变量的数据类型。.../a.out x = 107, z = 108.000000 显式类型转换 此过程也称为类型转换,它是用户定义的。在这里,用户可以键入强制转换结果以使其具有特定的数据类型

2.3K30

C语言编程—强制类型转换

强制类型转换是把变量从一种类型转换为另一种数据类型。例如,如果您想存储一个 long 类型的值到一个简单的整型中,您需要把 long 类型强制转换为 int 类型。...您可以使用强制类型转换运算符来把值显式地从一种类型转换为另一种类型,如下所示: (type_name) expression 请看下面的实例,使用强制类型转换运算符把一个整数变量除以另一个整数变量,得到一个浮点数...类型转换可以是隐式的,由编译器自动执行,也可以是显式的,通过使用强制类型转换运算符来指定。在编程时,有需要类型转换的时候都用上强制类型转换运算符,是一种良好的编程习惯。...常用的算术转换 常用的算术转换是隐式地把值强制转换为相同的类型。...: Value of sum : 116.000000 在这里,c 首先被转换为整数,但是由于最后的值是 float 型的,所以会应用常用的算术转换,编译器会把 i 和 c 转换为浮点型,并把它们相加得到一个浮点数

30030
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言强制类型转换的原理

    ---- ---- 一、对指针进行强制类型转换 1.1printf打印时的转换形式 int main() { int a = 5; printf("%lf", a); return 0; } 解释代码...不能你做不出来题,或者因为代码风格不好,你就不做这题了吧 二、对变量进行强制类型转换 2.1 我们可能见到的形式 int main() { float a; scanf("%f", &a...还得怨你自己的能力不够,能看懂的人自然能看懂,你能力不够怨不得谁,这话也是说给我自己的哈 比较隐藏的地方就是,把那个浮点数+0.5赋值给了整型变量b里面了,这其实就是进行 了一个比较隐含的对变量进行的强制类型转换...比如你输入14.99,+0.5后变为15.49,这时我们又将其存到整型变量b里面,也就发生了强制类型转换,我们会改变a原来在内存里面表达为14.99的浮点型二进制代码形式,将其改变为表达15的整型二进制代码形式...我们只要将类型改成double就行了 2.3总结 变量的强制类型转换和指针的强制类型转换,本质就在于一个改变了其内存二进制的存储形式,一个未改变其内存二进制的存储形式

    1.3K10

    C语言的数据的强制类型转换

    定义:强制类型转换是把变量从一种类型转换为另一种数据类型。        强制类型转换算是C语言中常见常考的一项内容,如对于类型处理不好,将会产生错误结果。...对于某些类型转换编译器可隐式地自动进行,不需人工干预,称这种转换为自动类型转换;而有些类型转换需要编程者显式指定,通常,把这种类型转换称为强制类型转换 计算机硬件进行算术操作时,要求各操作数的类型具有相同的大小...其一般形式为:(类型说明符)(表达式)其功能是把表达式的运算结果强制转换类型说明符所表示的类型。自动转换是在源类型和目标类型兼容以及目标类型广于源类型时发生一个类型到另一类的转换。...所有这些转换都是由系统自动进行的, 使用时你只需从中了解结果的类型即可。这些转换可以说是自动的,但然,c语言也提供了以显式的形式强制转换类型的机制。 ...注意:赋值时的类型转换实际上是强制的。  (2) 单、双精度浮点型  ● 由于c语言中的浮点值总是用双精度表示的,所以float 型数据只是在尾部加0延长为doub1e型数据参加运算,然后直接赋值。

    1.2K20

    C++强制类型转换

    大家好,又见面了,我是全栈君   C++中的强制类型转换虽然兼容C语言中的强制类型转换,但是不建议在C++中使用C语言风格的强制类型转换。...C++中的强制类型转换共有4种:static_cast,dynamic_cast、const_cast、reinterpret_cast. static_cast 1....(2)使用多态的场景,增加了一层对真实调用对象类型的检查,可以实现向上转型和向下转型,前提是必须使用public或protected继承   (3)dynamic_cast不是强制转换,而是带有某种”咨询...这是强制转换做不到的。...&c)); //前两个的输出值是相同的,最后一个则会在原基础上偏移4个字节,这是因为static_cast计算了父子类指针转换的偏移量,\ 并将之转换到正确的地址(c里面有m_a,m_b

    1.3K10

    2.2 C++强制类型转换

    强制类型转换运算符 在C++的表达式中,不同的数据类型会自动地转换类型进行运算,但有的时候也需要程序员自己进行强制类型转换,将某个表达式转换成自己所需要的数据类型。...强制类型转换的一般形式为 (类型名) (表达式) 如果进行强制类型转换的对象是一个变量,则该变量的括号可以省略;如果要进行强制转换的对象是一个包含多项的表达式,则应该用小括号括起来表达式 比如 (int...) (a+b); //将a+b的值转换成整型 (float)(7%3); //将7%3的值转换成float型 (double) x; //将x转换成double类型 如果读者,看过小林之前推送C语言的文章...,会发现C++的强制类型转换C语言一样,因为C++编写者将C语言的优点保留了下来,除此之外C++还特别增加了 类型名 (表达式),类型名不加括号,但是变量或者表达式用括号括起来 int (a); float...在强制类型转换时,会得到一个中间变量,原来变量的类型未发生变化,但是如果从高精度向低精度转换时,会丢失精度。

    7143330

    C++:16---强制类型转换类型转换

    旧式的强制类型转换 在早期C/C++中,显式地进行强制类型转换有以下两种形式: type (expr) ; //函数形式的强制类型转换 (type) expr; //...C语言风格的强制类型转换 比如: char c = '12'; int b = (int)c; float f = float(b); C++的新式强制类型转换...type是转换的目标类型 避免强制类型转换 强制类型转换干扰了正常的类型检查,所以强烈建议程序员避免使用强制类型转换 这个建议对于reinterpret_cast尤其使用,因为此类类型转换总是充满了风险...j = 1; double slope1 = i / j; //一般的强制类型转换,编译器可能会报出警告 double slope2 = static_cast(j) / j; //显式地强制类型...转换,编译器无警告 当我们把较大的算术类型赋值给较小的类型时,一般的强制类型转换编译器会发出警告 但是当我们使用static_cast后,编译器就不会报出警告 演示案例 static_cast对于编译器无法自动执行的类型转换也非常有用

    2K20

    C++ 强制类型转换和赋值中的类型转换

    强制类型转换C语言的形式: (类型名)(表达式) 比如: (double)a //把a转换为double类型 (int)(a+b) //把a+b的值转换为整型 需要注意的是:如果强制类型转换的对象是一个变量...(int)(a+b) //把a+b的值转换为整型 (int)a+b //把a的值转换为整型,然后加b C++新增加的形式: 类型名(表达式) 该形式的类型名不需要括括号,但是待转换的对象不管是变量还是表达式都需要用括号括起来...i = (int)x; cout<<"x = "<<x<<",i = "<<i<<endl; getchar(); return 0; } 运行结果: x = 3.6,i = 3 赋值过程中的<em>类型</em><em>转换</em>...如果赋值运算符两侧的<em>类型</em>不一致,但都是数值型或字符型,在赋值时可以自动进行<em>类型</em><em>转换</em>。...字符型与数值型的说明: 在<em>C</em>++基本的数据<em>类型</em>中,可以分为四类:整型,浮点型,字符型,布尔型。其中数值型包括 整型与浮点型;字符型即为char。

    1.6K10

    Java基础:数值类型转换强制类型转换

    数值类型之间的转换 数值类型之间的转换,在小数值往大数值转换时,不会发生精度的损失。在小数值往大数值转换时有可能发生精度的损失。...比如byte最大值也只有127,如果一个大于127的int类型数据往byte转换肯定是不行的,但是往long类型转换就完全没问题了。...在我们进行一些两种不同数值类型之间的数值运算时,先要将两个操作数转换为同一种类型,然后再计算。 具体转换为那种类型,得看他们的取值。...注:《Java核心技术 卷1》 强制类型转换 除了Java自己会进行类型转换。比如int+double,系统会把结果转换为double。 我们有时候需要手动转换一些类型。...int类型数据时,需要再强转一下。

    2.4K00

    【专业知识】C++的强制类型转换

    C 风格(C-style)强制转换一般用(类型修饰)来转换类型。...C++则有自己的转换方式 使用标准C++的类型转换符:static_cast、dynamic_cast、reinterdivt_cast、和const_cast。...②用于基本数据类型之间的转换,如把int转换成char,把int转换成enum。这种转换的安全性也要开发人员来保证。 ③把空指针转换成目标类型的空指针。 ④把任何类型的表达式转换成void类型。...static_cast覆盖的变换类型除类层次的静态导航以外,还包括无映射变换、窄化变换(这种变换会导致对象切片,丢失信息)、用void*的强制变换、隐式类型变换等......(这句话是C++编程思想中的原话) static_cast 和 reinterdivt_cast 操作符修改了操作数类型

    1.1K40

    C++学习——数据类型强制转换详解

    C++ 使用运算符时,它会努力将操作数转换为相同的类型。这种隐式或自动的转换称为类型强制。当一个值被转换为更髙的数据类型时,称之为升级。反之,降级则意味着将其转换为更低的数据类型。...类型强制转换 有时程序员想要自己更改值的数据类型,这可以通过使用类型强制转换表达式来完成。类型强制转换表达式允许手动升级或降级值。...类型转换表达式在 C++ 不能自动执行所需转换的情况下很有用。 下面的程序显示了使用类型强制转换表达式来防止发生整除法的示例。...注意,C++ 提供了若干种不同类型强制转换表达式。static_cast 是最常用的类型强制转换表达式,所以这将是在本教程中主要使用的表达式。...C 风格和预标准 C++ 类型强制转换表达式 虽然 static_cast 是目前使用最多的类型强制转换表达式,但是 C++ 还支持两种较旧的形式,这也是程序员应该有所了解的,即 C 风格形式和预标准

    1.6K10
    领券