写嵌入式的程序员,成天跟二进制/16进制打交道,
某些时候,您可能会想,能不能直接给出一个二进制值呢,
比如
unsigned int n = 11110000b; /* 11110000b表示二进制的一个值 */
在C++11之前,做不到这一点,只好老实一点,比如用16进制写
unsigned int n = 0xF0;
C++11就不一样了,可以自定义一个后缀的标识来处理这件事。
这个例子里,可以自定义一个跟后缀b相关联的函数
unsigned int operator "" b(const char *binstr) { ..... }
这个函数,它的输入参数就是 11110000这样的字符串,
把当它二进制处理后,输出一个值为0xF0的整数。
有了这个函数,后面的代码就可以这样直接写了,非常方便。
- #include <stdio.h>
-
#include <stdexcept>
-
-
unsigned int operator "" b(const char *binstr)
-
{
-
size_t len = 0;
-
unsigned int v = 0;
-
for(; *binstr != '\0'; ++binstr)
-
{
-
/* 检测二进制数字的长度,是否超过一个32 bit ? */
-
if(len >= sizeof(v) * 8)
-
throw std::runtime_error("too long length of binary value");
-
-
/* 移位赋值,将字符串当作二进制数转成整数 */
-
v <<= 1;
-
if(*binstr == '1')
-
v |= 1;
-
else if(*binstr == '0')
-
; /* Do nothing */
-
else
-
throw std::runtime_error("invalid binary value format");
-
}
-
return v;
-
}
-
-
int main()
-
{
-
unsigned int n = 11110000b;
-
printf("%x\n", n); /* 输出 f0 */
-
-
return 0;
-
}
但是哦,理想是美好的,现实是残酷的,
要使用这么绚丽的功能,恐怕还要加以时日,等待编译器厂家的进步。
上面这段代码,也是笔者随意写的,未经任何编译器证实:)
笔者试验gcc 4.5.2 和 VC 2010支持的C++11功能,
都还不支持这种自定义数据的写法。(2011/11/17日试验)
(转载请注明来自:nuvoton-m0.com)
阅读(1567) | 评论(0) | 转发(0) |