可能导致此问题的原因之一是Timer1在输入捕获中断期间无法正常工作。如果等到捕获事件发生后再进行操作,在未启用TIMER1_CAP_VECT中断的情况下,可能会解决此问题。下面是一段示例代码,可解决AVR ATMEGA328在TIMER1_CAP_VECT中断中出现的问题。
#include
#include
volatile unsigned long count = 0;
ISR(TIMER1_CAPT_vect){
cli(); //关闭所有中断
TCCR1B = 0; // 停止定时器
count = ICR1; //读取输入捕获寄存器的值
TCNT1 = 0; // 复位计数器
TCCR1B |= (1<
在上面的示例代码中,我们在定时器输入捕获中启用了一个中断,并在此中断中进行所有处理。我们关闭了所有中断,以确保在处理计时器状态寄存器和捕获寄存器时不会引起冲突。我们停止了计时器,并读取输入捕获