逻辑运算左移与右移

左移与右移操作格式

  • 左移运算(<<): 操作数 << 移动的位数
  • 右移运算(>>): 操作数 >> 移动的位数

基本概念

  • 左移运算 (<<) : 将二进制数向左移动指定位数,低位补0,注意对于有符号,最高位为符号位,其不参与运算。
  • 右移运算 (>>) : 将二进制数向右移动,高位补0,注意对于有符号,最高位为符号位,其不参与运算。

基本运算示例

  • 无符号右移运算(>>)
    • 比如对于二进制数 0000 1010,右移2位结果为0000 0010,高位直接补0。
  • 有符号右移运算(>>)
    • 比如对于二进制数 1000 1010(补码表示-6),右移2位结果为 1000 0010(-2),高位保持不变。
  • 无符号左移运算(<<):
    • 比如0000 1010左移2位结果为 0010 1000,低位补0。
  • 有符号左移运算(<<)
    • 比如1000 1010(补码表示-6)左移2位结果为1010 1000(-24)。

左移右移等效位乘除法运算

  • 对于左移操作:
    - 当我们左移一个数n位时,实际上就是将这个数乘以2的n次方。这是因为每向左移一位,相当于在原数的基础上乘以2。
    - 例如,将二进制数 1010 左移2位等同于将其乘以 2的2次方,即得到 101000,这相当于将其乘以4。
  • 对于右移操作:
    - 当我们右移一个数n位时,实际上就是将这个数除以2的n次方,取整数部分。右移时,左侧空出的位将由符号位填充,这意味着对于正数是用0填充,对于负数是用1填充。
    - 例如,将二进制数 1010 右移2位等同于将其除以 2的2次方,即得到 0010,这相当于将其除以4。

流水灯实现

流水灯程序实现

  • 延时函数
    • 定义函数 delay_ms
    • 使用循环实现延时功能
  • GPIO 初始化
    • 使能 GPIOD 时钟
    • 设置 GPIOD 引脚为输出模式
  • 流水灯控制
    • for 循环控制流水灯
    • 使用左移操作控制引脚

#include "stm32f4xx.h"

void delay_ms(int delay_time) {
    for (int i = 0; i < delay_time * 1000; i++) {
        // 延时函数,根据实际情况调整延时时间
    }
}

int main(void) {
    // 初始化GPIO
    RCC->AHB1ENR |= RCC_AHB1ENR_GPIODEN;  // 使能GPIOD时钟
    GPIOD->MODER &= ~(GPIO_MODER_MODE12 | GPIO_MODER_MODE13 | GPIO_MODER_MODE14 | GPIO_MODER_MODE15);  // 清除之前的设置
    GPIOD->MODER |= (GPIO_MODER_MODE12_0 | GPIO_MODER_MODE13_0 | GPIO_MODER_MODE14_0 | GPIO_MODER_MODE15_0);  // 设置为输出模式

    while (1) {
        for (int i = 0; i < 4; i++) {
            GPIOD->ODR = 1 << (12 + i);  // 依次左移控制每个引脚
            delay_ms(200);  // 延时一段时间
        }
    }
}


  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值