gpt4 book ai didi

c - 使用数组存储引脚位

转载 作者:行者123 更新时间:2023-12-01 13:47:48 25 4
gpt4 key购买 nike

只是想确保我在正确的轨道上。我正在尝试将大量 6 位字节存储到一个数组中,以使用我的 PIC18F2550 控制并行设备。

我的数组:

char pins[4] = {
000000, //0
000001, //1
000010, //2
000011, //3
000100 //4
}

稍后在我的代码中,我希望能够输入如下命令“设置 3”会将引脚 RB0-RB5 分别设置为 000011。

伪代码:

if command="Set 3" then find pins[3]{
LATBbits.LATB0 = pins[3][0];
LATBbits.LATB1 = pins[3][1];
LATBbits.LATB2 = pins[3][2];
LATBbits.LATB3 = pins[3][3];
LATBbits.LATB4 = pins[3][4];
LATBbits.LATB5 = pins[3][5];
}

这将给出:

{
LATBbits.LATB0 = 0;
LATBbits.LATB1 = 0;
LATBbits.LATB2 = 0;
LATBbits.LATB3 = 0;
LATBbits.LATB4 = 1;
LATBbits.LATB5 = 1;
}

这是一种合适的创建方式吗?我在正确的轨道上吗?您是否有更好的方法来创建高效阵列来控制具有许多设置的 6 位并行设备?

谢谢大家!

最佳答案

由于多种原因,您走错了路。

Wrong track #1:在您的数组定义中,C 编译器不会将像 000011 这样的值解释为二进制。由于前导零,它将解释为八进制。所以 000011 是八进制,即十进制的 9。所以你的数组包含值零、一、八、九和六十四。

您可以编写类似 0b000011 的值来告诉编译器该值是二进制的。但这不是标准的 C,许多 C 编译器不支持它。您必须检查您的编译器是否支持该约定。

Wrong track #2:您的意图是创建一个包含值 0、1、2、3、4 的数组。请注意,数组中每个成员的值都等于索引该成员的。这个数组毫无意义。只需直接使用索引值,而不是作为数组的索引,数组只返回原始索引值。

Wrong track #3:当您设置 LATBbits.LATB0 = pins[3][0]; 时,您正在尝试引用一个一维数组,就好像它是一个二维数组。你不能那样做。您不能在值上使用额外的数组维度说明符来从该值中提取一点。 C 语言不是这样工作的。

Wrong track #4:仅仅因为 LATBbits 定义了位域,并不意味着您不能直接设置 LATBbits。换句话说,您不必单独设置这些位。您只需直接设置 LATBbits 即可一次设置所有位。

Wrong track #5:您写道 LATB4 和 LATB5 将设置为 1。但这些不是 LATBbits 的最低有效位。 LATB0 和 LATB1 是最低有效位,当您设置 LATBBits = 0b000011 时将设置这些位。

正确的轨道:看一下 LATBbits 的定义。我在网上找到了这个,确保它与你的头文件中的定义相匹配。

//==============================================================================
// LATB Bits

extern __at(0x0F8A) __sfr LATB;

typedef struct
{
unsigned LATB0 : 1;
unsigned LATB1 : 1;
unsigned LATB2 : 1;
unsigned LATB3 : 1;
unsigned LATB4 : 1;
unsigned LATB5 : 1;
unsigned LATB6 : 1;
unsigned LATB7 : 1;
} __LATBbits_t;

extern __at(0x0F8A) volatile __LATBbits_t LATBbits;

#define _LATB0 0x01
#define _LATB1 0x02
#define _LATB2 0x04
#define _LATB3 0x08
#define _LATB4 0x10
#define _LATB5 0x20
#define _LATB6 0x40
#define _LATB7 0x80

我很确定您的整个示例伪代码都可以简化为这个。

if command="Set 3" then {
LATB = 3;
}

不需要数组,也不需要单独设置位。您可以设置 LATBLATBbits(它们是同一内存映射寄存器的两个不同名称)。设置 LATB(或 LATBbits)= 3 将导致 LATB0 和 LATB1 被设置,而其他位被清除。

如果 LATB 值与命令值不匹配,那么使用数组查找 LATB 值可能会有用。例如,假设您确实希望在 command 为 3 时设置 LATB4 和 LATB5。在这种情况下,您应该使用 _LATBx 定义来定义数组,如下所示:

char pins[] = {
0, // All bits clear
(_LATB0), // Bit 0 set
(_LATB1), // Bit 1 set
(_LATB4 | _LATB5), // Bit 4 and Bit 5 set
(_LATB2) // Bit 2 set
}

然后您可以像这样从数组中设置 LATB。

LATB = pins[3];

关于c - 使用数组存储引脚位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34537735/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com