什么是C语言的中断程序 有什么用啊

在下不才 麻烦讲得通俗一点 详细一点

中断服务程序:处理器处理“急件”,可理解为是一种服务,是通过执行事先编好的某个特定的程序来完成的,这种处理“急件”的程序被称为——中断服务程序。

中央处理器正在处理内部数据时,外界发生了紧急情况,要求CPU暂停当前的工作转去处理这个紧急事件。处理完毕后,再回到原来被中断的地址,继续原来的工作,这样的过程称为中断。实现这一功能的部件称为中断系统,申请CPU中断的请求源称为中断源,单片机的中断系统一般允许多个中断源,当多个中断源同时向CPU请求中断时,就存在一个中断优先权的问题。通常根据中断源的优先级别,优先处理最紧急事件的中断请求源,即最先响应级别最高的中断请求。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-09-25
VC 中不能使用,用 TC
TC本身提供中断程序的接口,函数名记不清了,大概的过程是定义一个函数作为中断的处理程序,然后调用TC自己的函数(可以在DOS.H或BIOS.H中找到,名称与Interrupt有关)
/keys.cpp
// 按键表索引发:
// 首先建立key_table[]作为按键表,然后根据按键扫描码改变key_table[]中的状态,
// 这样key_table[]中所有对应的索引按键即为需要的组合键。
// 以下程序仅对上、下、左、右四个光标键做了组合按键的处理。
// 本程序在Borland C++ 3.1 中调试通过。
#include<dos.h>
#include<conio.h>
#include<stdio.h>

#define ESC 1
#define UP 72
#define _UP 200
#define DOWN 80
#define _DOWN 208
#define LEFT 75
#define _LEFT 203
#define RIGHT 77
#define _RIGHT 205

#define NUM_KEYS 4

#define INDEX_UP 0
#define INDEX_DOWN 1
#define INDEX_LEFT 2
#define INDEX_RIGHT 3
#ifdef __cplusplus
#define __CPPARGS...
#else
#define __CPPARGS
#endif

char * key_table_name[NUM_KEYS]
= {"UP","DOWN","LEFT","RIGHT" };
int key_scan_code; // 键盘扫描码
int key_table[NUM_KEYS]; // 按键表

class INTERRUPT
{// 定义中断类
int INT;
void far interrupt ( *Old_Int)(__CPPARGS);
public:
void BEGIN_INT(int Int,void far interrupt(*New_Int)(__CPPARGS));
void END_INT(void);
};

void INTERRUPT::BEGIN_INT(int Int,void far interrupt(*New_Int)(__CPPARGS))
{// 开始自定义中断处理
INT = Int;
Old_Int = getvect(INT);
setvect(INT,New_Int);
}

void INTERRUPT::END_INT(void)
{// 结束自定义中断处理
setvect(INT,Old_Int);
}

void far interrupt special_key(__CPPARGS)
{// 自定义中断处理函数
int status;
key_scan_code = inp(0x60); // 读键盘扫描码
status = inp(0x61); // 读键盘状态
outp(0x61,status and 0x80); // 置位7并写
outp(0x61,status); // 再写位7
outp(0x20,0x20); // 复位PIC
switch(key_scan_code){ // 记录光标键,设置key_table[]中的状态
// 1为按下键,0为松开键
case UP: key_table[INDEX_UP] = 1; break;
case _UP: key_table[INDEX_UP] = 0; break;
case DOWN: key_table[INDEX_DOWN] = 1; break;
case _DOWN: key_table[INDEX_DOWN] = 0; break;
case LEFT: key_table[INDEX_LEFT] = 1; break;
case _LEFT: key_table[INDEX_LEFT] = 0; break;
case RIGHT: key_table[INDEX_RIGHT] = 1;break;
case _RIGHT:key_table[INDEX_RIGHT] = 0;break;
}
}

void init_key_table(void)
{// 初始化键盘表
register i;
for(i=0;i<NUM_KEYS;i++)
key_table[i]=0;
}

void main(void)
{
int i;
INTERRUPT KEY;
init_key_table();
clrscr();
KEY.BEGIN_INT(9,special_key);
printf("Play with the arrow keys,press ESC to quit.\n");
while(key_scan_code != ESC){
gotoxy(5,5);
printf("Key scancode: %d",key_scan_code);
gotoxy(5,10);
printf("Key name:");
for(i=0;i<NUM_KEYS;i++)
if(key_table[i] != 0) printf("%s",key_table_name[i]);
printf("%10c",' ');
}
printf("\n");
KEY.END_INT();
return;
}
第2个回答  2013-09-25
朋友
打个比方就是今天晚上你知道有客人来
而这里你就是CPU,开门就是CPU要做的事情
而因为你不知道客人多少点来,所以第一你守在门口等,就好比CPU用个循环不断检测一样
第二呢就是等客人按了门铃再去开门,事实上大家都是用的第二种方式
恰巧第二种方式就和中断很像,这里门铃声就是一个中断信号,他要求你停下手中的事,不如做饭做菜出去开门,开完们继续接着做你刚才的事情
就是这样了
相似回答