2024年Web前端最全第十五届蓝桥杯模拟考试III_物联网设计与开发官方代码分析,实现原理分析

文末

如果30岁以前,可以还不知道自己想去做什么的话,那30岁之后,真的觉得时间非常的宝贵,不能再浪费时间在一些碎片化的事情上,比如说看综艺,电视剧。一个人的黄金时间也就二,三十年,不能过得浑浑噩噩。所以花了基本上休息的时间,去不断的完善自己的知识体系,希望可以成为一个领域内的TOP。

同样是干到30岁,普通人写业务代码划水,榜样们深度学习拓宽视野晋升管理。

这也是为什么大家都说30岁是程序员的门槛,很多人迈不过去,其实各行各业都是这样都会有个坎,公司永远都缺的高级人才,只用这样才能在大风大浪过后,依然闪耀不被公司淘汰不被社会淘汰。

269页《前端大厂面试宝典》

包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

前端面试题汇总

JavaScript

sprintf 函数的作用是将一个或多个表达式按照指定的格式转换成字符串,并将结果存储在指定的字符数组中,定义在 stdio.h 头文件中。

真是一个神仙函数,之前我还看不上,今天我才发现是我高攀不起的函数,真的是方便到极致

例子1:

原始人代码:

void Function\_NumbertoStr(unsigned char a[]){
	unsigned char up[30];
	unsigned char down[30];
	sprintf(up, "%.2f", num1);
	sprintf(down, "%.2f", num2);
	unsigned char i = 0, j = 0, k = 0;
		while(up[j] != '\0') a[i ++] = up[j ++];
	   
    a[i ++] = '/';		
		while(down[k] != '\0') a[i ++] = down[k ++];
		a[i] = '/';
	 //OLED\_ShowString(0, 2, a, 8);
}

优雅代码:

void Function\_NumbertoStr(unsigned char a[]){
  sprintf(a, "%.2f/%.2f/",num1, num2);
}

在这里插入图片描述

两者等效妙解,这就是一个或多个表达式的意思

例子2:

原始人代码:

unsigned char Function\_NumberPoint(double number){
	while(number >= 1){
		number = number - 1;
	}
	return (unsigned char)(number \* 10 + 0.5);
}
 
unsigned char  Function\_NumberLen(unsigned char number){
	unsigned char res = 0;
	while(number){
		res = res + 1;
		number = number / 10;
	}
	if(res == 0) res = 1;
	return res;
}

uint32\_t OLED\_Pow(uint32\_t X, uint32\_t Y){
	uint32\_t result = 1;
	while(Y){
		result = result \* X;
		Y --;
	}
	return result;
}

void OLED\_ShowNumber(unsigned char x, unsigned char y, uint32\_t chr, unsigned char len, unsigned char size){
	unsigned char i = 0, j = 0;
	
	while(j < len){
		OLED\_ShowChar(x, y, chr / OLED\_Pow(10, len - 1 - i) % 10 + '0' , size);
		i ++;
		j ++;
		x += 8;
    if(x > 120)
    {
      x = 0;
      y += 2;
    }
	}
}
void Function\_ShowMasg1(void){
	
	OLED\_ShowString(24, 0, "TEMP:", 16);
	OLED\_ShowNumber(64, 0, (uint32\_t)(num1), Function\_NumberLen((uint32\_t)(num1)), 16);
	OLED\_ShowString(64 + 8 \* Function\_NumberLen((uint32\_t)(num1)), 0, "." , 16);
	OLED\_ShowNumber(64 + 8 \* Function\_NumberLen((uint32\_t)(num1)) + 8, 0,  Function\_NumberPoint(num1), 1, 16);
	OLED\_ShowString(24, 2, "HUMI:", 16);
	OLED\_ShowNumber(64, 2, (uint32\_t)(num2), Function\_NumberLen((uint32\_t)(num2)), 16);
	OLED\_ShowString(64 + 8 \* Function\_NumberLen((uint32\_t)(num2)), 2, "." , 16);
	OLED\_ShowNumber(64 + 8 \* Function\_NumberLen((uint32\_t)(num2)) + 8, 2,  Function\_NumberPoint(num2), 1, 16);
	
}
void Function\_ShowMasg2(void){
	OLED\_ShowString(0, 0, "TEMP",16);
	OLED\_ShowString(48, 0, "UP:", 16);
	OLED\_ShowNumber(72, 0, upt[flag1], 2, 16);
	OLED\_ShowString(32, 2, "DOWN:", 16);
	OLED\_ShowNumber(72, 2, dnt[flag2], 2,16);
}

void Function\_ShowMasg3(void){
	OLED\_ShowString(0, 0, "HUMI", 16);
	OLED\_ShowString(48, 0, "UP:", 16);
	OLED\_ShowNumber(72, 0, ups[flag3], 2, 16);
	OLED\_ShowString(32, 2, "DOWN:", 16);
	OLED\_ShowNumber(72, 2, dns[flag4], 2, 16);
}

优雅代码:

	if(ui == 0){
		sprintf((char\*)ucBuf, " TEMP:%.1f ", TEMP_rx\*0.1);
		OLED\_ShowString(0, 0, ucBuf);
		sprintf((char\*)ucBuf, " HUMI:%.1f ", HUMI_rx\*0.1);
		OLED\_ShowString(0, 2, ucBuf);
	}else if(ui == 1){ 
		sprintf((char\*)ucBuf, "TEMP UP:%d ", TEMP_UP);
		OLED\_ShowString(0, 0, ucBuf);
		sprintf((char\*)ucBuf, " DOWN:%d ", TEMP_DOWN);
		OLED\_ShowString(0, 2, ucBuf);
	}else if(ui == 2){
		sprintf((char\*)ucBuf, "HUMI UP:%d ", HUMI_UP);
		OLED\_ShowString(0, 0, ucBuf);
		sprintf((char\*)ucBuf, " DOWN:%d ", HUMI_DOWN);
		OLED\_ShowString(0, 2, ucBuf);
	}

在这里插入图片描述
特别是这个格式,我弄了很久很久,又是写新的显示函数,又是写查看数字长度函数,又是调试区域,还好这次数字显示长度没有过多的变化,不用写区域清屏函数,否者真是越写越🤡

人家代码绝妙在于直接将格式连同数据打印到数组里了,直接用show_string显示即可,真是优雅

———— 2024 / 3 / 15

页面切换:

页面切换部分我感觉我的还是不错的,毕竟我的代码不可能什么优点也没有,页面切换基于算法%符号
选取一个标记位,keynumber每次按键按下对这个标记位%3即可,毕竟只有三个页面分别标记为0、1、2即可,这个比官方的if else 语句要优雅😏

优雅代码:

unsigned char Function\_KeyCheck(unsigned char keynumber){
	 if(HAL\_GPIO\_ReadPin(User_key_GPIO_Port, User_key_Pin) == GPIO_PIN_RESET){
			while(HAL\_GPIO\_ReadPin(User_key_GPIO_Port, User_key_Pin) == GPIO_PIN_RESET);
		  keynumber = keynumber + 1;
		  OLED\_Clear();
		}	 
		return keynumber % 3;
}

数值的轮回调整:

里面有一个功能是

在这里插入图片描述

结束

一次完整的面试流程就是这样啦,小编综合了腾讯的面试题做了一份前端面试题PDF文档,里面有面试题的详细解析,分享给小伙伴们,有没有需要的小伙伴们都去领取!

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 12
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值