VC++ 16进制数转换10进制???

在写程序的过程中..虽然用到一个16进制数.
已知 a=100(10进制)
是什么函数 转换呢?
MFC程序 DWORD a=100 类型是这个
不是用来输出的...要在程序内做运算....而需要16进制的

1.如果是输出用,没必要转换吧!fprint里的输出格式中,有%d十进制输出。也有16进进输出,好象是%x,你查一下书吧。而程序编译时,不管是什么进制的,全部自动转为机器码。
2.DWORD,双字,指的是变量a的内存分配,它是一个宏
32-bit unsigned integer.
This type is declared in WinDef.h as follows:
typedef unsigned long DWORD;
//32位无符号的整型。
----------
语法
Visual C++
public:
static String^ Hex(int Number)
参数
Number
类型:System..::.Int32

必选。任何有效的数值表达式或 String 表达式。

返回值
类型:System..::.String

返回表示某数十六进制值的字符串。
===========
一般的数据进制包括十进制,二进制,十六进制.十进制就是我们日常生活用到的数据进制,因此也是我们最熟悉和清楚的;二进制是计算机的基础进制,主要是因为便于用物理器件实现二进制;八进制和十六进制因为和二进制的天然的亲密关系,并且表示比二进制更方便,因而也成为计算机的常用表示方法.

VB中涉及到的数据进制之间的转换函数主要有如下几个:
Hex 函数: 返回代表十六进制数值的 String;
Oct 函数: 返回代表一数值的八进制值的Variant (String);
Cint函数: 强制将一个表达式转换成-32,768 至 32,767的整型;
CLng函数: 强制将一个表达式转换成-2,147,483,648 至 2,147,483,647的长整型;
Cdec函数: 强制将一个表达式转换成Decimal 数据类型;
CDbl函数: 强制将一个表达式转换成Double 数据类型;

以上这些函数是最基本的几个数据进制之间的转换函数,其中以前三个函数最常用,也最有用.从上面几个函数我们可以看到,VB中没有为我们提供专门的函数供我们将表达式或是数据转换成十进制和二进制,不过十进制的转换我们可以通过Cint函数轻松完成,而二进制的实现我们可以通过二进制和八进制,十六进制的关系轻松转换.

下面几个例子为Hex函数和Oct函数以及Cint函数的实例:
(1). A= hex(5) 返回5;
(2). B=hex(10) 返回A
(3). C=hex(23) 返回17
(4). D=oct(5) 返回5
(5). E=oct(10) 返回12
(6). F=oct(23) 返回27
(7). G=Cint(&H17) 返回23
(8) . H=Cint(&O12) 返回10

以上这些函数的应用比较简单,就不多说了,值得一提的是Hex函数和Oct函数返回的都是字符串,如果是想将十六进制或是八进制的字符串变量转换成十进制,可以按如下方法进行:
C=”17” 17为十六进制数值的String
C=”&H” & C
Ic=Cint(C) 返回23

=========
我只是帮你查了一下,没有试过,自已试吧
温馨提示:答案为网友推荐,仅供参考
第1个回答  2020-05-08
#include"stdio.h"
如果没记错的话,那时候我们用的<>,跟编译器有关系吧。
scanf("xx",&mum);
这边要接收参数的嘛,所以xx是你看错了,应该是%x才对
最后一个输出函数,如果你是要输出mum变量,那应该这样写:
printf("mum
10:%d\n",&mum);
另外,main主函数的第一句和第二句都尾巴都没加分号结束语句
最后,这个值是做一个接参和输出,并没有做转10进制的操作,详细的算法你的教程后面应该会说。
希望能给你帮助
第2个回答  2008-05-07
不管显示的是什么格式,在存储空间中都是二进制,格式化输出就可以了
相似回答