memset对于int、long long、float、double 的极值怎么清
来源:互联网 发布:笑傲江湖ol捏脸数据 编辑:程序博客网 时间:2024/05/22 12:37
出处[辗转山河弋流歌 by 空灰冰魂]
原网址:blog.csdn.net/vmurder/article/details/46537613
int
”较“的原则:加法不爆。
极大值:0x7f
较大值:0x3f
较小值:0xc0
极小值:0x80
long long
”较“的原则:加法不爆。
极大值:0x7f
较大值:0x3f
较小值:0xc0
极小值:0x80
float
”较“的原则:保证一定位精度。
7f以上一直到be都是-0 (实际上是一个很小的>-1.0的负数)
极大值:0x7f
较大值:0x4f
较小值:0xce
极小值:0xfe
0xff是 -1.#QNAN0000…… (-∞?)
double
”较“的原则:保证一定位精度。
极大值:0x7f
较大值:0x43
较小值:0xc2
极小值:0xfe
实验代码:
#include <cstdio>#include <cstring>#include <iostream>#include <algorithm>#define N 5using namespace std;int a[N];long long b[N];float c[N];double d[N];void _int(){ puts(""); puts("int:"); puts(""); memset(a,0x7f,sizeof a);printf("%d\n",a[0]); memset(a,0x80,sizeof a);printf("%d\n",a[0]); memset(a,0x81,sizeof a);printf("%d\n",a[0]); puts(""); memset(a,0xbf,sizeof a);printf("%d %d\n",a[0],a[0]*2); memset(a,0xc0,sizeof a);printf("%d %d\n",a[0],a[0]*2); memset(a,0xc1,sizeof a);printf("%d %d\n",a[0],a[0]*2); puts(""); memset(a,0x3e,sizeof a);printf("%d %d\n",a[0],a[0]*2); memset(a,0x3f,sizeof a);printf("%d %d\n",a[0],a[0]*2); memset(a,0x40,sizeof a);printf("%d %d\n",a[0],a[0]*2); puts(""); memset(a,0x7e,sizeof a);printf("%d\n",a[0]); memset(a,0x7f,sizeof a);printf("%d\n",a[0]); memset(a,0x80,sizeof a);printf("%d\n",a[0]);}void _long(){ puts(""); puts("long long:"); puts(""); memset(b,0x7f,sizeof b);printf("%I64d\n",b[0]); memset(b,0x80,sizeof b);printf("%I64d\n",b[0]); memset(b,0x81,sizeof b);printf("%I64d\n",b[0]); puts(""); memset(b,0xbf,sizeof b);printf("%I64d %I64d\n",b[0],b[0]*2); memset(b,0xc0,sizeof b);printf("%I64d %I64d\n",b[0],b[0]*2); memset(b,0xc1,sizeof b);printf("%I64d %I64d\n",b[0],b[0]*2); puts(""); memset(b,0x3e,sizeof b);printf("%I64d %I64d\n",b[0],b[0]*2); memset(b,0x3f,sizeof b);printf("%I64d %I64d\n",b[0],b[0]*2); memset(b,0x40,sizeof b);printf("%I64d %I64d\n",b[0],b[0]*2); puts(""); memset(b,0x7e,sizeof b);printf("%I64d\n",b[0]); memset(b,0x7f,sizeof b);printf("%I64d\n",b[0]); memset(b,0x80,sizeof b);printf("%I64d\n",b[0]);}void _float(){ puts(""); puts("float:"); puts(""); memset(c,0xfd,sizeof c);printf("%f\n",c[0]); memset(c,0xfe,sizeof c);printf("%f\n",c[0]); memset(c,0xff,sizeof c);printf("%f\n",c[0]); puts(""); memset(c,0xcd,sizeof c);printf("%f %f\n",c[0],c[0]*2); memset(c,0xce,sizeof c);printf("%f %f\n",c[0],c[0]*2); memset(c,0xcf,sizeof c);printf("%f %f\n",c[0],c[0]*2); puts(""); memset(c,0x4e,sizeof c);printf("%f %f\n",c[0],c[0]*2); memset(c,0x4f,sizeof c);printf("%f %f\n",c[0],c[0]*2); memset(c,0x50,sizeof c);printf("%f %f\n",c[0],c[0]*2); puts(""); memset(c,0x7e,sizeof c);printf("%.15f\n",c[0]); memset(c,0x7f,sizeof c);printf("%.15f\n",c[0]); memset(c,0x80,sizeof c);printf("%.15f\n",c[0]);}void _double(){ puts(""); puts("double:"); puts(""); memset(d,0xfd,sizeof d);printf("%lf\n",d[0]); memset(d,0xfe,sizeof d);printf("%lf\n",d[0]); memset(d,0xff,sizeof d);printf("%lf\n",d[0]); puts(""); memset(d,0xc1,sizeof d);printf("%lf %lf\n",d[0],d[0]*2); memset(d,0xc2,sizeof d);printf("%lf %lf\n",d[0],d[0]*2); memset(d,0xc3,sizeof d);printf("%lf %lf\n",d[0],d[0]*2); puts(""); memset(d,0x42,sizeof d);printf("%lf %lf\n",d[0],d[0]*2); memset(d,0x43,sizeof d);printf("%lf %lf\n",d[0],d[0]*2); memset(d,0x44,sizeof d);printf("%lf %lf\n",d[0],d[0]*2); puts(""); memset(d,0x7e,sizeof d);printf("%lf\n",d[0]); memset(d,0x7f,sizeof d);printf("%lf\n",d[0]); memset(d,0x80,sizeof d);printf("%lf\n",d[0]);}int main(){ _int(); _long(); _float(); _double();}
阅读全文
0 0
- 【自用】 memset对于int、long long、float、double 的极值怎么清
- 【自用】 memset对于int、long long、float、double 的极值怎么清
- memset对于int、long long、float、double 的极值怎么清
- int,long,long,double,float的范围
- int,long,long long,float,double范围
- int、long、longlong、float、double、long double的范围
- short、int、long、long long, float、double、 long double
- float double int long long int的精度
- int,long,float,double 的最小值,最大值
- short int、long、float、double
- Int,long,float,double类型
- short,int,float,long,double
- 打印数据的二进制格式 float double int char long
- int long longlong float double类型数据的范围
- int、long转换为float、double的区别
- byte[]与short、int、long、float、double的互换
- byte short int long float double
- int、long、float、double最大最小值
- mysql更改引擎(InnoDB,MyISAM)的方法
- Oracle高性能SQL语句
- COM初学(二) 编写和使用一个简单的COM
- springMVC 拦截器
- 使用Mybaties xml的增删改查
- memset对于int、long long、float、double 的极值怎么清
- 反思
- 【技术贴收集】微信开发 多图片上传接口异常日志
- Java 输入输出流
- COM初学 (一) 理论入门
- Oracle、SQL Server、MySQL、pointbase、DB2、MongoDB、Redis、memcached简介及端口
- 使用JSON的小bug
- https://wenku.baidu.com/view/f3854ed7b14e852458fb575f.html
- C++学习之路(15)---C++ 资源大全(太全了)