[英]How do i convert an array with booleans to a byte in Arduino/C/C++?
我是 arduino 编程 (c/c+) 的新手。 并且想将带有布尔值的数组转换为类似字节的数组。 布尔值在这里表示一个按钮。
bool array[] = {0,1,1,0}; // needs to convert to 0b0110
// bool array[] = {1,0,0,0}; // needs to convert to 0b1000
// bool array[] = {true,true,false,true}; // needs to convert to 0b1101
void setup(){
byte b = convert(array); // 0b0110
}
byte convert(bool array[]){
byte b = 0b + 0 + 1 + 1 + 0; // <- wrong stuff here :(
return b;
}
我现在不能重写你所有的代码,但我可以列出一个基本的算法。 我想它会帮助你。
你需要一些东西,要么是循环的,要么是硬编码的(如果你真的只有四位的话)。 为简洁起见,我将调用您的数组a
并且我将对计算进行硬编码,因此它非常清晰。
如果您以位为单位考虑数组的条目,则如下所示:
eights fours twos ones
{ 0 , 1 , 1 , 0 }
您可以使用左移运算符<<
获得这些值,该运算符将每次移位的值加倍。
因此,将数组的最左边成员作为最重要的位,您可以这样做:
shift 3 shift 2 shift 1 no shift
uint8_t b = (a[0] << 3) + (a[1] << 2) + (a[2] << 1) + a[3];
so -> no eights one four one two no ones
6 = 0 + 4 + 1 + 0
你看到图案了吗? 每个较低有效位向左移动一个 LESS,使其总值减半。 这些值的总和是您的字节值( uint8_t
)。
还有其他符号具有相同的效果,但这个是最容易理解的。
现在到布尔值。 您可以使用三元运算符并测试每个元素,如下所示:
uint8_t b = (
(a[0] ? 1 << 3 : 0) +
(a[1] ? 1 << 2 : 0) +
(a[2] ? 1 << 1 : 0) +
(a[3] ? 1 : 0 )
);
一旦你看到这个模式,你就可以用它做各种很酷的按位构造。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.