蓝桥杯单片机组第十一届国赛试题_十一届蓝桥杯单片机决赛题目

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注运维)
img

正文

	case 7:P2=(P2&0x1f)|0xe0;break;
}

}
void system_init()
{
select573(4);P0=0xff;
select573(5);P0=0x00;
select573(6);P0=0xff;
select573(7);P0=0xff;
}
void timer0init()
{
TMOD=0x00;
TH0=(65536-1000)/256;
TL0=(65536-1000)%256;
TF0=0;
ET0=1;
EA=1;
TR0=1;
}
void display()
{
select573(7);P0=0xff;
select573(6);
P0=1<<dscom;
select573(7);
if((dscom6 && ym_mode1 && shuju_mode2) ||(ym_mode1 && shuju_mode3 && dscom2))
{
P0=tab[dsbuff[dscom]]&0x7f;
}
else
P0=tab[dsbuff[dscom]];

P2&=0x1f;
P0=0xff;
if(++dscom==8)
	dscom=0;

}

//=按键函数=============================================================================================
void key_scan()
{
unsigned char i;
static unsigned char keyout=0;
keybuff[keyout][0]=keybuff[keyout][0]<<1|l0;
keybuff[keyout][1]=keybuff[keyout][1]<<1|l1;
keybuff[keyout][2]=keybuff[keyout][2]<<1|l2;
keybuff[keyout][3]=keybuff[keyout][3]<<1|l3;
for(i=0;i<4;i++)
{
if((keybuff[keyout][i]&0x0f)==0x00)
{
keysta[keyout][i]=0;
}
else if((keybuff[keyout][i]&0x0f)==0x0f)
{
keysta[keyout][i]=1;
}
}
keyout++;
if(keyout>=4)
keyout=0;
switch(keyout)
{
case 0:h0=0;h3=1;break;
case 1:h1=0;h0=1;break;
case 2:h2=0;h1=1;break;
case 3:h3=0;h2=1;break;
}

}
void key_handle()
{
unsigned char i,j;
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
{
if(keyback[i][j]!=keysta[i][j])
{
if(keysta[i][j]==0)
{
keyaction(keycode[i][j]);
}
else if(keysta[i][j]==1)
{
keysong(keycode[i][j]);
}
keyback[i][j]=keysta[i][j];
}
}
}
}

void keyaction(unsigned char dat)
{
//界面按键====
if(dat4)
{
if(ym_mode
1)
{
ym_mode=2;//参数界面
canshu_mode=1;
}
else if(ym_mode2)
{
ym_mode=1;//数据界面
shuju_mode=1;
}
}
//切换按键
==
if(dat5)
{
if(ym_mode
1)//数据界面
{
if(shuju_mode1)
{
shuju_mode=2; //温度数据显示
}
else if(shuju_mode
2)
{
shuju_mode=3; //亮暗状态显示
}
else if(shuju_mode3)
{
shuju_mode=1; //时间数据显示
}
}
else if(ym_mode
2) //参数界面
{
if(canshu_mode1)
{
canshu_mode=2;//温度参数P2
}
else if(canshu_mode
2)
{
canshu_mode=3;//指示灯参数P3
}
else if(canshu_mode3)
{
canshu_mode=1;//时间参数P1
}
}
}
if(dat
8)
{
if(ym_mode2)
{
if(canshu_mode
1)
{
shijian_canshu–;
}
else if(canshu_mode2)
{
wendu_canshu–;
}
else if(canshu_mode
3)
{
led_canshu–;
if(led_canshu<1)
led_canshu=8;
}
}
}
if(dat9)
{
if(ym_mode
2)
{
if(canshu_mode1)
{
shijian_canshu++;
}
else if(canshu_mode
2)
{
wendu_canshu++;
}
else if(canshu_mode==3)
{
led_canshu++;
if(led_canshu>8)
{
led_canshu=1;
}
}
}
}

}
void keysong(unsigned char dat)
{
if(dat==9)
{

}

}
//LED函数=============================================================================================
unsigned char led_number=0xff;

void led_IRQ()
{
P0=0xff;
select573(4);
P0=led_number;
P2&=0x1f;
}
void led_function()
{
// L1
if((((clk[2]/16)*10+clk[2]%16) % shijian_canshu==0) && ((clk[2]/16)10+clk[2]%16) % 8!=0&&ad_value>70)
{
led_number &= 0xfe;
}
else
{
led_number |= 0x01;
}
// L2
if(tempture<wendu_canshu
10)
{
led_number &= 0xfd;
}
else
{
led_number |= 0x02;
}
// L3 有延时,放中断里了

//L4
if(ad_value<40)
{
	if(led_canshu==4)
	{
		led_number &= 0xf7;
	}
	else
	{
		led_number |= 0x08;
	}
	if(led_canshu==5)
	{
		led_number &= 0xef;
	}
	else
	{
		led_number |= 0x10;
	}
	if(led_canshu==6)
	{
		led_number &= 0xdf;
	}
	else
	{
		led_number |= 0x20;
	}
	if(led_canshu==7)
	{
		led_number &= 0xbf;
	}
	else
	{
		led_number |= 0x40;
	}
	if(led_canshu==8)
	{
		led_number &= 0x7f;
	}
	else
	{
		led_number |= 0x80;
	}
}
else
{
	led_number |= 0x08;
	led_number |= 0x10;
	led_number |= 0x20;
	led_number |= 0x40;
	led_number |= 0x80;
}

}
//=中断函数=============================================================================================
unsigned int l3_count=0;
unsigned int l3_l_count=0;
void timer0()interrupt 1
{
led_IRQ();
display();
yemian();
key_scan();
//=温度
wendu_count++;
if(wendu_count>=250)
{
wendu_count=0;
wendu_bit=1;
}
//=时间
clk_count++;
if(clk_count>=250)
{
clk_count=0;
clk_bit=1;
}
//=ad采集
ad_count++;
if(ad_count>=250)
{
ad_count=0;
ad_bit=1;
}
//=led3=
if(ad_value<50)
{
l3_count++;
if(l3_count>=3000)
{
l3_l_count=0;
led_number &= 0xfb;
}
}
else
{
l3_l_count++;
if(l3_l_count>=3000)
{
l3_count=0;
led_number |= 0x04;
}
}
}
//=main函数
===============================================================

void main()
{
system_init();
timer0init();
ds1302_init();
while(1)
{
key_handle();
led_function();
//=温度
if(wendu_bit
1)
{
wendu_bit=0;
tempture=(unsigned int)read_tempture();
}
//=时间
if(clk_bit
1)
{
clk_bit=0;
read_ds1302();
}
//=ad采集
if(ad_bit
1)
{
ad_bit=0;
ad_value=pcf_ad(0x01);
if(ad_value>=80)
{
liangdu=0;
}
else
{
liangdu=1;
}
ad_v=ad_value*100/51.0;
}
}
}
//=页面函数
===========================================================================
void yemian()
{
if(ym_mode1)
{
if(shuju_mode
1)
{
dsbuff[0]=clk[2]/16;
dsbuff[1]=clk[2]%16;
dsbuff[2]=11;
dsbuff[3]=clk[1]/16;
dsbuff[4]=clk[1]%16;
dsbuff[5]=11;
dsbuff[6]=clk[0]/16;
dsbuff[7]=clk[0]%16;

	}
	else if(shuju_mode==2)
	{
		dsbuff[0]=14;
		dsbuff[1]=ad_value/100;
		dsbuff[2]=ad_value/10%10;
		dsbuff[3]=ad_value%10;
		dsbuff[4]=10;
		dsbuff[5]=tempture/100;
		dsbuff[6]=tempture/10%10;
		dsbuff[7]=tempture%10;
	}
	else if(shuju_mode==3)
	{
		dsbuff[0]=16;
		dsbuff[1]=10;
		dsbuff[2]=ad_v/100;
		dsbuff[3]=ad_v/10%10;
		dsbuff[4]=ad_v%10;
		dsbuff[5]=10;
		dsbuff[6]=10;
		dsbuff[7]=liangdu;
	}
}
else if(ym_mode==2)
{
	if(canshu_mode==1)
	{
		dsbuff[0]=18;
		dsbuff[1]=1;
		dsbuff[2]=10;
		dsbuff[3]=10;
		dsbuff[4]=10;
		dsbuff[5]=10;
		dsbuff[6]=shijian_canshu/10;
		dsbuff[7]=shijian_canshu%10;
	}
	else if(canshu_mode==2)
	{
		dsbuff[0]=18;
		dsbuff[1]=2;
		dsbuff[2]=10;
		dsbuff[3]=10;
		dsbuff[4]=10;
		dsbuff[5]=10;
		dsbuff[6]=wendu_canshu/10;
		dsbuff[7]=wendu_canshu%10;
	}
	else if(canshu_mode==3)
	{
		dsbuff[0]=18;
		dsbuff[1]=3;
		dsbuff[2]=10;
		dsbuff[3]=10;
		dsbuff[4]=10;
		dsbuff[5]=10;
		dsbuff[6]=10;
		dsbuff[7]=led_canshu%10;
	}
}

}


IIC函数



#include “iic.h”
#include “intrins.h”

#define DELAY_TIME 5

sbit scl=P2^0;
sbit sda=P2^1;
//
static void I2C_Delay(unsigned char n)
{
do
{
nop();nop();nop();nop();nop();
nop();nop();nop();nop();nop();
nop();nop();nop();nop();nop();
}
while(n–);
}

//
void I2CStart(void)
{
sda = 1;
scl = 1;
I2C_Delay(DELAY_TIME);
sda = 0;
I2C_Delay(DELAY_TIME);
scl = 0;
}

//
void I2CStop(void)
{
sda = 0;
scl = 1;
I2C_Delay(DELAY_TIME);
sda = 1;
I2C_Delay(DELAY_TIME);
}

//
void I2CSendByte(unsigned char byt)
{
unsigned char i;

for(i=0; i<8; i++){
    scl = 0;
	I2C_Delay(DELAY_TIME);
    if(byt & 0x80){
        sda = 1;
    }
    else{
        sda = 0;
    }
	I2C_Delay(DELAY_TIME);
    scl = 1;
    byt <<= 1;
	I2C_Delay(DELAY_TIME);
}

scl = 0;  

}

//
unsigned char I2CReceiveByte(void)
{
unsigned char da;
unsigned char i;

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
[外链图片转存中…(img-HtnWwGl7-1713279397389)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值