_gcvt_s(,,,) && float

来源:互联网 发布:高清网络机顶盒安装 编辑:程序博客网 时间:2024/06/05 03:05

首先,3.4*10^38是什么意思?就是通过普通的运算得出的一个数值吗?如果只有32bit怎么能表示这么大的数字?
------------------------------------------------------------
表示3.4乘以10的38次方,浮点数的存储格式跟整形是不一样的,它通常遵循IEEE-754标准,分为符号位、阶码、规格化尾数等数部份,因此能表示很大的数。



其次,有效数字指的是从左边数第一个非零的数字到右边最尾端的数字,我这样理解对吗?比如123.456,这是六位有效数字,如果是123.4567就超出了float的范围了吗?  
---------------------------------------------------
多于六位有效数字并非超出float的范围,而是表示多于六位的数字不能保证其精确度。




如果我想用4个字节表示在0~42949672.94这个范围的数值,应该用什么类型?好像只有long double可以装下吧?可它的大小远大于4字节了
----------------------------------------------------------------
float就可以了。

 

 

 

errno_t _gcvt_s(   
  char *buffer,
  size_t sizeInBytes,
  double value,
  int digits   
);
第一个参数char*,你把你的number格式化一下char[]再传入
char buf[20];
sprintf_s(buf, sizeof(buf), "%f", number);
..
_gcvt_s(buf, ....);

 


 

 

 

 

字符串与整数、浮点数、无符号整数之间的转换常用函数atof(将字符串转换成浮点型数)表头文件 #include <stdlib.h>定义函数 double atof(const char *nptr);函数说明atof()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结    束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。返回值 返回转换后的浮点型数。附加说明 atof()与使用strtod(nptr,(char**)NULL)结果相同。范例 /* 将字符串a 与字符串b转换成数字后相加*/#include<stdlib.h>main(){char *a=”-100.23”;char *b=”200e-2”;float c;c=atof(a)+atof(b);printf(“c=%.2f/n”,c);}执行c=-98.23////////////////////////////////////////////////////////////////////atoi(将字符串转换成整型数)表头文件 #include<stdlib.h>定义函数 int atoi(const char *nptr);函数说明 atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换,并将结果返回。返回值 返回转换后的整型数。附加说明 atoi()与使用strtol(nptr,(char**)NULL,10);结果相同。范例 /* 将字符串a 与字符串b转换成数字后相加*/#include<stdlib.h>mian(){char a[]=”-100”;char b[]=”456”;int c;c=atoi(a)+atoi(b);printf(c=%d/n”,c);}执行c=356//////////////////////////////////////////////////////////////////////////atol(将字符串转换成长整型数)表头文件 #include<stdlib.h>定义函数 long atol(const char *nptr);函数说明 atol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换, 并将结果返回。返回值 返回转换后的长整型数。附加说明 atol()与使用strtol(nptr,(char**)NULL,10);结果相同。范例 /*将字符串a与字符串b转换成数字后相加*/#include<stdlib.h>main(){char a[]=”1000000000”;char b[]=” 234567890”;long c;c=atol(a)+atol(b);printf(“c=%d/n”,c);}执行c=1234567890////////////////////////////////////////////////////////////////gcvt(将浮点型数转换为字符串,取四舍五入)相关函数 ecvt,fcvt,sprintf表头文件 #include<stdlib.h>定义函数 char *gcvt(double number,size_t ndigits,char *buf);函 数说明 gcvt()用来将参数number转换成ASCII码字符串,参数ndigits表示显示的位数。gcvt()与ecvt()和fcvt()不同的地 方在于,gcvt()所转换后的字符串包含小数点或正负符号。若转换成功,转换后的字符串会放在参数buf指针所指的空间。返回值 返回一字符串指针,此地址即为buf指针。附加说明 范例 #include<stdlib.h>main(){double a=123.45;double b=-1234.56;char *ptr;int decpt,sign;gcvt(a,5,ptr);printf(“a value=%s/n”,ptr);ptr=gcvt(b,6,ptr);printf(“b value=%s/n”,ptr);}执行a value=123.45b value=-1234.56/////////////////////////////////////////////////////////////////////// strtod(将字符串转换成浮点数)表头文件 #include<stdlib.h>定义函数 double strtod(const char *nptr,char **endptr);函 数说明 strtod()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,到出现非数字或字符串结束时('')才结束转 换,并将结果返回。若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。参数nptr字符串可包含正负号、 小数点或E(e)来表示指数部分。如123.456或123e-2。返回值 返回转换后的浮点型数。附加说明 参考atof()。范例 /*将字符串a,b,c 分别采用10,2,16 进制转换成数字*/#include<stdlib.h>mian(){char a[]=”1000000000”;char b[]=”1000000000”;char c[]=”ffff”;printf(“a=%d/n”,strtod(a,NULL,10));printf(“b=%d/n”,strtod(b,NULL,2));printf(“c=%d/n”,strtod(c,NULL,16));}执行a=1000000000b=512c=65535//////////////////////////////////////////////////////////////////////////////////// strtol(将字符串转换成长整型数)相关函数 atof,atoi,atol,strtod,strtoul表头文件 #include<stdlib.h>定义函数 long int strtol(const char *nptr,char **endptr,int base);函数说明strtol()会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如 base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用 16进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束 时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。返回值 返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。附加说明 ERANGE指定的转换字符串超出合法范围。范例 /* 将字符串a,b,c 分别采用10,2,16进制转换成数字*/#include<stdlib.h>main(){char a[]=”1000000000”;char b[]=”1000000000”;char c[]=”ffff”;printf(“a=%d/n”,strtol(a,NULL,10));printf(“b=%d/n”,strtol(b,NULL,2));printf(“c=%d/n”,strtol(c,NULL,16));}执行a=1000000000b=512c=65535/////////////////////////////////////////////////////////// strtoul(将字符串转换成无符号长整型数)相关函数 atof,atoi,atol,strtod,strtol表头文件 #include<stdlib.h>定义函数 unsigned long int strtoul(const char *nptr,char **endptr,int base);函数说明strtoul()会将参数nptr字符串根据参数base来转换成无符号的长整型数。参数base范围从2至36,或0。参数base代表采用的进制 方式,如base值为10则采用10进制,若base值为16则采用16进制数等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符 则会使用16进制做转换。一开始strtoul()会扫描参数nptr字符串,跳过前面的空格字符串,直到遇上数字或正负符号才开始做转换,再遇到非数字 或字符串结束时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。返回值返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。附加说明ERANGE指定的转换字符串超出合法范围。范例参考strtol()toascii(将整型数转换成合法的ASCII 码字符)相关函数isascii,toupper,tolower表头文件#include<ctype.h>定义函数int toascii(int c)函数说明toascii()会将参数c转换成7位的unsigned char值,第八位则会被清除,此字符即会被转成ASCII码字符。返回值将转换成功的ASCII码字符值返回。范例#include<stdlib.h>main(){int a=217;char b;printf(“before toascii () : a value =%d(%c)/n”,a,a);b=toascii(a);printf(“after toascii() : a value =%d(%c)/n”,b,b);}执行before toascii() : a value =217()after toascii() : a value =89(Y)////////////////////////tolower(将大写字母转换成小写字母)相关函数 isalpha,toupper表头文件 #include<stdlib.h>定义函数 int tolower(int c);函数说明 若参数c为大写字母则将该对应的小写字母返回。返回值 返回转换后的小写字母,若不须转换则将参数c值返回。附加说明   范例 /* 将s字符串内的大写字母转换成小写字母*/#include<ctype.h>main(){char s[]=”aBcDeFgH12345;!#$”;int i;printf(“before tolower() : %s/n”,s);for(i=0;I<sizeof(s);i++)s=tolower(s);printf(“after tolower() : %s/n”,s);}执行before tolower() : aBcDeFgH12345;!#$after tolower() : abcdefgh12345;!#$toupper(将小写字母转换成大写字母)相关函数 isalpha,tolower表头文件 #include<ctype.h>定义函数 int toupper(int c);函数说明若参数c为小写字母则将该对映的大写字母返回。返回值 返回转换后的大写字母,若不须转换则将参数c值返回。范例 /* 将s字符串内的小写字母转换成大写字母*/#include<ctype.h>main(){char s[]=”aBcDeFgH12345;!#$”;int i;printf(“before toupper() : %s/n”,s);for(i=0;I<sizeof(s);i++)s=toupper(s);printf(“after toupper() : %s/n”,s);}执行before toupper() : aBcDeFgH12345;!#$after toupper() : ABCDEFGH12345;!#$ 

 

原创粉丝点击