蓝桥杯模块综合——高质量讲解AT24C02,BS18B20,BS1302,AD/DA(PCF8591),超声波模块
AT24C02——就是一个存储的东西,可以给他写东西,掉电不丢失。
void EEPROM_Write(unsigned char * EEPROM_String,unsigned char addr , unsigned char num)
{IIC_Start();IIC_SendByte(0xA0);IIC_WaitAck();IIC_SendByte(addr);IIC_WaitAck();while(num--){IIC_SendByte(*EEPROM_String++);IIC_WaitAck();IIC_Delay(200);}IIC_Stop();
}
void EEPROM_Read(unsigned char * EEPROM_String,unsigned char addr , unsigned char num)
{IIC_Start();IIC_SendByte(0xA0);IIC_WaitAck();IIC_SendByte(addr);IIC_WaitAck();IIC_Start();IIC_SendByte(0xA1);IIC_WaitAck();while(num--){*EEPROM_String++=IIC_RecByte();if(num) IIC_SendAck(0);//·¢ËÍÓ¦´ðelse IIC_SendAck(1);}IIC_Stop();
}
这个是这个代码,先开始IIC看他在不在(0xA0)等待应答,然后发送要写的页,和字节。然后发送然后等待 停止。
读——
一样的是先开始,然后找他,等待,然后写入页,然后IIC开始,进入读模式,然后等待。然后将读的东西给,数组。if num==0 就停止应答
下面是测试代码:
#include <STC15F2K60S2.H>
#include <iic.h>
void EEPROM_Write(unsigned char * EEPROM_String,unsigned char addr , unsigned char num);
void EEPROM_Read(unsigned char * EEPROM_String,unsigned char addr , unsigned char num);
unsigned char code Duan[22]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,
0xc6,0xc0,0x86,0x8e,0xbf,0x7f,0XC1,0X8C,0XC8,0xc3};
unsigned char dat[2]={30,60},keynum;
void Delay(unsigned int t)
{while(t--);}
void suocun(unsigned char n)
{switch(n){case 4:P2=(P2 & 0x1f)|0x80;break;case 5:P2=(P2 & 0x1f)|0xa0;break;case 6:P2=(P2 & 0x1f)|0xc0;break;case 7:P2=(P2 & 0x1f)|0xe0;break;}
}
void smg(unsigned char wei,unsigned char shu)
{suocun(6);P0=0x01<<wei;suocun(7);P0=Duan[shu];Delay(500);P0=0xff;
}
void shuma()
{smg(0,dat[0]/10);Delay(100);smg(1,dat[0]%10);Delay(100);smg(6,dat[1]/10);Delay(100);smg(7,dat[1]%10);Delay(100);
}
void jvzhen()
{P30=P31=P32=P33=1;P34=P35=P42=1;P44=0;if(P33==0){Delay(100);keynum=4;while(P33==0){shuma();}}if(P32==0){Delay(100);keynum=5;while(P32==0){shuma();}}if(P31==0){Delay(100);keynum=6;while(P31==0){shuma();}}if(P30==0){Delay(100);keynum=7;while(P30==0){shuma();}}
}
void zhixing()
{if(keynum==4){dat[0]+=10;keynum=0;}if(keynum==5){dat[0]-=10;keynum=0;}if(keynum==6){EEPROM_Write(dat,0,2);keynum=0;}}
void EEPROM_Write(unsigned char * EEPROM_String,unsigned char addr , unsigned char num)
{IIC_Start();IIC_SendByte(0xA0);IIC_WaitAck();IIC_SendByte(addr);IIC_WaitAck();while(num--){IIC_SendByte(*EEPROM_String++);IIC_WaitAck();IIC_Delay(200);}IIC_Stop();
}
void EEPROM_Read(unsigned char * EEPROM_String,unsigned char addr , unsigned char num)
{IIC_Start();IIC_SendByte(0xA0);IIC_WaitAck();IIC_SendByte(addr);IIC_WaitAck();IIC_Start();IIC_SendByte(0xA1);IIC_WaitAck();while(num--){*EEPROM_String++=IIC_RecByte();if(num) IIC_SendAck(0);//·¢ËÍÓ¦´ðelse IIC_SendAck(1);}IIC_Stop();
}void main()
{EEPROM_Read(dat,0,2);while(1){shuma();jvzhen();zhixing();}
}
DS18B20——温度读取
float read_t()
{unsigned char low,high;init_ds18b20();Write_DS18B20(0xcc);Write_DS18B20(0x44);init_ds18b20();Write_DS18B20(0xcc);Write_DS18B20(0xbe);low = Read_DS18B20();high = Read_DS18B20();return ((high<<8)|low)/16.0;}
下面是测试代码,可能会有温度显示不正常,一直是85,就是DS18B20的Delay不正常,要在里面有一句 t*=12
#include <STC15F2K60S2.H>
#include <onewire.h>
#include <intrins.h>
sbit s0 = P3^0;
sbit s1 = P3^1;
sbit s2 = P3^2;
sbit s3 = P3^3;sbit r0 = P3^4;
sbit r1 = P3^5;
sbit r2 = P4^2;
sbit r3 = P4^4;
float t=31.5;
unsigned char keynum;
unsigned char code Duan[22]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,
0xc6,0xc0,0x86,0x8e,0xbf,0x7f,0XC1,0X8C,0XC8,0xc3};
void Delay750ms() //@12.000MHz
{unsigned char i, j, k;_nop_();_nop_();i = 35;j = 51;k = 182;do{do{while (--k);} while (--j);} while (--i);
}void Delaysmg(unsigned int t)
{while(t--);
}
void Delayjan(unsigned char t)
{while(t--);
}
void suocun(unsigned char n)
{switch(n){case 4:P2 = (P2 & 0x1f) | 0x80; break;case 5:P2 = (P2 & 0x1f) | 0xa0; break;case 6:P2 = (P2 & 0x1f) | 0xc0; break;case 7:P2 = (P2 & 0x1f) | 0xe0; break;case 0:P2 = (P2 & 0x1f) | 0x00; break;}
}
void shuma(unsigned char wei,unsigned char shu)
{suocun(6);P0=0x01<<wei;suocun(0);suocun(7);P0=Duan[shu];Delaysmg(1000);P0=0xff;suocun(0);
}
void shumadong()
{t = read_t();shuma(5,(int)t/10%10);Delaysmg(500);shuma(6,(int)t%10);Delaysmg(500);shuma(7,(int)(t*10)%10);Delaysmg(500);}
void Delay_Key(unsigned char t)
{while(t--);
}
void jvzhen()
{s0=0;s1=s2=s3=1;r0=r1=r2=r3=1;if(r3==0){while(r3==0);keynum=0;shumadong();}
//=============================s0=0;s1=s2=s3=1;r0=r1=r2=r3=1;if(r2==0){while(r2==0);keynum=1;shumadong();}
//=============================s0=0;s1=s2=s3=1;r0=r1=r2=r3=1;if(r1==0){while(r1==0);keynum=2;shumadong();}
//=============================s0=0;s1=s2=s3=1;r0=r1=r2=r3=1;if(r2==0){while(r2==0);keynum=2;shumadong();}
//=========================================================s1=0;s0=s2=s3=1;r0=r1=r2=r3=1;if(r3==0){while(r3==0);keynum=3;shumadong();}
//=============s1=0;s0=s2=s3=1;r0=r1=r2=r3=1;if(r2==0){while(r2==0);keynum=4;shumadong();}
//=============s1=0;s0=s2=s3=1;r0=r1=r2=r3=1;if(r1==0){while(r1==0);keynum=5;shumadong();}
//====================================s2=0;s0=s1=s3=1;r0=r1=r2=r3=1;if(r3==0){while(r3==0);keynum=6;shumadong();}
//===================s2=0;s0=s1=s3=1;r0=r1=r2=r3=1;if(r2==0){while(r2==0);keynum=7;shumadong();}
//====================s2=0;s0=s1=s3=1;r0=r1=r2=r3=1;if(r1==0){while(r1==0);keynum=8;shumadong();}
//=================================s3=0;s0=s1=s2=1;r0=r1=r2=r3=1;if(r3==0){while(r3==0);keynum=9;shumadong();}
}
void main()
{while(1){shumadong();}
}
DS1302——时间的计时
unsigned char wirter[7]={0x80,0x82,0x84,0x86,0x88,0x8a,0x8c};
unsigned char read[7]={0x81,0x83,0x85,0x87,0x89,0x8b,0x8d};
//20Äê18ÈÕ ÖÜÁù 23.59.24
unsigned char Timer[7]={0x24,0x59,0x23,0x18,0x04,0x06,0x20};
unsigned char code Duan[22]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,
0xc6,0xc0,0x86,0x8e,0xbf,0x7f,0XC1,0X8C,0XC8,0xc3};
void Delaysmg(unsigned int t)
{while(t--);
}
void Ds1302()
{char i;Write_Ds1302_Byte(0x8e,0x00);for (i=0;i<7;i++){Write_Ds1302_Byte(wirter[i],Timer[i]);}Write_Ds1302_Byte(0x8e,0x80);
}
void readds()
{char i;for(i=0;i<7;i++){Timer[i]=Read_Ds1302_Byte(read[i]);}
}
写入有七个地址,读也是七个,然后存入数据 ,,上面我是 2020年周六4月18日,23分59分24秒
刚刚好七位,就是分别写入七个地址。
下面是测试代码:
#include <STC15F2K60S2.H>
#include <ds1302.h>
unsigned char wirter[7]={0x80,0x82,0x84,0x86,0x88,0x8a,0x8c};
unsigned char read[7]={0x81,0x83,0x85,0x87,0x89,0x8b,0x8d};
//20Äê18ÈÕ ÖÜÁù 23.59.24
unsigned char Timer[7]={0x24,0x59,0x23,0x18,0x04,0x06,0x20};
unsigned char code Duan[22]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,
0xc6,0xc0,0x86,0x8e,0xbf,0x7f,0XC1,0X8C,0XC8,0xc3};
void Delaysmg(unsigned int t)
{while(t--);
}
void Ds1302()
{char i;Write_Ds1302_Byte(0x8e,0x00);for (i=0;i<7;i++){Write_Ds1302_Byte(wirter[i],Timer[i]);}Write_Ds1302_Byte(0x8e,0x80);
}
void readds()
{char i;for(i=0;i<7;i++){Timer[i]=Read_Ds1302_Byte(read[i]);}
}
void suocun(unsigned char n)
{switch(n){case 4:P2=(P2 & 0x1f)|0x80;break;case 5:P2=(P2 & 0x1f)|0xa0;break;case 6:P2=(P2 & 0x1f)|0xc0;break;case 7:P2=(P2 & 0x1f)|0xe0;break;case 0:P2=(P2 & 0x1f)|0x00;break;}
}
void smg(unsigned char wei,unsigned char shu)
{suocun(6);P0=0x01<<wei;suocun(7);P0=Duan[shu];Delaysmg(500);P0=0xff;
}
void xianshi()
{smg(0,Timer[2]/16);Delaysmg(100);smg(1,Timer[2]%16);Delaysmg(100);smg(3,Timer[1]/16);Delaysmg(100);smg(4,Timer[1]%16);Delaysmg(100);smg(6,Timer[0]/16);Delaysmg(100);smg(7,Timer[0]%16);Delaysmg(100);}
void main()
{Ds1302();while(1){readds();xianshi();}
}
PCF8591——数模转换 AD/DA
unsigned char Ad_read(unsigned char addr)
{unsigned char temp;IIC_Start();IIC_SendByte(0x90);//дÈëIIC_WaitAck();IIC_SendByte(addr);//Òª¶ÁµÄÊÇIIC_WaitAck();IIC_Start();IIC_SendByte(0x91);//¶ÁIIC_WaitAck();temp = IIC_RecByte();IIC_SendAck(1);IIC_Stop();return temp;
}void Da_write(unsigned char dat)
{IIC_Start();IIC_SendByte(0x90);//дÈëIIC_WaitAck();IIC_SendByte(0x41);//ʹÄÜDACIIC_WaitAck();IIC_SendByte(dat);//дÈëIIC_WaitAck();IIC_Stop();
}
经典的IIC。
读——
开始IIC,发送找到模块(0x90),等待,然后从哪里读数据,等待,然后IIC开始读,停止响应,然后IIC停止。
写——
开始 写数据,写入到0x41(0x43)等待响应,写入,然后写入。
测试代码:
#include <STC15F2K60S2.H>
#include <iic.h>
unsigned char code Duan[22]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,
0xc6,0xc0,0x86,0x8e,0xbf,0x7f,0XC1,0X8C,0XC8,0xc3};
unsigned char dat;
void Delay(unsigned int t)
{while(t--);
}
void suocun(unsigned char n)
{switch(n){case 4:P2=(P2 & 0x1f)|0x80;break;case 5:P2=(P2 & 0x1f)|0xa0;break;case 6:P2=(P2 & 0x1f)|0xc0;break;case 7:P2=(P2 & 0x1f)|0xe0;break;}
}
void shuma(unsigned char wei,unsigned char shu)
{suocun(6);P0=0x01<<wei;suocun(7);P0=Duan[shu];Delay(500);P0=0xff;
}
void xianshi()
{shuma(1,1);Delay(100);shuma(2,2);Delay(100);
}
void chuli()
{dat=Ad_read(0x43);shuma(0,dat/100%10);Delay(100);shuma(1,dat/10%10);Delay(100);shuma(2,dat%10);Delay(100);}
void main()
{while(1){chuli();}
}
超声波——

左边发松所以左边为TX ,右边为RX
void Ut_Wave_init()
{unsigned char i;for(i=0;i<8;i++){TX=1;Delay12us();TX=0;Delay12us();}
}
unsigned char Ut_Wave_Data()
{unsigned int time;TMOD &= 0x0f;TH1=TL1=0;Ut_Wave_init();TR1=1;while((RX==1)&&(TF1 == 0));TR1=0;if(TF1==0){time = TH1<<8|TL1;return (time*0.017);}else{TF1=0;return 0;}
}
发送一个方波信号,
然后就是用定时器1去完成,波的计算。发送完成之后开启定时器,然后等待,如果RX==0 或者计数溢出(TF1=1)就会退出,停止计数。得到TH1和TL1。然后输出距离.
实例代码:
#include <STC15F2K60S2.H>
#include <intrins.h>
sbit TX = P1^0;
sbit RX = P1^1;
floatjvli;
unsigned char code Duan[22]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,
0xc6,0xc0,0x86,0x8e,0xbf,0x7f,0XC1,0X8C,0XC8,0xc3};void Delay12us() //@12.000MHz
{unsigned char i;_nop_();_nop_();i = 33;while (--i);
}
void Delay(unsigned int t)
{while(t--);
}
void suocun(unsigned char n)
{switch(n){case 4:P2= (P2 & 0x1f)|0x80;break;case 5:P2= (P2 & 0x1f)|0xa0;break;case 6:P2= (P2 & 0x1f)|0xc0;break;case 7:P2= (P2 & 0x1f)|0xe0;break;}
}
void smg(unsigned char wei,unsigned char shu)
{suocun(6);P0=0x01<<wei;suocun(7);P0=Duan[shu];Delay(500);P0=0xff;
}
void Ut_Wave_init()
{unsigned char i;for(i=0;i<8;i++){TX=1;Delay12us();TX=0;Delay12us();}
}
unsigned char Ut_Wave_Data()
{unsigned int time;TMOD &= 0x0f;TH1=TL1=0;Ut_Wave_init();TR1=1;while((RX==1)&&(TF1 == 0));TR1=0;if(TF1==0){time = TH1<<8|TL1;return (time*0.017);}else{TF1=0;return 0;}
}
void xianshi()
{smg(1,(int)jvli/100%10);Delay(100);smg(2,(int)jvli/10%10);Delay(100);smg(3,(int)jvli%10);Delay(100);}
void main()
{while(1){jvli=Ut_Wave_Data();xianshi();}
}
相关文章:
蓝桥杯模块综合——高质量讲解AT24C02,BS18B20,BS1302,AD/DA(PCF8591),超声波模块
AT24C02——就是一个存储的东西,可以给他写东西,掉电不丢失。 void EEPROM_Write(unsigned char * EEPROM_String,unsigned char addr , unsigned char num) {IIC_Start();IIC_SendByte(0xA0);IIC_WaitAck();IIC_SendByte(addr);IIC_WaitAck();while(nu…...
前端跨平台开发框架:简化多端开发的利器
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
cesium.js加载模型后,重新设置旋转角度属性值
// 加载模型var position Cesium.Cartesian3.fromDegrees(longitude, latitude, height);// 计算矩阵var rollAngleDegrees 15; // 设置翻滚角度var rollAngleRadians Cesium.Math.toRadians(rollAngleDegrees); // 将角度转换为弧度var orientation Cesium.Transforms.eas…...
②免费AI软件开发工具测评:通义灵码 VS 码上飞
前言 我又双叒叕来测评了!上次给大家带来的是iFlyCode和CodeFlying两款产品的测评,受到了大家的一致好评~ 今天咱就继续来聊聊,这次我们选的的对象是通义灵码和码上飞,从名字上也能看到出来这两款产品一定是跟软件开发有关系的&…...
幻兽帕鲁游戏搭建(docker)
系列文章目录 第一章: 幻兽帕陆游戏搭建 文章目录 系列文章目录前言一、镜像安装1.创建游戏目录2.拉取镜像3.下载配置文件4.启动游戏 二、自定义配置总结 前言 这段时间一直在写论文还有找工作,也没学啥新技术,所以博客也很长时间没写了&am…...
unity报错出现Asset database transaction committed twice!
错误描述: 运行时报错 Assertion failed on expression: ‘m_ErrorCode MDB_MAP_RESIZED || !HasAbortingErrors()’Asset database transaction committed twice!Assertion failed on expression: ‘errors MDB_SUCCESS || errors MDB_NOTFOUND’ 解决办法&…...
去除项目git的控制 端口号的关闭
以下操作都是在windows下。只是记录一下。 find . -name “.git” | xargs rm -rf 查看所有分支 git branch -a 查看当前分支 git branch -a 切换分支 git chenkout develop docker 查看容器的ip docker inspect -f ‘{{.Name}} - {{range .NetworkSettings.Networks}}{{.IP…...
交叉注意力融合时域、频域特征的FFT + CNN -BiLSTM-CrossAttention电能质量扰动识别模型
往期精彩内容: 电能质量扰动信号数据介绍与分类-Python实现-CSDN博客 Python电能质量扰动信号分类(一)基于LSTM模型的一维信号分类-CSDN博客 Python电能质量扰动信号分类(二)基于CNN模型的一维信号分类-CSDN博客 Python电能质量扰动信号分类(三)基于Transformer…...
简单的Charles抓包教程
安装Charles 安装地址:https://www.charlesproxy.com/download/ 开关本机抓包 一般我们在抓取手机端内容时需要将Proxy菜单栏下的Windows Proxy取消勾选,禁止charles抓取本机上的请求信息。 注:开启电脑端抓包后,会为电脑添加局…...
如何构建Docker自定义镜像
说明:平常我们使用Docker运行各种容器,极大地方便了我们对开发应用的使用,如MySQL、Redis,以及各种中间件,使用时只要拉镜像,运行容器即可。本文介绍如何创建一个Demo,自定义构建一个镜像。 开…...
一起学数据分析_2
写在前面:代码运行环境为jupyter,如果结果显示不出来的地方就加一个print()函数。 一、数据基本处理 缺失值处理: import numpy as np import pandas as pd#加载数据train.csv df pd.read_csv(train_chinese.csv) df.head()# 查看数据基本…...
请解释Redis是什么?它有哪些主要应用场景?Redis支持哪些数据类型?并描述每种数据类型的特性和使用场景。
请解释Redis是什么?它有哪些主要应用场景? Redis是一款内存高速缓存NoSQL数据库,使用C语言编写,它支持丰富的数据类型,如String、list、set、zset、hash等,并且这些数据类型都直接支持数据的原子性操作&…...
在centos8中部署Tomcat和Jenkins
参考链接1:tomcat安装和部署jenkins_jenkins和tomcat-CSDN博客 参考链接2:--配置开机启动tomcat文件 x超详细:Centos8安装Tomcat并配置开机自动启动_centos设置tomcat开机自启-CSDN博客文章浏览阅读4.4k次,点赞4次&…...
机器学习模型—K means
文章目录 机器学习模型—K means聚类的目标k 均值原理k 均值 的实现手动实现Python 实现K 的确定 手肘法总结机器学习模型—K means K-Means 聚类是一种无监督机器学习算法,它将未标记的数据集分为不同的簇。本文旨在探讨 k 均值聚类的基本原理和工作原理以及实现。 无监督机…...
QT UI设计
在QT中添加VTK 在main函数中初始化 //VTK的初始化语句 #ifndef INITIAL_OPENGL #define INITIAL_OPENGL #include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL); VTK_MODULE_INIT(vtkInteractionStyle); VTK_MODULE_INIT(vtkRenderingVolumeOpenGL); VTK_MODU…...
前端小白的学习之路(CSS3 一)
提示:CSS3 是 Cascading Style Sheets(层叠样式表)的第三个主要版本,引入了许多新的特性和增强功能,用于设计和布局网页。本章记录CSS3新增选择器,盒子模型。 目录 一、C3新增选择器 1) 属性选择器 1.[c…...
春暖花开,一起来看看2024年品牌春分海报吧!
春分(Vernal equinox)已至,春花烂漫、燕子归来、百草回芽。 今天我们要分享的是2024年品牌发布的春分节气海报合集,快来随我们一起感受这昂扬、蓬勃的春意吧! (1)泸州老窖 (2)BD…...
golang面试题总结
零、go与其他语言 0、什么是面向对象 在了解 Go 语言是不是面向对象(简称:OOP) 之前,我们必须先知道 OOP 是啥,得先给他 “下定义” 根据 Wikipedia 的定义,我们梳理出 OOP 的几个基本认知: …...
BUGKU-WEB shell
题目描述 题目截图如下: 描述: $poc "a#s#s#e#r#t";$poc_1 explode("#", $poc);$poc_2 $poc_1[0].$poc_1[1].$poc_1[2].$poc_1[3].$poc_1[4].$poc_1[5];$poc_2($_GET[s])进入场景看看:是一个空白的界面 解题思路 …...
系统重构后,对项目定制开发的兼容性问题
公司自实施产品线战略以来,基本推翻了全部旧有业务模块。后续以标准产品二次开发的模式进行项目开发。但在涉及到一些旧有系统二期、三期升级改造过程中。不可避免的需要解决旧有系统的客户定制化开发兼容性问题。也就是旧有系统定制开发的模块不能丢弃。重新开发从…...
Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动
一、前言说明 在2011版本的gb28181协议中,拉取视频流只要求udp方式,从2016开始要求新增支持tcp被动和tcp主动两种方式,udp理论上会丢包的,所以实际使用过程可能会出现画面花屏的情况,而tcp肯定不丢包,起码…...
.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...
渲染学进阶内容——模型
最近在写模组的时候发现渲染器里面离不开模型的定义,在渲染的第二篇文章中简单的讲解了一下关于模型部分的内容,其实不管是方块还是方块实体,都离不开模型的内容 🧱 一、CubeListBuilder 功能解析 CubeListBuilder 是 Minecraft Java 版模型系统的核心构建器,用于动态创…...
Psychopy音频的使用
Psychopy音频的使用 本文主要解决以下问题: 指定音频引擎与设备;播放音频文件 本文所使用的环境: Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...
select、poll、epoll 与 Reactor 模式
在高并发网络编程领域,高效处理大量连接和 I/O 事件是系统性能的关键。select、poll、epoll 作为 I/O 多路复用技术的代表,以及基于它们实现的 Reactor 模式,为开发者提供了强大的工具。本文将深入探讨这些技术的底层原理、优缺点。 一、I…...
08. C#入门系列【类的基本概念】:开启编程世界的奇妙冒险
C#入门系列【类的基本概念】:开启编程世界的奇妙冒险 嘿,各位编程小白探险家!欢迎来到 C# 的奇幻大陆!今天咱们要深入探索这片大陆上至关重要的 “建筑”—— 类!别害怕,跟着我,保准让你轻松搞…...
mac 安装homebrew (nvm 及git)
mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用: 方法一:使用 Homebrew 安装 Git(推荐) 步骤如下:打开终端(Terminal.app) 1.安装 Homebrew…...
用鸿蒙HarmonyOS5实现中国象棋小游戏的过程
下面是一个基于鸿蒙OS (HarmonyOS) 的中国象棋小游戏的实现代码。这个实现使用Java语言和鸿蒙的Ability框架。 1. 项目结构 /src/main/java/com/example/chinesechess/├── MainAbilitySlice.java // 主界面逻辑├── ChessView.java // 游戏视图和逻辑├──…...
xmind转换为markdown
文章目录 解锁思维导图新姿势:将XMind转为结构化Markdown 一、认识Xmind结构二、核心转换流程详解1.解压XMind文件(ZIP处理)2.解析JSON数据结构3:递归转换树形结构4:Markdown层级生成逻辑 三、完整代码 解锁思维导图新…...
如何通过git命令查看项目连接的仓库地址?
要通过 Git 命令查看项目连接的仓库地址,您可以使用以下几种方法: 1. 查看所有远程仓库地址 使用 git remote -v 命令,它会显示项目中配置的所有远程仓库及其对应的 URL: git remote -v输出示例: origin https://…...
