0x0A在C++中的含义是什么?我应该如何解释或读取这样的十六进制值?
if (version < 760 || version > 760){
disconnectClient(0x0A, STRING_CLIENT_VERSION);
}
uint32_t accnumber = msg.GetU32();
std::string password = msg.GetString();
if(!accnumber){
disconnectClient(0x0A, "You must enter your account number.");
return false;
}
Run Code Online (Sandbox Code Playgroud)
Abe*_*bel 28
如前所述,0x0A等于十进制10(十).这等于LF(换行)的ASCII码,这是许多系统上的换行符.但在你的情况下,你使用DisconnectClient,需要一个ULONG.无论你是通过0xA还是10无所谓.
在这种情况下,此数字的含义是客户端连接的接口.
编辑:再次查看您的代码,您的disconnectClient功能与MSDN上的功能不同.如果它是用户定义的方法,找出其含义0x0A需要检查该方法本身或其文档(尽管它可能只是"真实"的存根DisconnectClient,并简单地传递参数).
编辑:如果您想知道这里的所有答案者如何知道十六进制0x0A等于十进制10,请继续阅读:
十六进制数是base-16(hexa = 6,deca = 10).我们现在习惯于基数10,但历史表明,基数为20(法国仍有quatre-vingt),基数为5(俄罗斯),其他人甚至在二元(基数为2)的数字变得普遍之前就被使用过了.用于电脑.Base-16就像10-base一样,但现在你没有10个手指,而是16个手指.
计算机只能以位为单位思考,四位(半字节)可以使数字为0-15.为了便于读取和写入位,使用了十六进制表示法.这将AF添加到无处不在的数字0-9,其中A等于10,B等于11,直到F等于15.
在编程语言中是很常见的以数字开头x,0x或&h(取决于语言)来表示一个十六进制数.与十进制数一样,前导零可以忽略.尾随零有明显的含义.
那么,你会如何从十六进制到十进制数?每个数字应乘以16的幂,而不是十进制的10的幂.有一个简单的通用公式可以从任何base-X到任何base-Y,但是它适用于从base-16到base-10.
16^pos,其中pos ==位置以十六进制数表示,最右边的位置为零数量0x8B20变为:
8 * 16^3 = 8 * 4096 = 32768
B * 16^2 = 11 * 256 = 2816
2 * 16^1 = 2 * 16 = 32
0 * 16^0 = 0 * 1 = 0
------- +
35616
我希望,手工操作相当繁琐,但你会得到漂移.如果您有Windows,请在运行窗口或搜索框(Vista,W7)中键入Calc,然后单击视图>科学.现在您可以键入十六进制数字(按F5)并在十进制(F6),八进制(F7)和二进制(F8)之间切换.
关于数字及其基数还有很多话要说,但如果你需要更多,我建议你看一下数学论坛常见问题,或维基百科(更一般).要在许多基础之间进行转换,请尝试使用此在线base-X计算器.
更新:添加了关于理解和转换十六进制数的部分,认为它可能适用;-)