// 强制类型转换.cpp : Defines the entry point for the console application.
//
lkjh
#include "stdafx.h"
#include <stdio.h>
//强制类型转换
int main1(int argc, char* argv[])
{
//int a=10.0f;//隐藏类型转换
//printf("%d\n",a);
printf("%d\n",1.0);//把double按照%d来输出解析出现错误导致输错
printf("%d\n",sizeof(1.0));//1.0相当于一个double类型
printf("%d\n",1.0);
printf("%d\n",(int)1.0);//就用到了强制类型转换
printf("%f\n",1);//1按照float类型来解析就会输出错误
printf("%f\n",(float)1);
int x=100;
printf("%f\n",(float)x);
printf("%d\n",x);
/*
强制类型转换时会有一个中间变量来保存 不会改变当前x的值
*/
return 0;
}
//类型转换精度的损失
void main2()
{
int x=3.6;//3.6是double类型赋值给int类型就会出现精度的损失
printf("%d\n",x);//精度的损失 double 占字节较大有精度的损失
//实数向整数转换会有精度的损失
float y;
y=3.6f;
x=(int)y;//实数转换成整数会导致精度的损失
printf("%d\n",x);
}
//数据的溢出
#include <limits.h>
void main()
{
// ch占1个字节 8个位
// 1111 1111 两进制转换就是十进制
unsigned char ch=255;
printf("%d\n",ch);
printf("%d\n",UCHAR_MAX);//输出最大的unsigned char的最大数
int max=256;
ch=max;
printf("%d\n",ch);//数据的溢出 unsigned char最大255
//256-256=0;//输出的结果是0
}
//
lkjh
#include "stdafx.h"
#include <stdio.h>
//强制类型转换
int main1(int argc, char* argv[])
{
//int a=10.0f;//隐藏类型转换
//printf("%d\n",a);
printf("%d\n",1.0);//把double按照%d来输出解析出现错误导致输错
printf("%d\n",sizeof(1.0));//1.0相当于一个double类型
printf("%d\n",1.0);
printf("%d\n",(int)1.0);//就用到了强制类型转换
printf("%f\n",1);//1按照float类型来解析就会输出错误
printf("%f\n",(float)1);
int x=100;
printf("%f\n",(float)x);
printf("%d\n",x);
/*
强制类型转换时会有一个中间变量来保存 不会改变当前x的值
*/
return 0;
}
//类型转换精度的损失
void main2()
{
int x=3.6;//3.6是double类型赋值给int类型就会出现精度的损失
printf("%d\n",x);//精度的损失 double 占字节较大有精度的损失
//实数向整数转换会有精度的损失
float y;
y=3.6f;
x=(int)y;//实数转换成整数会导致精度的损失
printf("%d\n",x);
}
//数据的溢出
#include <limits.h>
void main()
{
// ch占1个字节 8个位
// 1111 1111 两进制转换就是十进制
unsigned char ch=255;
printf("%d\n",ch);
printf("%d\n",UCHAR_MAX);//输出最大的unsigned char的最大数
int max=256;
ch=max;
printf("%d\n",ch);//数据的溢出 unsigned char最大255
//256-256=0;//输出的结果是0
}