#i nclude <absacch> // 包含头文件
#i nclude <reg51h>
#i nclude <intrinsh>
#define Z8279 XBYTE[0xFF82] //定义外部命令口
#define D8279 XBYTE[0xFF80] //定义外部数据口
#define LEDMOD 0x10 //定义显示模式
////powered by coleq@eyoucom /////
#define LEDFEQ 0x38 //定义8279工作频率
#define LEDCLS 0xD1 //清除显示
#define LEDWR0 0x90 //写端口命令
#define READKB 0x40 //读端口命令
#define REIN 0 //定义一些常见的提示信息
#define DONE 1
#define IN1234 2
#define IN2 3
#define IN4 4
#define uchar unsigned char
sbit P11_2=P1^2; //程序运行指示
sbit l1=P1^0; //灯L1控制
sbit l2=P1^1; // 灯L2控制
unsigned char hour1=0,hour2=0,min1=0,min2=0,sec1=0,sec2=0,num_20; //时 分 秒的十位和个位,初值为零
uchar led[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79,0x71};//定义0 到F的键码
uchar beetime[]={8,0,11,30,12,30,17,0}; //定义闹铃时间
void test8279(void); //测试及初始化led函数
void delay(uchar); //延时程序
void view8279(void); //显示数据
void changh(void); //改小时
void changm(void); //改分钟
void changs(void); //改秒
void chang_bee(void); //改闹铃时间
void viewmsg(uchar msg); //显示提示信息,本程序中为空,留作扩展用
bit havekey(void); //判断有无键按下
uchar getkey(void); //读键值
bit view_flag=1; //是否刷新显示标志,默认显示
////powered by coleq@eyoucom /////
void main() //主程序
{uchar keyval,i;
bit temp,bee_temp;
SP=0x60; //堆栈底指针,可省略
test8279();
TMOD=0x01; //计时器初始化
TH0=0x4B; //50ms初值
TL0=0xFC;
IE=0x82;
TR0=1; //启动计时器
num_20=20; //循环20个50ms
l1=0; //灯默认是灭的
l2=0;
////powered by coleq@eyoucom /////
while(1) //循环判断是否是闹铃中的一个,是则坐相应 *** 作,否则跳过
{
for (i=0;i<4;i++)
{ bee_temp=(hour110+hour2)==beetime[i+i] && (min110+min2)==beetime[i+i+1] && sec1==0 && sec2==0;
if (bee_temp)
{ switch(i)
{
case 0: //1亮2秒 ,2灭
l1=1;delay(2);l1=0;break;
case 1: //1亮2秒,2亮
l1=1;l2=1;delay(2);l1=0;break;
case 2: //1亮两秒,2灭
l1=1;l2=0;delay(2);l1=0;break;
case 3: //1亮2秒,2亮10分钟
l1=1;l2=1;delay(2);l1=0;delay(3);delay(3);delay(3);delay(3);delay(3);delay(3);delay(3);l2=0;break;
default: ;
}
}
} //end for
P1_2=~P1_2; //取反
temp=havekey(); //读键
if (temp)
{keyval=getkey();
switch (keyval)
{ case 40 ://change hour
EA=0;
changh();
EA=1;
break;
case 41 ://change minute
EA=0;
changm();
EA=1;
break;
case 42: //change second
EA=0;
changs();
EA=1;
break;
case 43: //change bee time
view_flag=0;
chang_bee();
view_flag=1;
break;
default :
;
}
EA=1;
}
} //end while
}
////powered by coleq@eyoucom /////
void changh(void)
{uchar i,j;
bit flag;
flag=1;
while(flag) //读两个数,直到符合要求,并赋值
{ i=getkey();
j=getkey();
if ((i10+j)<24 ) //判断是否符合要求
{hour1=i; //修改相应值
hour2=j;
viewmsg(DONE);
flag=0;
}
else viewmsg(REIN);
} //end while(flag)
}
void changm(void)
{uchar i,j;
bit flag;
flag=1;
while(flag) //读两个数,直到符合要求,并赋值
{
i=getkey();
j=getkey();
if (i<6 && j<10 ) //判断是否符合要求
{ min1=i; //修改相应值
min2=j;
viewmsg(DONE);
flag=0;
}
else viewmsg(REIN);
}
}
void changs(void)
{uchar i,j;
bit flag;
flag=1;
while(flag) //读两个数,直到符合要求,并赋值
{
i=getkey();
j=getkey();
if (i<6 && j<10 ) //判断是否符合要求
{ sec1=i; //修改相应值
sec2=j;
viewmsg(DONE);
flag=0;
}
else viewmsg(REIN);
}
}
void chang_bee(void)
{ uchar key,h1,h2,s1,s2,temp1,temp2;
bit flag;
viewmsg(IN1234);
key=getkey(); //再次读一个键 1234分别修改第1-4个闹钟时间
while (key<1 || key>4)
{viewmsg(REIN);
key=getkey();
}
////powered by coleq@eyoucom /////
flag=1;
while(flag) //读4两个数,直到符合要求,并赋值
{ viewmsg(IN4);
h1=getkey();
h2=getkey();
s1=getkey();
s2=getkey();
temp1=h110+h2;
temp2=s110+s2;
if (temp1<24 && temp2<60 ) //判断是否符合要求
{beetime[key+key-2]=temp1; //修改相应值
beetime[key+key-1]=temp2;
viewmsg(DONE);
flag=0;
}
else //viewmsg(REIN)
;
}
}
bit havekey(void)
{uchar temp;
temp=Z8279; //读外部端口
return(temp & 0x0F); //返回非零为有键
}
uchar getkey(void)
{uchar temp;
while (1)
if (havekey())
{
Z8279=READKB; //写读数据口命令
temp=D8279; //读数据口
break;
}
return(temp); //返回所读值
}
////powered by coleq@eyoucom /////
void viewmsg(uchar msg) //显示提示信息,本程序中为空,留作扩展用
{ switch (msg)
{ case REIN :
break;
case DONE :
break;
case IN1234:
break;
case IN2:
break;
case IN4:
break;
default : ;
}
}
void delay(uchar n)
{
unsigned int i;
for (i=1;i<20000n;i++)
;
}
void test8279(void)
{uchar i;
Z8279=LEDMOD; //初始化
Z8279=LEDFEQ;
Z8279=LEDWR0;
for (i=0;i<8;i++) //每个led均显示8
D8279=0xFF;
delay(2); //延时
Z8279=LEDCLS; //清零
Z8279=LEDWR0;
}
void view8279(void)
{ if (view_flag) //在正常显示情况下显示各位数字
{Z8279=LEDWR0;
D8279=led[sec2];
D8279=led[sec1];
D8279=0x40;
D8279=led[min2];
D8279=led[min1];
D8279=0x40;
D8279=led[hour2];
D8279=led[hour1];
}
}
void timeint(void) interrupt 1 //中断程序
{
TH0=0x4B;
TL0=0xFC;
num_20--;
if (num_20!=0) return; //没有二十次则返回
if (sec1==5 && sec2==9)
{ sec1=0;
sec2=0;
if (min1==5 && min2==9)
{ min1=0;
min2=0;
if (hour1==2 && hour2==3)
{hour1=0;
hour2=0;
}
else if (hour2==9)
{hour1++;
hour2=0;
}
else hour2++;
}
else if (min2==9)
{min1++;
min2=0;
}
else min2++;
}
else if (sec2==9)
{sec1++;
sec2=0;
}
else sec2++;
num_20=20;
view8279(); //显示数值
}
1 11H 是 17字节 ,不是11字节(16进制)
2 PSP 长度是256字节
3 11H 不是PSP长度
4 正确计算公式
长度:(代码段长度+数据段长度+堆栈段长度+256(PSP长度)+15)/16
5 MOV DX,OFFSET GO
SUB DX,OFFSET START // 这步完成后DX是要驻留的代码长度+数据段长度
MOV CL,4
SHR DX,CL // DX 右移4位(高->低) = /16
ADD DX,11H // (256(PSP长度)+15)/16 = 17(169)
计算机病毒在一定的环境和条件下激活发作,该激活发作是指程序运行。
当运行了带有病毒的宿主文件.exe或是.com更可能是现在流行的.vbs的脚本文件,即激活了病毒的驻留程序。一般驻留程序会占据宿主文件的一部分,因此驻留程序首先会恢复这一部分的宿主程序;其次可能会判断系统内存是否已驻留了病毒,如果已驻留了则转去执行宿主程序,没有则将病毒程序驻留到内存中,驻留完成后再转去执行原宿主程序。
计算机病毒的特点
1、计算机病毒具有很强的自我复制性,能够随着软件、程序的运行而不断进行自我繁殖和复制,这也是判断计算机病毒的一个基本标志。
2、计算机病毒本身具有很强的传染性,计算机病毒会通过各种渠道从已被感染的计算机扩散到未被感染的计算机,如果一台电脑被感染而没有得到及时处理,病毒就会通过各种途径和方式感染另一台电脑。
3、计算机病毒具有很强的破坏性,轻则导致数据的丢失和程序的不正常运转,重则导致机器瘫痪、系统损坏,这也是病毒编制者所欲达到的目的。
4、潜伏性,即病毒会潜伏在电脑一段时间,当条件具备时会自动开启,破坏电脑,而且还可以设定破坏的目标。
5、计算机病毒具有很强的隐蔽性,一般的病毒可以检测出来,但是有一些却检测不出来,变化很多。
比如说WINRAR程序
在执行过程中,你可以选择让它最小化到任务栏
还可以将它转入后台,为使不影响你的其他 *** 作
但是同时它的后台运行仍然会占用你的内存
相同的软件例如:Bitcomet等下载器、网络播放器等等
以上就是关于利用C语言实现的时钟驻留程序全部的内容,包括:利用C语言实现的时钟驻留程序、一个时钟驻留程序中的PSP长度、计算机病毒在一定环境和条件下激活发作该激活发作是指等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)