一份不知道哪里来的第十五届国赛模拟题

这是一个不知道来源的模拟题目,没有完全完成,只作代码记录,不作分析和展示,极其冗长,但里面有长按短按双击的复合,可以看看。

目录

  • 题目
  • 代码
    • 底层驱动
    • 主程序核心代码
    • 关键:双击单击长按复合代码

题目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码

底层驱动

IIC(EEPROM没在主程序用)

unsigned char guangmin(){unsigned char ret;I2CStart();I2CSendByte(0x90);I2CWaitAck();I2CSendByte(0x41);I2CWaitAck();I2CStart();I2CSendByte(0x91);I2CWaitAck();ret = I2CReceiveByte();I2CSendAck(1);I2CStop();return ret;
}void DAC(unsigned char dat){I2CStart();I2CSendByte(0x90);I2CWaitAck();I2CSendByte(0x41);I2CWaitAck();I2CSendByte(dat);I2CWaitAck();I2CStop();
}void eepromwirte(unsigned char addr,unsigned char dat){I2CStart();I2CSendByte(0xa0);I2CWaitAck();I2CSendByte(addr);I2CWaitAck();I2CSendByte(dat);I2CWaitAck();I2CStop();
}unsigned char eepromread(unsigned char addr){unsigned char ret;I2CStart();I2CSendByte(0xa0);I2CWaitAck();I2CSendByte(addr);I2CWaitAck();I2CStart();I2CSendByte(0xa1);I2CWaitAck();ret = I2CReceiveByte();I2CSendAck(1);I2CStop();return ret;
}

主程序核心代码

#include <STC15F2K60S2.H>
#include "intrins.h"
#include "inithc138.h"
#include "delay.h"
#include "onewire.h"
#include "iic.h"
#include "ds1302.h"#define de 5
code unsigned char Seg_Table[17] = 
{
0xc0, //0
0xf9, //1
0xa4, //2
0xb0, //3
0x99, //4
0x92, //5
0x82, //6
0xf8, //7
0x80, //8
0x90, //9
0x88, //A
0x83, //b
0xc6, //C
0xa1, //d
0x86, //E
0x8e, //F
0xbf
};
unsigned char show = 0;//显示功能切换
unsigned char canshu = 0;//参数界面切换
bit mode = 1;//控制模式切换
unsigned char jiaozhun = 0;//校准设置切换
bit huixian = 0;//回显模式切换
unsigned int temp = 0;//温度
bit ce = 1;
unsigned int time = 0;//超声波传播时间
long distance = 0;//距离
unsigned char cejushangxian = 80;//测距上限
unsigned char cejuxiaxian = 20;//测距下限
unsigned int tempcan = 30;//温度参数
unsigned char light = 0;//光敏参数
unsigned char ds1302writeaddr[3] = {0x80,0x82,0x84};
unsigned char ds1302readaddr[3] = {0x81,0x83,0x85};
unsigned char rtctime[3] = {0x05,0x29,0x10};
char disjiao = 0;//距离校准值
int tempjiao = 0;//温度校准值
unsigned char temptime[3] = {0};//温度超限时间
unsigned char distime[3] = {0};//温度超限时间
double daczhi = 0;//DAC输出大小
bit zhouqi = 0;//1为进入按键周期
unsigned char keycount = 0;//按键周期计时
unsigned char cishu = 0;
bit zhouqi1 = 0;//1为进入按键周期
unsigned char keycount1 = 0;//按键周期计时
unsigned char cishu1 = 0;
bit keystat = 0;//按键状态(长短按)
unsigned int count = 0;//长按计时
unsigned char ledstat = 0xff;
unsigned char ledcount = 0;
bit ledflag = 0;
bit chaoxian = 0;
unsigned int tempshow = 0;//校准后的温度
//*****************************************测温模块
void cewen(){unsigned char LSB,MSB;init_ds18b20();Write_DS18B20(0xcc);Write_DS18B20(0x44);if(ce){Delay(520);}ce = 0;init_ds18b20();Write_DS18B20(0xcc);Write_DS18B20(0xbe);LSB = Read_DS18B20();MSB = Read_DS18B20();init_ds18b20();temp = ((MSB << 8) | LSB) * 0.625;tempshow = temp + tempjiao;}
//*****************************************
//*****************************************超声波模块
sbit TX = P1^0;
sbit RX = P1^1;
void showselect();
void Delay13us(void)	//@12.000MHz
{unsigned char data i;_nop_();_nop_();i = 36;while (--i);
}void fangbo(){unsigned char i;for(i = 0;i < 8;i++){TX = 1;Delay13us();TX = 0;Delay13us();}
}void initpca(){CMOD = 0x01;CCON = 0x00;
}void ceju(){CH = 0x00;CL = 0x00;CF = 0;CR = 0;			fangbo();CR = 1;while((RX == 1) && (CH < 0x17));CR = 0;if(RX == 0){RX = 1;time = (CH << 8) | CL;distance = time * 0.017;}
}
//*****************************************
//*****************************************DS1302实时时钟
void ds1302config(){unsigned char i;Write_Ds1302_Byte(0x8e,0x00);for(i = 0;i < 3;i++){Write_Ds1302_Byte(ds1302writeaddr[i],rtctime[i]);}Write_Ds1302_Byte(0x8e,0x80);
}void ds1302read(){unsigned char i;for(i = 0;i < 3;i++){rtctime[i] = Read_Ds1302_Byte(ds1302readaddr[i]);}
}
//*****************************************
//*****************************************显示功能
void shujujiemian(){//数据界面showsmg(1,Seg_Table[12]);showsmg(2,Seg_Table[tempshow / 100]);showsmg(3,Seg_Table[tempshow / 10 % 10] & 0x7f);showsmg(4,Seg_Table[tempshow % 10]);if((distance + disjiao) >= 0){showsmg(8,Seg_Table[(distance + disjiao) % 10]);if((distance + disjiao) > 9){showsmg(7,Seg_Table[(distance + disjiao) / 10 % 10]);}}else{showsmg(7,0xc7);showsmg(8,0xc7);}
}void p1(){//参数P1showsmg(1,0x8c);showsmg(2,Seg_Table[1]);showsmg(6,0x89);showsmg(7,Seg_Table[cejushangxian / 10]);showsmg(8,Seg_Table[cejushangxian % 10]);
}void p2(){//参数P2showsmg(1,0x8c);showsmg(2,Seg_Table[2]);showsmg(6,0xc7);showsmg(7,Seg_Table[cejuxiaxian / 10]);showsmg(8,Seg_Table[cejuxiaxian % 10]);
}void p3(){//参数P3showsmg(1,0x8c);showsmg(2,Seg_Table[3]);showsmg(7,Seg_Table[tempcan / 10]);showsmg(8,Seg_Table[tempcan % 10]);
}void p4(){//参数P4showsmg(1,0x8c);showsmg(2,Seg_Table[4]);if(mode){showsmg(4,0x8c);showsmg(5,Seg_Table[14]);}else{showsmg(4,Seg_Table[10]);showsmg(5,0xc1);}showsmg(8,Seg_Table[light % 10]);if(light > 9){showsmg(7,Seg_Table[light / 10 % 10]);}if(light > 99){showsmg(6,Seg_Table[light / 100 % 10]);}
}void canshujiemian(){//参数界面switch(canshu){case 0:p1();break;case 1:p2();break;case 2:p3();break;case 3:p4();break;}
}void shijianjiemian(){//时间显示showsmg(1,Seg_Table[rtctime[2] / 16]);showsmg(2,Seg_Table[rtctime[2] % 16]);showsmg(3,Seg_Table[16]);showsmg(4,Seg_Table[rtctime[1] / 16]);showsmg(5,Seg_Table[rtctime[1] % 16]);showsmg(6,Seg_Table[16]);showsmg(7,Seg_Table[rtctime[0] / 16]);showsmg(8,Seg_Table[rtctime[0] % 16]);
}void f1(){showsmg(1,Seg_Table[15]);showsmg(2,Seg_Table[1]);if(disjiao >= 0){showsmg(8,Seg_Table[disjiao % 10]);if(disjiao > 9){showsmg(7,Seg_Table[disjiao / 10 % 10]);}}else if(disjiao < 0){if(disjiao >= -9){showsmg(8,Seg_Table[-(disjiao) % 10]);showsmg(7,Seg_Table[16]);}if(disjiao < -9){showsmg(8,Seg_Table[-(disjiao) % 10]);showsmg(7,Seg_Table[-(disjiao) / 10 % 10]);showsmg(6,Seg_Table[16]);}}
}void f2(){showsmg(1,Seg_Table[15]);showsmg(2,Seg_Table[2]);if(tempjiao > 0){showsmg(8,Seg_Table[tempjiao % 10]);showsmg(7,Seg_Table[tempjiao  / 10 % 10] & 0x7f);}else if(tempjiao < 0){showsmg(8,Seg_Table[(-tempjiao) % 10]);showsmg(7,Seg_Table[(-tempjiao) / 10 % 10] & 0x7f);showsmg(6,Seg_Table[16]);}else if(tempjiao == 0){showsmg(8,Seg_Table[0]);}
}void f3(){showsmg(1,Seg_Table[15]);showsmg(2,Seg_Table[3]);if(mode){showsmg(7,0x8c);showsmg(8,Seg_Table[14]);}else{showsmg(7,Seg_Table[10]);showsmg(8,0xc1);}
}void jiaozhunshezhi(){//校准设置界面switch(jiaozhun){case 0:f1();break;case 1:f2();break;case 2:f3();break;}
}void wenduchaoxian(){//温度超限时间记录showsmg(1,0x8b);showsmg(2,0xa7);if(temptime[2] != 0){showsmg(3,Seg_Table[temptime[2] / 16]);showsmg(4,Seg_Table[temptime[2] % 16]);showsmg(5,Seg_Table[temptime[1] / 16]);showsmg(6,Seg_Table[temptime[1] % 16]);showsmg(7,Seg_Table[temptime[0] / 16]);showsmg(8,Seg_Table[temptime[0] % 16]);}
}void julichaoxian(){//距离超限时间记录showsmg(1,0x8b);showsmg(2,0xa1);if(distime[2] != 0){showsmg(3,Seg_Table[distime[2] / 16]);showsmg(4,Seg_Table[distime[2] % 16]);showsmg(5,Seg_Table[distime[1] / 16]);showsmg(6,Seg_Table[distime[1] % 16]);showsmg(7,Seg_Table[distime[0] / 16]);showsmg(8,Seg_Table[distime[0] % 16]);}
}void huixianmoshi(){//回显模式if(huixian == 0){wenduchaoxian();}else{julichaoxian();}
}
//*****************************************
//*****************************************DAC输出
void DACshuchu(){if((disjiao + distance) <= cejuxiaxian){daczhi = 51;}else if((disjiao + distance) >= cejushangxian){daczhi = 255;}else{daczhi = (204 / (cejushangxian - cejuxiaxian)) * (disjiao + distance - cejuxiaxian) + 51;}DAC(daczhi);
}
//*****************************************
//*****************************************
void showselect(){switch(show){case 0:shujujiemian();break;case 1:canshujiemian();break;case 2:shijianjiemian();break;case 3:jiaozhunshezhi();break;case 4:huixianmoshi();break;}
}
//*****************************************
//*****************************************单击双击检测
void Timer0_Isr(void) interrupt 1
{ledcount++;if(zhouqi){keycount++;}if(keycount == 100){zhouqi = 0;}if(zhouqi1){keycount1++;}if(keycount1 == 100){zhouqi1 = 0;}if(keystat){count++;}if(ledcount == 200){ledcount = 0;}if(ledcount % 20 == 0){ledflag = ~ledflag;}
}void Timer0_Init(void)		//5毫秒@12.000MHz
{AUXR |= 0x80;			//定时器时钟1T模式TMOD &= 0xF0;			//设置定时器模式TL0 = 0xA0;				//设置定时初始值TH0 = 0x15;				//设置定时初始值TF0 = 0;				//清除TF0标志TR0 = 1;				//定时器0开始计时ET0 = 1;				//使能定时器0中断EA = 1;
}//*****************************************
//*****************************************按键扫描
void scankey(){P33 = 0;P32 = 1;P44 = 1;P35 = 1;if(P44 == 0){//S4Delay(de);while(P44 == 0){showselect();}show++;jiaozhun = 0;canshu = 0;huixian = 0;show %= 5;}if(P35 == 0){//S12Delay(de);if(P35 == 0){zhouqi = 1;}while(P35 == 0){showselect();}cishu++;if(show == 1){if(canshu == 2){tempcan++;if(tempcan > 40){tempcan = 40;}}else if((canshu == 3) && (mode == 1)){light += 10;if(light > 200){light = 200;}}}if(show == 3){if(jiaozhun == 0){disjiao++;if(disjiao > 10){disjiao = 10;}}else if(jiaozhun == 1){tempjiao++;if(tempjiao > 30){tempjiao = 30;}}}}if(show == 1){if(zhouqi == 0){if(cishu == 1){//单击if(show == 1){if(canshu == 0){cejushangxian++;if(cejushangxian > 90){cejushangxian = 90;}}else if(canshu == 1){cejuxiaxian++;if(cejuxiaxian > (cejushangxian - 20)){cejuxiaxian = cejushangxian - 20;}}}}if(cishu == 2){//双击if(show == 1){if(canshu == 0){cejushangxian += 10;if(cejushangxian > 90){cejushangxian = 90;}}else if(canshu == 1){cejuxiaxian += 10;if(cejuxiaxian > (cejushangxian - 20)){cejuxiaxian = cejushangxian - 20;}}}}keycount = 0;cishu = 0;}}P33 = 1;P32 = 0;P44 = 1;P35 = 1;if(P44 == 0){//S5Delay(de);while(P44 == 0){showselect();}if(show == 1){canshu++;canshu %= 4;}if(show == 3){jiaozhun++;jiaozhun %= 3;}if(show == 4){huixian = ~huixian;}}if(P35 == 0){//S13Delay(de);if(P35 == 0){zhouqi1 = 1;}while(P35 == 0){keystat = 1;showselect();}keystat = 0;if(count < 400){//短按cishu1++;if(show == 1){if(canshu == 2){tempcan--;if(tempcan < 20){tempcan = 20;}}else if((canshu == 3) && (mode == 1)){light -= 10;if(light > 200){light = 0;}}}if(show == 3){if(jiaozhun == 0){disjiao--;if(disjiao < -10){disjiao = -10;}}else if(jiaozhun == 1){tempjiao--;if(tempjiao < -30){tempjiao = -30;}}}}else{if(show == 3){if(jiaozhun == 0){disjiao = 0;}if(jiaozhun == 1){tempjiao = 0;}}}count = 0;}if(show == 1){if(zhouqi1 == 0){if(cishu1 == 1){//单击if(show == 1){if(canshu == 0){cejushangxian--;if(cejushangxian < (cejuxiaxian + 20)){cejushangxian = cejuxiaxian + 20;}}else if(canshu == 1){cejuxiaxian--;if(cejuxiaxian < 10){cejuxiaxian = 10;}}}}if(cishu1 == 2){//双击if(show == 1){if(canshu == 0){cejushangxian -= 10;if(cejushangxian < (cejuxiaxian + 20)){cejushangxian = (cejuxiaxian + 20);}}else if(canshu == 1){cejuxiaxian -= 10;if(cejuxiaxian < 10){cejuxiaxian = 10;}}}}keycount1 = 0;cishu1 = 0;}}
}
//*****************************************
//*****************************************LED模块与超限判断
void chaoxianpanduan(){if(((temp + tempjiao) / 10) > tempcan){chaoxian = 1;temptime[0] = rtctime[0];temptime[1] = rtctime[1];temptime[2] = rtctime[2];//eepromwirte()}
}void led(){unsigned char tmp = 0;if(tempshow > tempcan * 10){ledstat = ledstat & ~0x10;}else{ledstat = ledstat | 0x10;}if((show == 0) && (ledflag == 1)){ledstat = ledstat & ~0x01;}else{ledstat = ledstat | 0x01;}if((show == 3) && (ledflag == 1)){ledstat = ledstat & ~0x02;}else{ledstat = ledstat | 0x02;}if(((distance + disjiao) <=cejushangxian) && ((distance + disjiao) >= cejuxiaxian)){ledstat = ledstat | 0x08;}else{ledstat = ledstat & ~0x08;}tmp = guangmin();if((mode == 1) && (tmp > light)){ledstat = ledstat & ~0x80;}else{ledstat = ledstat | 0x80;}outputp0(4,ledstat);
}
//*****************************************
void main(){ds1302config();cewen();initpca();initsys();ceju();Timer0_Init();while(1){if(mode == 0){light = guangmin();}cewen();led();ceju();showselect();ds1302read();DACshuchu();scankey();chaoxianpanduan();}
}

关键:双击单击长按复合代码

以S12为例

//*****************************************单击双击检测
void Timer0_Isr(void) interrupt 1
{ledcount++;if(zhouqi){keycount++;}if(keycount == 100){zhouqi = 0;}if(zhouqi1){keycount1++;}if(keycount1 == 100){zhouqi1 = 0;}if(keystat){count++;}if(ledcount == 200){ledcount = 0;}if(ledcount % 20 == 0){ledflag = ~ledflag;}
}void Timer0_Init(void)		//5毫秒@12.000MHz
{AUXR |= 0x80;			//定时器时钟1T模式TMOD &= 0xF0;			//设置定时器模式TL0 = 0xA0;				//设置定时初始值TH0 = 0x15;				//设置定时初始值TF0 = 0;				//清除TF0标志TR0 = 1;				//定时器0开始计时ET0 = 1;				//使能定时器0中断EA = 1;
}//*****************************************P33 = 0;P32 = 1;P44 = 1;P35 = 1;if(P44 == 0){//S4Delay(de);while(P44 == 0){showselect();}show++;jiaozhun = 0;canshu = 0;huixian = 0;show %= 5;}if(P35 == 0){//S12Delay(de);if(P35 == 0){zhouqi = 1;}while(P35 == 0){showselect();}cishu++;if(show == 1){if(canshu == 2){tempcan++;if(tempcan > 40){tempcan = 40;}}else if((canshu == 3) && (mode == 1)){light += 10;if(light > 200){light = 200;}}}if(show == 3){if(jiaozhun == 0){disjiao++;if(disjiao > 10){disjiao = 10;}}else if(jiaozhun == 1){tempjiao++;if(tempjiao > 30){tempjiao = 30;}}}}if(show == 1){if(zhouqi == 0){if(cishu == 1){//单击if(show == 1){if(canshu == 0){cejushangxian++;if(cejushangxian > 90){cejushangxian = 90;}}else if(canshu == 1){cejuxiaxian++;if(cejuxiaxian > (cejushangxian - 20)){cejuxiaxian = cejushangxian - 20;}}}}if(cishu == 2){//双击if(show == 1){if(canshu == 0){cejushangxian += 10;if(cejushangxian > 90){cejushangxian = 90;}}else if(canshu == 1){cejuxiaxian += 10;if(cejuxiaxian > (cejushangxian - 20)){cejuxiaxian = cejushangxian - 20;}}}}keycount = 0;cishu = 0;}}

注意几个要点:
1、涉及到双击,要把判断部分抽离按键按下阶段,否则不会进行判断
2、注意按键周期,在编程过程中可以用数码管显示按键周期和按键按下进行调试。
3、定时器尽量使用1T,优先级尽量高。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/845356.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter 中的 SliverPadding 小部件:全面指南

Flutter 中的 SliverPadding 小部件&#xff1a;全面指南 Flutter 是一个功能丰富的 UI 框架&#xff0c;由 Google 开发&#xff0c;允许开发者使用 Dart 语言来构建高性能、美观的跨平台应用。在 Flutter 的滚动组件体系中&#xff0c;SliverPadding 是一个用来为其子 Slive…

今日学会的,刘姥姥进大观园

Git - First-Time Git Setup 下载了Git&#xff0c;会用Git了&#xff1f; 还有这个&#xff1a;学习 HTML5 Canvas 这一篇文章就够了 | 菜鸟教程 (runoob.com) JavaScript 用法 | 菜鸟教程 (runoob.com) 看到这个真的是受益匪浅&#xff0c;我终于懂了一直有的疑惑。 3D可…

js 正则匹配返回所有匹配到的范围

js正则默认不返回匹配到的范围&#xff0c;有些场景用起来就不太方便。如果想针对于匹配到的位置多次操作就要另外想个办法了。 indexOf 这个只能获取到第一个出现的位置&#xff0c;其他位置不太行&#xff0c;这个方法好像就行不通了。 自己一个个找&#xff0c;写个kmp算法感…

Mock的用法

1. 引入unittest包&#xff0c;再从包里引用mock类 import unittest from unittest import Mock 2. mock的作用&#xff0c;做挡板或者用来做一些单元测试过程中复杂的数据的模拟 demo Demo() #把mock的值赋值给demo的get()方法&#xff0c;这样在调用这个方法时&#xff0…

RAG技术探索

什么是RAG 1 RAG原理 RAG&#xff08;Retrieval Augmented Generation, 检索增强生成&#xff09;&#xff0c;即LLM在回答问题或生成文本时&#xff0c;先会从大量文档中检索出相关的信息&#xff0c;然后基于这些信息生成回答或文本&#xff0c;从而提高预测质量。RAG模型尤…

数据在内存中的存储<C语言>

导言 在计算机中不同类型的数据在计算机内部存储形式各不相同&#xff0c;弄懂各种数据在计算机内部存储形式是有必要的&#xff0c;C语言的学习不能浮于表面&#xff0c;更要锻炼我们的“内功”&#xff0c;将来在写程序的时候遇见各种稀奇古怪的bug时&#xff0c;也便能迎刃而…

天文学专业大学院校排名(2024最新排行榜)

序号 学校代码 学校名称 学科名称 评估结果 1 10284 南京大学 天文学 A 2 10358 中国科学技术大学 天文学 A 3 10001 北京大学 天文学 B- 4 10248 上海交通大学 天文学 C 5 10027 北京师范大学 天文学 C- 天文学专业排名前5名的大学有&#xff1…

pipeline在计算机领域有什么贴切的翻译

在计算机领域&#xff0c;"pipeline"一词通常被翻译为“流水线”。这个术语指的是一种技术或架构&#xff0c;其中多个处理阶段按顺序执行&#xff0c;使得数据可以在一个阶段完成处理后立即被送入下一个阶段&#xff0c;从而提高效率和性能。在不同的上下文中&#…

控制障碍函数CBF详解(附带案例实现)

控制障碍函数CBF详解&#xff08;附带案例实现&#xff09; 文章目录 控制障碍函数CBF详解&#xff08;附带案例实现&#xff09;1. Control Affine System2. Lyapunov Theory, Nagumos Theory, Invariance Principle3. Control Lyapunov Function (CLF) and CLF-QP4. Control …

算法(十二)分治算法

文章目录 算法概念算法例子字符串中小写转大写求X^n问题 算法概念 分治算法&#xff08;divide and conquer&#xff09;算法的核心思想其实就是"分而治之"&#xff0c;将原问题划分成n个规模较小&#xff0c;并且结构与原问题相似的子问题&#xff0c;递归地解决这…

移植其他命令行Vivado IDE的工具

移植其他命令行Vivado IDE的工具 介绍 本章介绍如何迁移各种AMD命令行工具以在AMD中使用 Vivado™集成设计环境&#xff08;IDE&#xff09;。 迁移ISE Partgen命令行工具 ISE™Design Suite Partgen工具可获得&#xff1a; •系统上安装的所有设备的信息 •详细的包装信息 您可…

[openwrt-21.02]openwrt-21.02 make menuconfig不显示luci-app-firewall问题分析及解决方案

问题描述 make menuconfig在 在applications界面没有luci-app-firewall 问题分析 首先重新执行 ./scripts/feeds update -a ./scripts/feeds install -a 然后再次执行make menuconfig&#xff0c;依然不显示&#xff0c;所以不是feeds安装的问题 最后看到log有个openmptc…

GB-T 43206-2023 信息安全技术 信息系统密码应用测评要求

GB-T 43206-2023 信息安全技术 信息系统密码应用测评要求 编写背景 随着信息技术的飞速发展&#xff0c;信息系统在社会经济活动中扮演着越来越重要的角色。信息安全问题也随之成为社会关注的焦点。GB-T 43206-2023《信息安全技术 信息系统密码应用测评要求》是针对信息系统中…

kotlin gradle 在libs.versions.toml控制下添加本地aar/jar的方法

与之前gradle集中控制的方法相同&#xff0c;唯一不同的是改成kotlin dsl格式&#xff1a; 修改Module级别的build.gradle.kt文件 在dependencies函数块内添加下面代码块 implementation(fileTree(mapOf("dir" to "libs","include" to listOf(…

记录mabatis-plus初体验

一、简介 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 测试问题现象&#xff1a;测试mabatis的crud方法 增加 批量删除都没有问题 单单就是这个根据ID删除有问题 解决方案&#xff1a;真的就是pom文件的问题 自己的版本是Intelli…

Fully Convolutional Networks for Semantic Segmentation--论文笔记

论文笔记 资料 1.代码地址 2.论文地址 https://arxiv.org/abs/1411.4038 3.数据集地址 论文摘要的翻译 卷积网络是强大的视觉模型&#xff0c;可以产生特征层次结构。我们表明&#xff0c;卷积网络本身&#xff0c;经过端到端&#xff0c;像素对像素的训练&#xff0c;在…

【新能源大巴BMS结构与乘用车的区别】

新能源大巴BMS结构与乘用车的区别 这篇文章主要介绍新能源大巴的电池和BMS的结构与乘用车的区别。 主要有&#xff0c;新能源大巴行业、新能源电池系统结构和新能源大巴的BMS系统。 第一部分 新能源大巴行业 其实数数全球的商用车(大巴卡车)&#xff0c;大致的方向还是沿着就…

解释 Vue route和router的区别?

Vue中的route和router在单页应用&#xff08;SPA&#xff09;开发中扮演着不同的角色&#xff0c;它们的区别可以归纳为以下几点&#xff1a; 定义与功能&#xff1a; router&#xff1a;router是Vue Router的一个实例对象&#xff0c;它是全局的。通过Vue.use(VueRouter)和Vue…

RocketMQ重复消费的幂等性问题

什么是幂等性&#xff1f;----》多次调用接口&#xff0c;得到的结果都一样。 用幂等性来解决重复消费的问题。 重复消费可以解决吗-----》重复消费根部避免不了。只能从消息的幂等消费入手。 为什么会有重复消费&#xff1f; 由于我们要求RocketMQ消息不丢失&#xff0c;要…

前端传String字符串 后端使用enun枚举类出现错误

情况 前端 String 后端 enum 前端 后端 报错 2024-05-31T21:47:40.61808:00 WARN 21360 --- [nio-8080-exec-6] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.web.method.annotation.MethodArgumentTypeMismatchException: Failed to con…