51单片机学习笔记——第七天:IO扩展(串转并)-74HC595

74HC595芯片介绍:

74HC595 是一个 8 位串行输入、并行输出的位移缓存器,其中并行输出为三 态输出(即高电平、低电平和高阻抗)。

 这是同一类芯片,只是管脚口的命名不同,但是功能还是一样的,现在我们就来介绍管脚功能。

GND/VCC:接地/接高电平,

DS/SER:串行数据输入,

Q0…Q7:并行数据输出,

Q7‘:串行数据输出,主要用来拓展更多的io口,

SHCP/STCP:见下图,(这是我自己的理解,画的尽力了)

官方描述:当 MR 为高电平,OE 为低电平时,数据在 SHCP 上升沿进入移位寄存器,在 STCP 上升沿输出到并行端口。 74595 的数据端: QA--QH: 八位并行输出端,可以直接控制数码管的 8 个段。 QH': 级联输出端。我将它接下一个 595 的 SI 端。 SI: 串行数据输入端。 74595 的控制端说明: /SCLR(10 脚): 低点平时将移位寄存器的数据清零。通常我将它接 Vcc。 SCK(11 脚):上升沿时数据寄存器的数据移位。QA-->QB-->QC-->...-->QH;下 降沿移位寄存器数据不变。(脉冲宽度:5V 时,大于几十纳秒就行了。) RCK(12 脚):上升沿时移位寄存器的数据进入数据存储寄存器,下降沿时存储寄 存器数据不变。通常我将 RCK 置为低点平,当移位结束后,在 RCK 端产生一 个正脉冲(5V 时,大于几十纳秒就行了。我通常都选微秒级),更新显示数据。 /G(13 脚): 高电平时禁止输出(高阻态)。如果单片机的引脚不紧张,用一个引 脚控制它,可以方便地产生闪烁和熄灭效果。比通过数据端移位控制要省时省力。

 

设计如下:

void hc595_write_data(u8 dat)
{
    u8 i=0;
    
    for(i=0;i<8;i++)//循环8次即可将一个字节写入寄存器中
    {
        SER=dat>>7;//优先传输一个字节中的高位
        dat<<=1;//将低位移动到高位
        SRCLK=0;
        delay_10us(1);
        SRCLK=1;
        delay_10us(1);//移位寄存器时钟上升沿将端口数据送入寄存器中    
    }
    RCLK=0;
    delay_10us(1);
    RCLK=1;//存储寄存器时钟上升沿将前面写入到寄存器的数据输出    
}
 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值