strtemp.Format("%02d",bt); 如果bt是十六进制数6000,那么程序中的strtemp是96XXX,
而实际的十进制应该是24576.怎样在程序中实现把十六进制数6000变成十进制的24576 。
又怎样变成245.76
解决方案 »
- 关于VC6.0中MSFlexGrid动态生成以及在其中添加编辑框问题
- 在dll里面,如何得到调用者exe的HINSTANCE? 用Win32api.
- 如何设置窗口焦点
- VC如何安装第三方提供的控件?
- 散分顺便找工作!!!
- 程序怎样得到文件的图标?(菜鸟求助)
- 在VC中如何用ODBC的方式调用ORACLE的存储过程?(急)
- 高手請進﹐關于com組件
- 我在调试程序时,遇到memory check error at 0x021F56BC = 0xC4, should be 0xFD.这样的错误,怎么回事?
- 我该何去何从???
- 寻求高手:如何向具有滚动条风格的窗口发送滚动条滚动的消息
- 关于vc与pdf文件
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 ”,strtol(a,NULL,10));
printf(“b=%d ”,strtol(b,NULL,2));
printf(“c=%d ”,strtol(c,NULL,16));
}
执行
a=1000000000
b=512
c=65535
又怎样变成245.76
...直接除以100.0 ???LZ??
strtod(将字符串转换成浮点数)
相关函数
atoi,atol,strtod,strtol,strtoul
表头文件
#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 ”,strtod(a,NULL,10));
printf(“b=%d ”,strtod(b,NULL,2));
printf(“c=%d ”,strtod(c,NULL,16));
}
执行
a=1000000000
b=512
c=65535
memcpy(&a,bt,2);
int b=htons(a);
strtemp.Format("%d",b);
或
bt[ 1 ] << 8 + bt[ 0 ]
error C2065: 'htons' : undeclared identifier
int inum = bt[0]*0x100 + bt[1];
bt = 0x6000;
strtemp.Format( "%02d ",bt);
BYTE bt[2];
bt[0] = 0x00;
bt[1] = 0x60;
int aa;
aa = bt[1] << 8 + bt[0];