C语言系列之强制类型转换(一)

例子:

#include <stdio.h>

{

char cChar;   //字符型变量

short int iShort; //短整型变量

int ilnt;           //整形变量

float fFloat=70000;      //单精度浮点型

cChar=(char)fFloat;     //强制转换赋值

iShort=(short)fFloat;    //

ilnt=(int)fFloat;           //

printf("the char is: %c\n",cChar);   // 输出字符变量值

printf("the long is:%ld\n",iShort);      //输出短整型变量值

printf("the int is: %d\n",ilnt);           //输出整型变量值

printf("the float is:%f\n",fFloat);      //输出浮点型变量值

return 0;                                      //返回值为0

}

输出结果:

the char is: p

the long is: 4464

the int is;70000

the float is 70000.000000

问题一:

the char is: p

为什么将单精度浮点型转换成字符型的时候输出结果为p;

根据C语言的结构而言,字符型输出方式可以用字符或者用ASCLL码,如下图所示

最简单的例子如:

cChar1=‘a‘;

cChar2=97;

printf("%c/n",cChar1);

printf("%c/n",cChar2);

输出结果:

a

a

因为a的ascll码就是97;

重点:

ascll码表一共有128位,当超过128位的时候,又重新开始。

例如例子中的数值为70000

70000/128=546余112;

由ascll码表可知,第112位为p;

所以输出结果为p

问题二

the long is: 4464

单精度浮点型转换成短整型的时候为什么输出为4464

我们知道短整型的区间为-32768至32767,两者相减加1等于65536

为什么要加1,是因为还有一个整数0

重点:

同上;

短整型一共有65536位,当超过这么位数时,又重新开始

我们通过题目可以知道

70000-65536=4464

所以输出结果为4464

总结

有高级别向低级别转换,可能会出现数据丢失,这种丢失往往是按照一个一个区间进行丢失,

例如上面讲到的有浮点型转换成字符型的时候是按照ascll码区间进行数据丢失的,

而浮点型转换成短整型时是按照短整型的数据区间进行丢失的。

时间: 2024-07-29 02:14:36

C语言系列之强制类型转换(一)的相关文章

C语言隐式强制类型转换

今天又被精度问题困扰,把最基本的东西忘了. int n = 5; int cnt = 5.5; double sum = (n-cnt);  运算完后sum是 -0.5.不知道什么时候n转换成double类型. 结果搜索了下: 当一个低精度的数据类型和一个高精度的数据类型运算时,运算结果为高精度. C语言默认的隐式转换规则: char,short --> int --> unsigned --> long --> double <-- float. 先挖个坑,考完试补一下.

C语言中将0到1000的浮点数用强制类型转换的方式生成一幅图像

搞过计算机图像的人都知道,图像中的每一个像素通常为一个整型数,它可以分成4个无符号的char类型,以表示其RGBA四个分量.一幅图像可以看做是一个二维整型数组.这里我会生成一个float数组,其数组大小为1000000,刚好1000*1000,数组内的浮点数的数值范围在0到1000.0之间,呈等差数组排列,相邻两数的差为0.001.然后将其每一个浮点数强制转化成一个整型数或三个unsigned char型,以决定像素的RGB三个通道分量,看看其生成的图像是什么样子. 前几天写了一篇文章是在C语言

C语言的 (强制类型转换) 以及 &#39;字符字面值&#39;

C语言的显式/隐式类型转换,都有一个中间变量的存在,原数据的类型.内容都不变. 以下代码,都用GCC编译. 1 #include<stdio.h> 2 3 int main() 4 { 5 printf("%d %d\n", 'a', sizeof((int)'a')); //输出为97,4. sizeof的作用对象为一个int型中间变量 6 7 char c = 255; 8 printf("%d\n", c); //输出-1. char型的c已溢出,

C语言之强制类型转换与指针--#define DIR *((volatile unsigned int *) 0x0022)

强制类型转换形式:(类型说明符) (表达式) 举例说明:1) int a; a = (int)1.9; 2)char *b; int *p; p = (int *) b; //将b的值强制转换为指向整型数据的指针类型,后赋给p 注示:类型说明符和表达式都必须加括号,表达式为单个变量可不加括号. 总结:只要看到(类型说明符) (表达式) 的一定为强制类型转换:如(int *) 0x0022; 再举一例:#define DIR *((volatile unsigned int *) 0x0022)

关于强制类型转换(c语言)

因为今天看的代码中用到了结构体的强制类型转换,就很想了解一下结构体的强制类型转换是怎样的. 一个结构体如下: 在下面这段代码中rbuf->reqCmdBuf是一个空指针,首先将这个空指针赋值给一个uint8_t类型的指针buf. 然后将buf指针强制类型转换为rdma_write_msg_head结构体类型指针. 那再这里是怎么转换的呢? 首先,将buf指针指向的内容的前8个字节赋值给rdma_write_msg_head结构体的rwmh->len变量,然后再 将紧接着的1个字节的内容赋值给r

c语言强制类型转换

一.强制类型转换 printf("3/2+100.5=%f",3/2+100.5);//100.5错误表达 printf ("    (float)3/(float)2 +100.5f=%f \n",    (float)3/(float)2 +100.5f); // (float) 前缀 二.自动类型转换和隐式类型转换 例1: printf ("    3/2+100.5=%f \n",       (float)3/2 +100.5f); p

C语言的强制类型转换

1.什么是强制类型转换:遇到一些类型不同的一些数据之间的表达运算 ,需要将较高的数据类型转换成较低类型时. 2.强制类型的形式: (强制转换的类型)(表达式): 2.强制类型的使用: float a,b; int  c ; c=(int) (a+b);

C语言强制类型转换和浮点数带来的问题

强制类型转换: (int)(6.9)的结果就是6 1/(float)(sum)的结果是浮点数 浮点数带来的问题 float i=6.25,实际上计算机很可能把i存为6.249999.. 用浮点型存放小数,实际存放的是该小数的近似值 存放5.5,实际存放的是5.499999 有一个浮点型变量x,如何判断x的值是否为0 因为0.0000001也可能被存成是0,拿这个数和0.000000000000000000000000001比较,如果较小,那么就是0了 for(i=5.25;i<6.25;i++)

C++强制类型转换:static_cast、dynamic_cast、const_cast、reinterpret_cast

1. c强制转换与c++强制转换 c语言强制类型转换主要用于基础的数据类型间的转换,语法为: (type-id)expression//转换格式1 type-id(expression)//转换格式2 c++除了能使用c语言的强制类型转换外,还新增了四种强制类型转换:static_cast.dynamic_cast.const_cast.reinterpret_cast,主要运用于继承关系类间的强制转化,语法为: static_cast<new_type> (expression) dynam