这两种方法有什么不同吗?

2019-07-31 15:35发布

#pragma vector = PORT2_VECTOR
__interrupt void port2(void)
{
switch(P2IV)
{
case P2IV_P2IFG6:
P2IFG &=~BIT6;
P1OUT ^= BIT0;break; //LED1 亮灭
case P2IV_P2IFG7:
P2IFG &=~BIT7;
P1OUT ^= BIT1;break; //LED2 亮灭
default :break;
}

}


#pragma vector = PORT2_VECTOR
__interrupt void port2(void)
{
if(P1IFG&BIT6){
P2IFG &=~BIT6;
}
if(P1IFG&BIT7){
P2IFG &=~BIT7;
}

}

这两种方法有什么不同吗?上面一种是通过向量中断号进行判断,下面是用中断标志进行判断,在上面的判断中是否需要用软件把中断标志清0
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
12条回答
Unshining
2019-08-01 09:40
在430中,很多中断向量寄存器在被读取后,系统会自动将优先级最高的中断标志硬件位置0.
所以如果有中断向量的话,一般查询中断向量。
具体会不会硬件置0你可以看一下DATASHEET

一周热门 更多>