当前位置: 首页 > news >正文

53 基于单片机的8路抢答器加记分

目录

一、主要功能

二、硬件资源

三、程序编程

四、实现现象


一、主要功能

首先有三个按键 分别为开始 暂停 复位,然后八个选手按键,开机显示四条杠,然后按一号选手按键,数码管显示30,这时候二号选手按键是加时间,三号宣誓减时间,这个是抢答倒计时,再按一次一号选手按键,数码管显示30是答题倒计时时间,同样二号和三号按键可以加减时间,然后再按1号按键,此时进入计分时刻,此时数码管是显示是1-00,然后2号键和3号键加减分数,此时数码管显示四条杠,此时按开始键,数码管开始抢答倒计时,此时比如1号按键按下,直接跳到答题倒计时,此时数码管显示1-30,这个30比如就是答题时间,开始倒计时,之前得抢答最后五秒内没人按就蜂鸣器报警,这个答题也是如此,然后答题30秒倒计时完后,,按复位键再按开始建可以重新开始抢答。还有一个违规抢答的功能 就是如果主持人没按开始,选手按抢答了会报警

二、硬件资源

基于KEIL5编写C++代码,PROTEUS8.15进行仿真,全部资源在页尾,提供安装包。

三、程序编程

#include<reg51.h>
#include<intrins.h>
sbit smg1=P2^4;		//定义数码管第一位
sbit smg2=P2^6;		//定义数码管第二位
sbit smg3=P2^7;		//定义数码管第三位
sbit smg4=P2^5;sbit keyks=P2^2;	//定义开始按键
sbit keytz=P2^1;	//定义停止按键
sbit keyqc=P2^0;	//定义清除按键sbit key1=P1^4;		//定义1号抢答选手		 
sbit key2=P1^5;		//定义2号抢答选手
sbit key3=P1^6;		//定义3号抢答选手
sbit key4=P1^7;		//定义4号抢答选手
sbit key5=P3^4;		//定义5号抢答选手
sbit key6=P3^5;		//定义6号抢答选手
sbit key7=P3^6;		//定义7号抢答选手
sbit key8=P3^7;		//定义8号抢答选手
sbit spk=P1^0;		//定义蜂鸣器
static int djs=30,djs2=30,djs3=30,js=0,xh=1,fs1,fs2,fs3,fs4,fs5,fs6,fs7,fs8;		   //djs和bt是初始倒计时时间,可修改
int fs[8];
unsigned char flag=0,flag1=0,flag2=0,flag3=0;
//int table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
int table[]={0x5f,0x44,0x9d,0xd5,0xc6,0xd3,0xdb,0x45,0xdf,0xd7,0x80};void delayms(int x)	   //延时函数
{
char i;
while(x--){for(i=500;i>0;i--); }
}void djsxsjf() 
{int b1,b2;b1=fs[xh]/10;b2=fs[xh]%10;				  // 将倒计时时间分成高低位P0=table[b1];smg2=0;delayms(3);smg2=1;					 //显示十位数字P0=table[b2];smg3=0;delayms(3);				 //显示个位数字smg3=1;P0=0x80;smg4=0;delayms(3);				 //显示个位数字smg4=1;P0=table[xh];smg1=0;delayms(3);				 //显示个位数字smg1=1;
}void djsxs200()
{int b1,b2;b1=djs2/10;b2=djs2%10;				  // 将倒计时时间分成高低位P0=table[b1];smg2=0;delayms(3);smg2=1;					 //显示十位数字P0=table[b2];smg3=0;delayms(3);				 //显示个位数字smg3=1;
}void djsxs()				   //显示倒计时函数
{	int b1,b2;b1=djs/10;b2=djs%10;				  // 将倒计时时间分成高低位P0=table[b1];smg2=0;delayms(3);smg2=1;					 //显示十位数字P0=table[b2];smg3=0;delayms(3);				 //显示个位数字smg3=1;
}
void djsxs30() //第二位数码管显示-{P0=0x80;			//第二位数码管smg4=0;delayms(3);smg4=1;}
void djsxs22()				 {	P0=0x80;smg1=0;delayms(3);smg1=1;//第一位数码管显示-P0=0x80;			//第二位数码管smg4=0;delayms(3);smg4=1;P0=0x80;smg2=0;delayms(3);			   //第三位数码管显示-smg2=1;P0=0x80;smg3=0;delayms(3);smg3=1;				  //第四位数码管显示-
}void djsxs1(){P0=table[1];smg1=0;delayms(3);smg1=1;				   //第一位数码管显示1}
void djsxs2(){P0=table[2];smg1=0;delayms(3);smg1=1;				//第一位数码管显示2}
void djsxs3(){P0=table[3];smg1=0;delayms(3);smg1=1;			  //第一位数码管显示3}
void djsxs4(){P0=table[4];smg1=0;delayms(3);smg1=1;			 //第一位数码管显示4}
void djsxs5(){P0=table[5];smg1=0;delayms(3);smg1=1;		   //第一位数码管显示5}
void djsxs6(){P0=table[6];smg1=0;delayms(3);smg1=1;			//第一位数码管显示6}
void djsxs7(){P0=table[7];smg1=0;delayms(3);smg1=1;		  //第一位数码管显示7
}
void djsxs8(){P0=table[8];smg1=0;delayms(3);smg1=1;		 //第一位数码管显示8}
void main()
{
int djs1=30;
Timer0_init();	 //初始化定时器中断
spk=1;			  //蜂鸣器不响
djs=30;		//倒计时赋值
djs1=30;
while(1)
{LOOP1:   djs=djs1;djs2=djs3;
djsxs22();	//LOOP1是标号,显示 -  --if(key1==0)		 //在定时器运行状态下,key1==0 则说明1号选手按下按键{delayms(3);if(key1==0){ flag3 = 1;flag1++;if(flag1>3){flag1=0;}while(!key1);	  //去除按键抖动后,重新在判断,是否确实按下djs=30;djs2=30;while(1){TR0=0;		  //定时器停止if(flag1==1){djsxs();	}if(flag1 == 2){djsxs200();//答题}if(flag1 == 3){djsxsjf();//记分}if(key2==0)	  //复位按下按下{	delayms(8);		   //去除抖动if(key2==0)	   //再次判断是否按下复位按键{do{ while(!key2); //如果按下复位键,则回到- --状态delayms(5);}while(key2!=1);if(flag1 == 1){djs++;djs1=djs;}if(flag1 == 2){djs2++;djs3=djs2;}if(flag1 == 3){switch(xh){case 1:fs1++;fs[1]=fs1;break;case 2:fs2++;fs[2]=fs2;break;case 3:fs3++;fs[3]=fs3;break;case 4:fs4++;fs[4]=fs4;break;case 5:fs5++;fs[5]=fs5;break;case 6:fs6++;fs[6]=fs6;break;case 7:fs7++;fs[7]=fs7;break;case 8:fs8++;fs[8]=fs8;break;}}}}if(key3==0)	  //复位按下按下{	delayms(8);		   //去除抖动if(key3==0)	   //再次判断是否按下复位按键{ do{while(!key3); //如果按下复位键,则回到- --状态delayms(5);	}while(key3!=1);if(flag1 == 1){djs--;djs1=djs;}if(flag1 == 2){djs2--;djs3=djs2;}if(flag1 == 3){switch(xh){case 1:fs1--;fs[1]=fs1;break;case 2:fs2--;fs[2]=fs2;break;case 3:fs3--;fs[3]=fs3;break;case 4:fs4--;fs[4]=fs4;break;case 5:fs5--;fs[5]=fs5;break;case 6:fs6--;fs[6]=fs6;break;case 7:fs7--;fs[7]=fs7;break;case 8:fs8--;fs[8]=fs8;break;}}}}if(key1==0)	  //复位按下按下{	delayms(3);		   //去除抖动if(key1==0)	   //再次判断是否按下复位按键{ flag1++;if(flag1>3){flag1 = 0;}while(!key1); //如果按下复位键,则回到- --状态if(flag1 == 0){goto LOOP1;		  //goto语句,回到loop1表号处}}}										   }}}if(keyks==0){	delayms(3);		 //去除按键抖动if(keyks==0){ flag3 = 1;flag2++;while(!keyks);	  //以上表示按下开始按键 TR0=1;			   //启动定时器 开始倒计时while(1){if(flag2>2){flag2 = 1;}if(flag2 == 1){djsxs();}if(flag2 == 2){djsxs200();}if(keytz==0){delayms(3);			 //此处表示出去抖动, 以后不一一标出if(keytz==0){ while(!keytz);	   //以上表示按下停止按键后 {TR0=0;		   //定时器停止flag=0;//spk=1;}}}if(keyks==0){delayms(3);if(keyks==0){ while(!keyks);	   //以上表示按下清楚按键后 TR0=1;		   //定时器启动}}
/***************************以下是八个选手抢答,key1表示1号选手,依次类推,注释只写第一位选手,其他和第一个完全一致,************************************/if((key1==0)&&(TR0==1))		 //在定时器运行状态下,key1==0 则说明1号选手按下按键{		spk=0;		 //蜂鸣器响delayms(3);if(key1==0){ while(!key1);	  //去除按键抖动后,重新在判断,是否确实按下{xh = 1;flag2=2;spk=1;		  //蜂鸣器不响flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs1();	  //显示选手编号djsxs30();	  //第二位数码管显示djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);		   //去除抖动if(keyqc==0){ while(!keyqc); //如果按下清楚键,则回到- --状态goto LOOP1;		  //goto语句,回到loop1表号处}}										   }}}if((key2==0)&&(TR0==1)){	spk=0;delayms(3);if(key2==0){ while(!key2);{xh = 2;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs2();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key3==0)&&(TR0==1)){	spk=0;delayms(3);if(key3==0){ while(!key3);{xh = 3;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs3();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key4==0)&&(TR0==1)){	spk=0;delayms(3);if(key4==0){ while(!key4);{xh = 4;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs4();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key5==0)&&(TR0==1)){	spk=0;delayms(3);if(key5==0){ while(!key5);{xh = 5;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs5();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key6==0)&&(TR0==1)){  spk=0;delayms(3);if(key6==0){ while(!key6);{xh = 6;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs6();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key7==0)&&(TR0==1)){	spk=0;delayms(3);if(key7==0){ while(!key7);{xh = 7;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs7();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}	   }}}if((key8==0)&&(TR0==1)){	spk=0;delayms(3);if(key8==0){ while(!key8);{xh = 8;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs8();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}	   }}} if(djs<=5)  {flag=1; }//spk=0;	  //到倒计时小于5是,蜂鸣器响if(djs==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;while(1){if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);spk=1;		  goto LOOP1;	}}}} }}}if(flag3 == 0){if(key2==0){delayms(3);if(key2 == 0){spk = 0;while(!key2);}}if(key3==0){delayms(3);if(key3 == 0){spk = 0;while(!key3);}}if(key4==0){delayms(3);if(key4 == 0){spk = 0;while(!key4);}}if(key5==0){delayms(3);if(key5 == 0){spk = 0;while(!key5);}}if(key6==0){delayms(3);if(key6 == 0){spk = 0;while(!key6);}}if(key7==0){delayms(3);if(key7 == 0){spk = 0;while(!key7);}}if(key8==0){delayms(3);if(key8 == 0){spk = 0;while(!key8);}}}}}

四、实现现象

具体动态效果看B站演示视频:

基于单片机的8路抢答器加记分_哔哩哔哩_bilibili

全部资料(源程序、仿真文件、安装包、原理图、演示视频):
链接: https://pan.baidu.com/s/1bYm0-YgFOqER36jrQ_xpTQ?pwd=49kj 提取码: 49kj 
 

相关文章:

53 基于单片机的8路抢答器加记分

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 首先有三个按键 分别为开始 暂停 复位&#xff0c;然后八个选手按键&#xff0c;开机显示四条杠&#xff0c;然后按一号选手按键&#xff0c;数码管显示&#xff13;&#xff10;&#xff0c;这…...

【java数据结构】二叉树OJ题

【java数据结构】二叉树OJ题 一、检查两颗树是否相同二、另一颗树的子树三、翻转二叉树四、对称二叉树五、判断一颗二叉树是否是平衡二叉树六、给定一个二叉树, 找到该树中两个指定节点的最近公共祖先七、根据一棵树的前序遍历与中序遍历构造二叉树练习&#xff1a;八、二叉树前…...

IIC和SPI的时序图

SCL的变化快慢决定了通信速率&#xff0c;当SCL为低电平的时候&#xff0c;无论SDA是1还是0都不识别&#xff1a; ACK应答&#xff1a;当从设备为低电平的时候识别为从设备有应答&#xff1a; 谁接收&#xff0c;谁应答&#xff1a; 起始位和停止位&#xff1a; IIC的时序图&am…...

MySQL数据库表的操作

1、总述 今天我跟大家分享MySQL数据库中表的创建&#xff0c;查看&#xff0c;修改&#xff0c;删除。 2、创建表 create table table_name ( field1 datatype, field2 datatype, field3 datatype ) character set 字符集 collate 校验规则 engine 存储引擎; 说明&#xff1…...

.net core 创建linux服务,并实现服务的自我更新

目录 创建服务创建另一个服务&#xff0c;用于执行更新操作给你的用户配置一些systemctl命令权限 创建服务 /etc/systemd/system下新建服务配置文件&#xff1a;yourapp.service&#xff0c;内容如下&#xff1a; [Unit] Descriptionyourapp Afternetwork.target[Service] Ty…...

springboot338it职业生涯规划系统--论文pf(论文+源码)_kaic

毕 业 设 计&#xff08;论 文&#xff09; 题目&#xff1a;it职业生涯规划系统的设计与实现 摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以…...

oracle将select作为字段查询

在Oracle中&#xff0c;如果你想将一个SELECT语句作为字段的值&#xff0c;你可以使用子查询或者使用WITH子句&#xff08;也称为公用表表达式CTE&#xff09;。以下是两种方法的示例&#xff1a; 方法1&#xff1a;使用子查询 语法如下&#xff1a; SELECTcolumn1,(SELECT …...

Java数据结构和算法相关面试题

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…...

网络安全风险评估

项目背景 随着信息化技术的快速发展&#xff0c;特别是面向社会、政府机构、企业等业务系统的投入使用&#xff0c;各组织机构对网络和信息系统安全防护都提出了新的要求。为满足安全需求&#xff0c;需对组织机构的网络和信息系统的安全进行一次系统全面的评估&#xff0c;以…...

ADAM优化算法与学习率调度器:深度学习中的关键工具

深度学习模型的训练效果离不开优化算法和学习率的选择。ADAM&#xff08;Adaptive Moment Estimation&#xff09;作为深度学习领域中广泛应用的优化算法之一&#xff0c;以其高效性和鲁棒性成为许多任务的默认选择。而学习率调度器则是优化算法的“助推器”&#xff0c;帮助训…...

岛屿数量C++11新特性

每日一题 200. 岛屿数量 class Solution {//使用深度的优先搜索来搜索岛屿图//遍历整个图片 当char数组的值为1时开始从这个点开始往外扩散搜索//注意处理边界 图不是正方形 public:int ans;int d[4][2] {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};int N;int M;void dfs(vector<…...

Git 快速入门:全面了解与安装步骤

Git 快速入门&#xff1a;全面了解与安装步骤 一、关于Git 1.1 简介 Git 是一个开源的分布式版本控制系统&#xff0c;由 Linus Torvalds 于 2005 年创建&#xff0c;最初是为了更好地管理 Linux 内核开发而设计。 Git用于跟踪计算机文件的变化&#xff0c;特别是源代码文件…...

基于域自适应的双光融合

目录 引言DAF-Net编码器-解码器分支编码器部分融合层解码器部分 域自适应层概述多核最大均值差异&#xff08;MK-MMD&#xff09;第一阶段&#xff1a;编码器-解码器分支训练训练过程损失函数 第二阶段&#xff1a;融合层训练训练过程损失函数 实验与结果总结 文章声明&#xf…...

迭代器模式 (Iterator Pattern)

文章目录 迭代器模式 (Iterator Pattern)原理优点缺点示例代码场景描述1. 定义迭代器接口2. 定义集合接口3. 实现具体集合类4. 客户端代码输出结果 UML 类图使用场景优化与扩展小结 迭代器模式 (Iterator Pattern) 迭代器模式是一种 行为型设计模式&#xff0c;用于顺序访问集…...

039集——渐变色之:CAD中画彩虹()(CAD—C#二次开发入门)

&#xff08;来左边儿 跟我一起画个龙&#xff0c;在你右边儿 画一道彩虹 ~~~~~~~~~~~ &#xff09; 效果如下&#xff1a; namespace AcTools {public class Class1{public Wform.Timer timer;//定时器需建在类下面public static DateTime startTime;[CommandM…...

如何将 GitHub 私有仓库(private)转换为公共仓库(public)

文章目录 如何将 GitHub 私有仓库转换为公共仓库步骤 1: 登录 GitHub步骤 2: 导航到目标仓库步骤 3: 访问仓库设置步骤 4: 更改仓库可见性步骤 5: 确认更改步骤 6: 验证更改注意事项 如何将 GitHub 私有仓库转换为公共仓库 在软件开发领域&#xff0c;GitHub 是一个广受欢迎的…...

C++11 右值引用

目录 左值 右值 左值引用与右值引用比较 左值引用总结&#xff1a; 右值引用总结&#xff1a; 左值引用的使用场景&#xff1a; 引用传参和做返回值都可以提高效率(减少拷贝) 左值引用的短板&#xff1a; 右值引用和移动语义解决上述问题&#xff1a; 下面就是有移动…...

WPS表格学习计划与策略

一、学习目标 掌握WPS表格的基本操作:包括新建、打开、保存工作簿,单元格的编辑与格式化,数据的输入与验证等。熟练运用WPS表格的数据处理功能:包括数据排序、筛选、分类汇总,以及使用公式和函数进行计算和分析。学会制作图表与数据可视化:掌握不同类型图表(如柱状图、折…...

Android 引入 proto 项目及使用方法

Proto&#xff08;Protocol Buffers&#xff09;是Google开发的一种语言无关、平台无关的序列化结构数据的方法&#xff0c;它类似于JSON和XML&#xff0c;但相对于XML而言更小&#xff0c;相对于JSON而言解析更快&#xff0c;支持多语言。以下是将Proto引入Android项目的方法及…...

VSOMEIP主要流程的时序

请求服务: client应用&#xff1a; ​ application_impl::request_service ​ routing_manager_client::request_service (老版本是routing_manager_proxy) ​ routing_manager_client::send_request_services ​ protocol::request_service_command its_command; // 创建…...

后进先出(LIFO)详解

LIFO 是 Last In, First Out 的缩写&#xff0c;中文译为后进先出。这是一种数据结构的工作原则&#xff0c;类似于一摞盘子或一叠书本&#xff1a; 最后放进去的元素最先出来 -想象往筒状容器里放盘子&#xff1a; &#xff08;1&#xff09;你放进的最后一个盘子&#xff08…...

生成xcframework

打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式&#xff0c;可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...

以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:

一、属性动画概述NETX 作用&#xff1a;实现组件通用属性的渐变过渡效果&#xff0c;提升用户体验。支持属性&#xff1a;width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项&#xff1a; 布局类属性&#xff08;如宽高&#xff09;变化时&#…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案

问题描述&#xff1a;iview使用table 中type: "index",分页之后 &#xff0c;索引还是从1开始&#xff0c;试过绑定后台返回数据的id, 这种方法可行&#xff0c;就是后台返回数据的每个页面id都不完全是按照从1开始的升序&#xff0c;因此百度了下&#xff0c;找到了…...

AI编程--插件对比分析:CodeRider、GitHub Copilot及其他

AI编程插件对比分析&#xff1a;CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展&#xff0c;AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者&#xff0c;分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...

Maven 概述、安装、配置、仓库、私服详解

目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...

Springboot社区养老保险系统小程序

一、前言 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;社区养老保险系统小程序被用户普遍使用&#xff0c;为方…...

Reasoning over Uncertain Text by Generative Large Language Models

https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...

纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join

纯 Java 项目&#xff08;非 SpringBoot&#xff09;集成 Mybatis-Plus 和 Mybatis-Plus-Join 1、依赖1.1、依赖版本1.2、pom.xml 2、代码2.1、SqlSession 构造器2.2、MybatisPlus代码生成器2.3、获取 config.yml 配置2.3.1、config.yml2.3.2、项目配置类 2.4、ftl 模板2.4.1、…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…...