USB转NRF24L01与单片机通信 1C

我用的山外串口软件 不知道怎么写目标地址 更改波特率 等等

2个回答

如果是转成串口通讯,只需要知道串口号就行,不需要其它地址啊。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
基于单片机STC15W401AS的nRF24L01无线通信无法调通
# 这是发送部分的程序和接收部分 ``` #include<STC15F2K60S2.h> #include"global_define.h" #include"NRF24L01.h" #include"Delay.h" sbit CE=P5^5; //RX/TX模式选择端 sbit IRQ=P3^7; //可屏蔽中断端 sbit CSN=P5^4; //SPI片选端//就是SS sbit MOSI=P1^3; //SPI主机输出从机输入端 sbit MISO=P1^4; //SPI主机输出从机输出端 sbit SCLK=P1^5; //SPI时钟端 uchar code TxAddr[]={0x34,0x43,0x10,0x10,0x01};//发送地址 /*****************状态标志*****************************************/ uchar bdata sta; //状态标志 sbit RX_DR=sta^6; sbit TX_DS=sta^5; sbit MAX_RT=sta^4; /*****************SPI时序函数******************************************/ uchar NRFSPI(uchar date) { uchar i; for(i=0;i<8;i++) // 循环8次 { if(date&0x80) MOSI=1; else MOSI=0; // byte最高位输出到MOSI date<<=1; // 低一位移位到最高位 SCLK=1; if(MISO) // 拉高SCK,nRF24L01从MOSI读入1位数据,同时从MISO输出1位数据 date|=0x01; // 读MISO到byte最低位 SCLK=0; // SCK置低 } return(date); // 返回读出的一字节 } /**********************NRF24L01初始化函数*******************************/ void NRF24L01Int() { Delay(2);//让系统什么都不干 CE=0; //待机模式1 CSN=1; SCLK=0; IRQ=1; } /*****************SPI读寄存器一字节函数*********************************/ uchar NRFReadReg(uchar RegAddr) { uchar BackDate; CSN=0;//启动时序 NRFSPI(RegAddr);//写寄存器地址 BackDate=NRFSPI(0x00);//写入读寄存器指令 CSN=1; return(BackDate); //返回状态 } /*****************SPI写寄存器一字节函数*********************************/ uchar NRFWriteReg(uchar RegAddr,uchar date) { uchar BackDate; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入地址 NRFSPI(date);//写入值 CSN=1; return(BackDate); } /*****************SPI读取RXFIFO寄存器的值********************************/ uchar NRFReadRxDate(uchar RegAddr,uchar *RxDate,uchar DateLen) { //寄存器地址//读取数据存放变量//读取数据长度//用于接收 uchar BackDate,i; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入要读取的寄存器地址 for(i=0;i<DateLen;i++) //读取数据 { RxDate[i]=NRFSPI(0); } CSN=1; return(BackDate); } /*****************SPI写入TXFIFO寄存器的值**********************************/ uchar NRFWriteTxDate(uchar RegAddr,uchar *TxDate,uchar DateLen) { //寄存器地址//写入数据存放变量//读取数据长度//用于发送 uchar BackDate,i; CSN=0; BackDate=NRFSPI(RegAddr);//写入要写入寄存器的地址 for(i=0;i<DateLen;i++)//写入数据 { NRFSPI(*TxDate++); } CSN=1; return(BackDate); } /*****************NRF设置为发送模式并发送数据******************************/ void NRFSetTxMode(uchar *TxDate) {//发送模式 CE=0; NRFWriteTxDate(W_REGISTER+TX_ADDR,TxAddr,TX_ADDR_WITDH);//写寄存器指令+接收地址使能指令+接收地址+地址宽度 NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH);//为了应答接收设备,接收通道0地址和发送地址相同 NRFWriteTxDate(W_TX_PAYLOAD,TxDate,TX_DATA_WITDH);//写入数据 /******下面有关寄存器配置**************/ NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+SETUP_RETR,0x0a); // 自动重发延时等待250us+86us,自动重发10次 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益 NRFWriteReg(W_REGISTER+CONFIG,0x0e); // CRC使能,16位CRC校验,上电 CE=1; Delay(5);//保持10us秒以上 } /*****************NRF设置为接收模式并接收数据******************************/ //主要接收模式 void NRFSetRXMode() { CE=0; NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH); // 接收设备接收通道0使用和发送设备相同的发送地址 NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RX_PW_P0,TX_DATA_WITDH); // 接收通道0选择和发送通道相同有效数据宽度 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益*/ NRFWriteReg(W_REGISTER+CONFIG,0x0f); // CRC使能,16位CRC校验,上电,接收模式 CE = 1; Delay(5);//保持10us秒以上 } /****************************检测应答信号******************************/ uchar CheckACK() { //用于发射 sta=NRFReadReg(R_REGISTER+STATUS); // 返回状态寄存器 if(TX_DS||MAX_RT) //发送完毕中断 { NRFWriteReg(W_REGISTER+STATUS,0xff); // 清除TX_DS或MAX_RT中断标志 CSN=0; NRFSPI(FLUSH_TX);//用于清空FIFO !!关键!!不然会出现意想不到的后果!!!大家记住!! CSN=1; return(0); } else return(1); } /******************判断是否接收收到数据,接到就从RX取出*********************/ //用于接收模式 /*uchar NRFRevDate(uchar *RevDate) { uchar RevFlags=0; sta=NRFReadReg(R_REGISTER+STATUS);//发送数据后读取状态寄存器 if(RX_DR) // 判断是否接收到数据 { CE=0; //SPI使能 NRFReadRxDate(R_RX_PAYLOAD,RevDate,RX_DATA_WITDH);// 从RXFIFO读取数据 RevFlags=1; //读取数据完成标志 } NRFWriteReg(W_REGISTER+STATUS,0xff); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标 return(RevFlags); }*/ # 下面是接收部分 #include<STC15F2K60S2.h> #include"global_define.h" #include"NRF24L01.h" #include"Delay.h" sbit CE=P5^5; //RX/TX模式选择端 sbit IRQ=P3^7; //可屏蔽中断端 sbit CSN=P5^4; //SPI片选端//就是SS sbit MOSI=P1^3; //SPI主机输出从机输入端 sbit MISO=P1^4; //SPI主机输出从机输出端 sbit SCLK=P1^5; //SPI时钟端 uchar RevTempDate[32]; //最后一位用来存放结束标志 uchar code TxAddr[]={0x34,0x43,0x10,0x10,0x01};//发送地址 /*****************状态标志*****************************************/ uchar bdata sta; //状态标志 sbit RX_DR=sta^6; sbit TX_DS=sta^5; sbit MAX_RT=sta^4; /*****************SPI时序函数******************************************/ uchar NRFSPI(uchar date) { uchar i; for(i=0;i<8;i++) // 循环8次 { if(date&0x80) MOSI=1; else MOSI=0; // byte最高位输出到MOSI date<<=1; // 低一位移位到最高位 SCLK=1; if(MISO) // 拉高SCK,nRF24L01从MOSI读入1位数据,同时从MISO输出1位数据 date|=0x01; // 读MISO到byte最低位 SCLK=0; // SCK置低 } return(date); // 返回读出的一字节 } /**********************NRF24L01初始化函数*******************************/ void NRF24L01Int() { Delay(2);//让系统什么都不干 CE=0; //待机模式1 CSN=1; SCLK=0; IRQ=1; } /*****************SPI读寄存器一字节函数*********************************/ uchar NRFReadReg(uchar RegAddr) { uchar BackDate; CSN=0;//启动时序 NRFSPI(RegAddr);//写寄存器地址 BackDate=NRFSPI(0x00);//写入读寄存器指令 CSN=1; return(BackDate); //返回状态 } /*****************SPI写寄存器一字节函数*********************************/ uchar NRFWriteReg(uchar RegAddr,uchar date) { uchar BackDate; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入地址 NRFSPI(date);//写入值 CSN=1; return(BackDate); } /*****************SPI读取RXFIFO寄存器的值********************************/ uchar NRFReadRxDate(uchar RegAddr,uchar *RxDate,uchar DateLen) { //寄存器地址//读取数据存放变量//读取数据长度//用于接收 uchar BackDate,i; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入要读取的寄存器地址 for(i=0;i<DateLen;i++) //读取数据 { RxDate[i]=NRFSPI(0); } CSN=1; return(BackDate); } /*****************SPI写入TXFIFO寄存器的值**********************************/ uchar NRFWriteTxDate(uchar RegAddr,uchar *TxDate,uchar DateLen) { //寄存器地址//写入数据存放变量//读取数据长度//用于发送 uchar BackDate,i; CSN=0; BackDate=NRFSPI(RegAddr);//写入要写入寄存器的地址 for(i=0;i<DateLen;i++)//写入数据 { NRFSPI(*TxDate++); } CSN=1; return(BackDate); } /*****************NRF设置为发送模式并发送数据******************************/ void NRFSetTxMode(uchar *TxDate) {//发送模式 CE=0; NRFWriteTxDate(W_REGISTER+TX_ADDR,TxAddr,TX_ADDR_WITDH);//写寄存器指令+接收地址使能指令+接收地址+地址宽度 NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH);//为了应答接收设备,接收通道0地址和发送地址相同 NRFWriteTxDate(W_TX_PAYLOAD,TxDate,TX_DATA_WITDH);//写入数据 /******下面有关寄存器配置**************/ NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+SETUP_RETR,0x0a); // 自动重发延时等待250us+86us,自动重发10次 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益 NRFWriteReg(W_REGISTER+CONFIG,0x0e); // CRC使能,16位CRC校验,上电 CE=1; Delay(5);//保持10us秒以上 } /*****************NRF设置为接收模式并接收数据******************************/ //主要接收模式 void NRFSetRXMode() { CE=0; NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH); // 接收设备接收通道0使用和发送设备相同的发送地址 NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RX_PW_P0,TX_DATA_WITDH); // 接收通道0选择和发送通道相同有效数据宽度 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益*/ NRFWriteReg(W_REGISTER+CONFIG,0x0f); // CRC使能,16位CRC校验,上电,接收模式 CE = 1; Delay(5);//保持10us秒以上 } /****************************检测是否有接收到数据******************************/ void CheckACK() { //用于发射模式接收应答信号 sta=NRFReadReg(R_REGISTER+STATUS); // 返回状态寄存器 if(TX_DS) NRFWriteReg(W_REGISTER+STATUS,0xff); // 清除TX_DS或MAX_RT中断标志 } /*************************接收数据*********************************************/ void GetDate() { sta=NRFReadReg(R_REGISTER+STATUS);//发送数据后读取状态寄存器 if(RX_DR) // 判断是否接收到数据 { CE=0;//待机 NRFReadRxDate(R_RX_PAYLOAD,RevTempDate,RX_DATA_WITDH);// 从RXFIFO读取数据 接收4位即可,后一位位结束位 // LcdWriteChStr(2,65,RevTempDate);//LCD12864液晶显示 // MAX232SendDate();//发送数据到上位机 NRFWriteReg(W_REGISTER+STATUS,0xff); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标 CSN=0; NRFSPI(FLUSH_RX);//用于清空FIFO !!关键!!不然会出现意想不到的后果!!!大家记住!! CSN=1; } //NRFWriteReg(W_REGISTER+STATUS,0xff); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标 } # keil运行时没有错误的,接收端与单片机串口也是通的,波特率115200, # IRC18.432MHz,可是在接收端的串口始终读不到数,搞了好久了还是没办法 # 技术小白求大神指点 ```
NRF24L01模块发送的2.4G信号能不能用其他非NRF24l01的模块接收?
NRF24L01模块发送的2.4G信号能不能用其他非NRF24l01的模块接收? 本人小白,求教!
关于nrf24l01无法通行问题
在配置STM32F103C8T6 +nrf2401问题时,SPI读写功能没问题,即nrf2401 check成功。 我配置发送端关闭自动应答:SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0 发送完成后,读取status寄存器内容为0x2e, fifostatus寄存器内容为0x11,即表示发送模块成功发送。 我配置接收端关闭ACK: SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0,在上述发送端一直工作前提下接收端不能接收数据,查看 接收端status寄存器内容为:0x0e,表示接收端未收到数据。 我猜想不能通行原因是通道、地址、频率、模式不正确,但仔细检查发送、接收端上述配置完全一样。现在不知道问题出在哪里了,请各位帮我看看。 uint8_t NRF24L01_Check(void) { uint8_t buf[5]={0XA5,0XA5,0XA5,0XA5,0XA5}; uint8_t i; SPI_Write_Buf(NRF_WRITE_REG+TX_ADDR,buf,5);// SPI_Read_Buf(TX_ADDR,buf,5); for(i=0;i<5;i++)if(buf[i]!=0XA5)break; if(i!=5)return 1; return 0; } void TX_Mode(void) { NRF24L01_SCK_L; NRF24L01_CE_L; SPI_Write_Buf(NRF_WRITE_REG + TX_ADDR, (u8*)TX_ADDRESS, 5); SPI_Write_Buf(NRF_WRITE_REG + RX_ADDR_P0, (u8*)TX_ADDRESS, 5); SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0 SPI_RW_Reg(NRF_WRITE_REG + EN_RXADDR, 0x00); // Enable Pipe0 SPI_RW_Reg(NRF_WRITE_REG + SETUP_RETR, 0x00); SPI_RW_Reg(NRF_WRITE_REG + SETUP_AW, 0x03); SPI_RW_Reg(NRF_WRITE_REG + RF_CH, 40); SPI_RW_Reg(NRF_WRITE_REG + RF_SETUP, 0x0F); SPI_RW_Reg(NRF_WRITE_REG + RX_PW_P0, TX_PLOAD_WIDTH); SPI_RW_Reg(NRF_WRITE_REG + CONFIG, 0x0e); NRF24L01_CE_H; delay_us(150); } void RX_Mode(void) { NRF24L01_SCK_L; NRF24L01_CE_L; SPI_Write_Buf(NRF_WRITE_REG + RX_ADDR_P0, (u8*)TX_ADDRESS, TX_ADR_WIDTH); // Use the same address on the RX device as the TX device SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0 SPI_RW_Reg(NRF_WRITE_REG + EN_RXADDR, 0x01); // Enable Pipe0 SPI_RW_Reg(NRF_WRITE_REG + SETUP_AW, 0x03); // SPI_RW_Reg(NRF_WRITE_REG + RF_CH, 40); // Select RF channel 40 SPI_RW_Reg(NRF_WRITE_REG + RX_PW_P0, TX_PLOAD_WIDTH); SPI_RW_Reg(NRF_WRITE_REG + RF_SETUP, 0x0f); SPI_RW_Reg(NRF_WRITE_REG + CONFIG, 0x0f); NRF24L01_CE_H; // delay_us(150); } u8 NRF24L01_RxPacket(u8 *rx_buf) { int16_t sta,fifosta,tt=0; sta=SPI_Read_Reg(STATUS); fifosta=SPI_Read_Reg(FIFO_STATUS); if(!( NRF24L01_IRQ)) { sta=SPI_Read_Reg(STATUS); if(sta&RX_OK) { SPI_Read_Buf(RD_RX_PLOAD,rx_buf,RX_PLOAD_WIDTH); SPI_RW_Reg(FLUSH_RX,0xff); SPI_RW_Reg(NRF_WRITE_REG+STATUS,0x7f); tt=1; } } return (tt); } u8 NRF24L01_TxPacket(u8 *txbuf) { uint8_t sta,fifosta,cd; NRF24L01_CE_L; SPI_Write_Buf(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH); sta = SPI_Read_Reg(STATUS); fifosta = SPI_Read_Reg(FIFO_STATUS); NRF24L01_CE_H;// while(NRF24L01_IRQ!=0);// sta=SPI_Read_Reg(STATUS); // fifosta = SPI_Read_Reg(FIFO_STATUS); cd=SPI_Read_Reg(0x09); SPI_RW_Reg(NRF_WRITE_REG+STATUS,sta); if(sta&MAX_TX)// { SPI_RW_Reg(FLUSH_TX,0xff);// return MAX_TX; } if(sta&TX_OK) { ; return 0x01; } return 0xff;// }
在安卓模拟器中调试nRF24L01射频模块要不要装驱动程序?
通过串口转usb将nRF24L01射频模块和电脑连接,然后在安卓模拟器中调试模块,需要给安卓模拟器安装安卓驱动程序吗?
nrf24l01无法同时多发一收
当EN_RXADDR寄存器设置为0x3f 使能通道012345的接收地址时 只能从通道1接收到数据,无法从通道0,2,3,4,5接收到数据 当EN_RXADDR寄存器设置为0x01 使能通道0的接收地址时 只能从通道0接收到数据 请问如何同时接收到通道0,1,2,3,4,5的数据 在不使用通讯协议的情况下如何判断接收到的数据是从通道0,1,2,3,4,5的哪个通道接收到的 我的代码如下 const u8 ADDRESS[7][5]={{0x30,0x30,0x30,0x30,0x30},{0x30,0x30,0x30,0x30,0x31},{0x30,0x30,0x30,0x30,0x32},{0x30,0x30,0x30,0x30,0x33},{0x30,0x30,0x30,0x30,0x34},{0x30,0x30,0x30,0x30,0x35},{0x30,0x30,0x30,0x30,0x36}}; /*********************************************/ /* 函数功能:设置24L01为接收模式 */ /*********************************************/ void NRF24L01_RX_Mode(void) { SPI_RF_CE_L;//CE拉低,使能24L01配置 NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P0, (u8*)ADDRESS[0], RX_ADR_WIDTH);//写RX接收地址 NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P1, (u8*)ADDRESS[1], RX_ADR_WIDTH);//写RX接收地址 NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P2,ADDRESS[2][4]); NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P3,ADDRESS[3][4]); NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P4,ADDRESS[4][4]); NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P5,ADDRESS[5][4]); NRF24L01_Write_Reg(WRITE_REG+EN_AA,0x3f); //开启通道0,1,2,3,4,5自动应答 NRF24L01_Write_Reg(WRITE_REG+EN_RXADDR,0x3f);//通道0 1,2,3,4,5 接收允许 NRF24L01_Write_Reg(WRITE_REG+RF_CH,0); //设置RF工作通道频率 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P1,RX_PLOAD_WIDTH);//选择通道1的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P2,RX_PLOAD_WIDTH);//选择通道2的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P3,RX_PLOAD_WIDTH);//选择通道3的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P4,RX_PLOAD_WIDTH);//选择通道4的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P5,RX_PLOAD_WIDTH);//选择通道5的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RF_SETUP,0x0f);//设置TX发射参数,0db增益,2Mbps,低噪声增益开启 NRF24L01_Write_Reg(WRITE_REG+CONFIG, 0x0f); //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,接收模式 NRF24L01_Write_Reg(FLUSH_RX,0xff);//清除RX FIFO寄存器 SPI_RF_CE_H;//CE置高,进入接收模式 delay_us(10); } /*********************************************/ /* 函数功能:设置24L01为发送模式 */ /*********************************************/ void NRF24L01_TX_Mode(void) { SPI_RF_CE_L;//CE拉低,使能24L01配置 NRF24L01_Write_Buf(WRITE_REG+TX_ADDR,(u8*)ADDRESS[0],TX_ADR_WIDTH);//写TX节点地址 NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P0,(u8*)ADDRESS[0],RX_ADR_WIDTH); //设置TX节点地址,主要为了使能ACK NRF24L01_Write_Reg(WRITE_REG+EN_AA,0x3f); //使能通道012345的自动应答 NRF24L01_Write_Reg(WRITE_REG+EN_RXADDR,0x3f); //使能通道012345的接收地址 NRF24L01_Write_Reg(WRITE_REG+SETUP_RETR,0x1a);//设置自动重发间隔时间:500us + 86us;最大自动重发次数:10次 NRF24L01_Write_Reg(WRITE_REG+RF_CH,0); //设置RF通道为0 NRF24L01_Write_Reg(WRITE_REG+RF_SETUP,0x0f); //设置TX发射参数,0db增益,2Mbps,低噪声增益开启 NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0e); //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,发送模式,开启所有中断 SPI_RF_CE_H;//CE置高,10us后启动发送 delay_us(10); } main中的死循环代码: while(1) { if(SPI_RF_IRQ==0) { if(NRF24L01_RxPacket(rece_buf)==0) { Usart_SendString(rece_buf); } } } 发送数据代码: SPI_RF_CE_L; NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0e); SPI_RF_CE_H; NRF24L01_TxPacket(rece_buf); SPI_RF_CE_L; NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0f); SPI_RF_CE_H;
nRF24L01发送与接收模式的转换
nRF24L01先处于接收状态一直接收数据,若有中断则让nRF24L01处于发送模式发送一串数字后返回接收模式。但我的程序进入中断发送一串数字后返回接收模式接收不到数据了?这是为什么呢?给出我的main()主要部分,大家帮我看看错在哪里? while(1) { if(flag1){ TX_Mode2(RX_BUF2); // 设置为发送模式 sta=SPI_Read(STATUS); //读取状态寄存器的值 SPI_RW_Reg(WRITE_REG+STATUS,sta); //清除TX_DS或MAX_RT中断标志 flag1=0; } RX_Mode(); // 设置为接收模式 for(i=0;i<TX_PLOAD_WIDTH*4;i++) { sta = SPI_Read(STATUS); // 读状态寄存器 if(RX_DR) // 判断是否接受到数据 { SPI_Read_Buf(RD_RX_PLOAD, RX_BUF, TX_PLOAD_WIDTH); // 从RX FIFO读出数据 nflag = 1; } SPI_RW_Reg(WRITE_REG + STATUS, sta); // 清除RX_DS中断标志 if(nflag==1) // 接受完成 { nflag = 0; // 清标志 Hum_Z = RX_BUF[0]; // 数据送到LED显示 Hum_X = RX_BUF[1]; // 数据送到LED显示 Tem_Z = RX_BUF[2]; // 数据送到LED显示 Tem_X = RX_BUF[3]; // 数据送到LED显示 LCD_Display1(); } } RX_Mode1(); for(i=0;i<TX_PLOAD_WIDTH*4;i++) { sta = SPI_Read(STATUS); // 读状态寄存器 if(RX_DR) // 判断是否接受到数据 { SPI_Read_Buf(RD_RX_PLOAD, RX_BUF1, TX_PLOAD_WIDTH); // 从RX FIFO读出数据 mflag = 1; } SPI_RW_Reg(WRITE_REG + STATUS, sta); // 清除RX_DS中断标志 if(mflag==1) // 接受完成 { mflag = 0; // 清标志 Hum_Z = RX_BUF1[0]; // 数据送到LED显示 Hum_X = RX_BUF1[1]; // 数据送到LED显示 Tem_Z = RX_BUF1[2]; // 数据送到LED显示 Tem_X = RX_BUF1[3]; // 数据送到LED显示 LCD_Display2(); } }
nrf24l01如何传输大量的数据?
已知uint16_t data[1500]; 请问如何利用nrf24l01传输data?
无线传输nrf24l01收发模式切换怎么实现
2个STC单片机连接2个nrf24l01,一开始上位机处于接收状态,下位机处于发送状态,上位机接收下位机发送的数据。上位机与PC相连接,上位机将接收到的数据发送给PC。当PC发送一串数据给上位机时,上位机转为发送模式,下位机转为接收模式接收上位机发送的数据。但我的上位机发送数据后下位机还是一直处于发送状态接收不到上位机发送的数据,而且上位机发送数据后再转为接收状态时接收不到数据了,这是怎么回事?
nRF24L01 2.4G收发问题
第一次用这个芯片,博主用的是中断的方式读取状态以及接收数据,发现发送端每次读出来的值是0x1F,说明发送到达了最大发送次数而没有被接收?发送是OK的吗?然而接收端怎么也没有数据打印出来,接收不到任何数据,不知道问题出现在哪里,读写寄存器函数是OK的,求大神指点一下。 ``` #ifdef nRF24l01_EN #define NRF24L01_TX 0 //发送使能 1:发送 0:接收 #define MOSI_PORT JL_PORTB #define MOSI_BIT BIT(1) #define MISO_PORT JL_PORTB #define MISO_BIT BIT(0) #define SCK_PORT JL_PORTB #define SCK_BIT BIT(6) #define CSN_PORT JL_PORTB #define CSN_BIT BIT(3) #define CE_PORT JL_PORTB #define CE_BIT BIT(5) #define MOSI_SET(x) do{x?(MOSI_PORT->OUT|=MOSI_BIT):(MOSI_PORT->OUT&=~MOSI_BIT);}while(0) #define CSN_SET(x) do{x?(CSN_PORT->OUT|=CSN_BIT):(CSN_PORT->OUT&=~CSN_BIT);}while(0) #define CE_SET(x) do{x?(CE_PORT->OUT|=CE_BIT):(CE_PORT->OUT&=~CE_BIT);}while(0) #define SCK_SET(x) do{x?(SCK_PORT->OUT|=SCK_BIT):(SCK_PORT->OUT&=~SCK_BIT);}while(0) #define MISO_DAT() (MISO_PORT->IN&MISO_BIT) uint8_t const TX_ADDRESS[TX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01}; //本地地址 uint8_t const RX_ADDRESS[RX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01}; //接收地址 void spi_io_init(void) { MOSI_PORT->DIR &= ~MOSI_BIT; MISO_PORT->DIR |= MISO_BIT; CE_PORT->DIR &= ~CE_BIT; CE_PORT->OUT &= ~CE_BIT; CSN_PORT->DIR &= ~CSN_BIT; CSN_PORT->OUT |= CSN_BIT; SCK_PORT->DIR &= ~SCK_BIT; SCK_PORT->OUT &= ~SCK_BIT; } void inerDelay_us(unsigned char n) { for(;n>0;n--) asm("nop"); } uint8_t SPI_RW(uint8_t uchar) { uint8_t bit_ctr; for(bit_ctr=0;bit_ctr<8;bit_ctr++) // output 8-bit { MOSI_SET(uchar & 0x80); // output 'uchar', MSB to MOSI uchar = (uchar << 1); // shift next bit into MSB.. SCK_SET(1); // Set SCK high.. uchar |= MISO_DAT(); // capture current MISO bit SCK_SET(0); // ..then set SCK low again } return(uchar); // return read uchar } uint8_t SPI_Read(uint8_t reg) { uint8_t reg_val; CSN_SET(0); // CSN low, initialize SPI communication... SPI_RW(reg); // Select register to read from.. reg_val = SPI_RW(0); // ..then read registervalue CSN_SET(1); // CSN high, terminate SPI communication return(reg_val); // return register value } uint8_t SPI_RW_Reg(uint8_t reg, uint8_t value) { uint8_t status; CSN_SET(0); // CSN low, init SPI transaction status = SPI_RW(reg); // select register SPI_RW(value); // ..and write value to it.. CSN_SET(1); // CSN high again return(status); // return nRF24L01 status uchar } uint8_t SPI_Read_Buf(uint8_t reg, uint8_t *pBuf, uint8_t uchars) { uint8_t status,uchar_ctr; CSN_SET(0); // Set CSN low, init SPI tranaction status = SPI_RW(reg); // Select register to write to and read status uchar for(uchar_ctr=0;uchar_ctr<uchars;uchar_ctr++) pBuf[uchar_ctr] = SPI_RW(0); // CSN_SET(1); return(status); // return nRF24L01 status uchar } uint8_t SPI_Write_Buf(uint8_t reg, uint8_t *pBuf, uint8_t uchars) { uint8_t status,uchar_ctr; CSN_SET(0); //SPI使能 status = SPI_RW(reg); for(uchar_ctr=0; uchar_ctr<uchars; uchar_ctr++) // SPI_RW(*pBuf++); CSN_SET(1); //关闭SPI return(status); // } void SetRX_Mode(void) { SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, (uint8_t *)RX_ADDRESS, RX_ADR_WIDTH); // 写接收端地址 SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //设置接收数据长度,本次设置为32字节 SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); // IRQ收发完成中断响应,16位CRC ,主接收 } /* */ void nRF24L01_RxPacket(unsigned char* rx_buf) { unsigned char revale=0; uint8_t sta=SPI_Read(STATUS); // 读取状态寄存其来判断数据接收状况 CE_SET(1); // printf("R:%x ",sta); if(sta & BIT(6)) // 判断是否接收到数据 { CE_SET(0); printf("R"); SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer } SPI_RW_Reg(WRITE_REG+STATUS,sta); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标志 } void nRF24L01_TxPacket(unsigned char * tx_buf) { //printf("s"); CE_SET(0); //StandBy I模式 SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, (uint8_t *)RX_ADDRESS, RX_ADR_WIDTH); // 装载接收端地址 SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH); // 装载数据 SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e); // IRQ收发完成中断响应,16位CRC,主发送 CE_SET(1); //置高CE,激发数据发送 } void nrf24l01_irq_init(void); void NRF24L01_RX_Mode(void) { } /****************************************************************************** * \par Description: * \param[in] NULL * \param[out] NULL * \return NULL * \ note: *******************************************************************************/ void init_NRF24L01(void) { spi_io_init(); nrf24l01_irq_init(); CE_SET(0); SPI_Write_Buf(WRITE_REG + TX_ADDR, (uint8_t *)TX_ADDRESS, TX_ADR_WIDTH); // 写本地地址 SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, (uint8_t *)RX_ADDRESS, RX_ADR_WIDTH); // 写接收端地址 SPI_RW_Reg(WRITE_REG + EN_AA, 0x01); // 频道0自动 ACK应答允许 SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01); // 允许接收地址只有频道0,如果需要多频道可以参考Page21 SPI_RW_Reg(WRITE_REG + SETUP_RETR, 0x1a); // 设置重发次数 SPI_RW_Reg(WRITE_REG + RF_CH, 40); // 设置信道工作为2.4GHZ,收发必须一致 SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //设置接收数据长度,本次设置为32字节 SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07); //设置发射速率为2MHZ,发射功率为最大值0dB #if (NRF24L01_TX == 0) SetRX_Mode(); #endif } const u8 send_data[32]={0x55,0x5a,0xa5,0xaa}; u8 rx_buf[32]; void nrf24l01_msg_handler(void) { #if (NRF24L01_TX == 0) //nRF24L01_RxPacket(rx_buf); #endif } /****************************************************************************** * \par Description: 1秒消息处理 * \param[in] NULL * \param[out] NULL * \return NULL * \ note: *******************************************************************************/ void one_second_handler(void) { #if (NRF24L01_TX) nRF24L01_TxPacket((u8 *)send_data); #endif } u8 nrf24l01_rx_buf[32]; /****************************************************************************** * \par Description: 外部中断服务 * \param[in] NULL * \param[out] NULL * \return NULL * \ note: *******************************************************************************/ void nrf24l01_isr(void) { /* CE_SET(0); uint8_t sta = SPI_Read(STATUS); // 读取状态寄存其来判断数据接收状况 printf("%x ",sta); SPI_RW_Reg(WRITE_REG+STATUS,sta); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标志 if (sta & 0x10){ CE_SET(1); // chip enable SPI_RW_Reg(WRITE_REG+FLUSH_TX,0xff); }*/ nRF24L01_RxPacket(nrf24l01_rx_buf); JL_WAKEUP->CON2 |= BIT(12);//clean pending } IRQ_REGISTER(IRQ_PORT_IDX, nrf24l01_isr); /****************************************************************************** * \par Description: 外部中断初始化 * \param[in] NULL * \param[out] NULL * \return NULL * \ note: 下降沿触发 *******************************************************************************/ void nrf24l01_irq_init(void) { JL_PORTB->DIR |=BIT(4); JL_PORTB->DIE |= BIT(4); JL_PORTB->PU |=BIT(4); JL_PORTB->PD &=~BIT(4); printf("*****nrf24l01_irq_init init***\n"); JL_WAKEUP->CON0 |= BIT(12);//检查PA8电平触发 JL_WAKEUP->CON1 |= BIT(12);//下降沿触发 IRQ_REQUEST(IRQ_PORT_IDX, nrf24l01_isr); } #endif ```
2.4G的NRF24L01P和SI24R1在室内哪个收发效果更好,范围更广?
NRF24L01P和SI24R1在室内哪个收发效果更好,范围更广?或者有其他的效果更好的芯片推荐? 还有就是假如SI24R1发射的信号能不能用NRF24L01接受? 求教!
NRF24L01如何才能保证接收到应答信号
我有一个主机设置为发送模式发送数据给从机,主机和从机都为自动应答模式,但是经常会出现从机接收到数据,但主机接收不到从机发送过来的应答信号。怎么才能保证主机能够收到从机的应答信号?
8051驱动NRF24L01模块
用51驱动NRF24L01, 看了两天资料,写出代码后很不理想。 读写寄存器测试后没有问题,读写接收发送地址也没有问题。在通信上存在一些问题。 所有寄存器采用复位值,如果我将发送的数据写进TX_FIFO寄存器,没有设置发送模式,此时一切正常,也能读状态寄存器看见TX_FIFO已满。但如果设置为发射模式,之后读出来的一切寄存器内容都是0xff。不知道是哪里的问题。 如果是现设置为发送模式,再写入TX_FIFO 此后读出来的数据全是0X00。请问哪里存在问题。谢谢
nrf24L01多个数据通道如何将所有通道优先级设置为一样?
我在使用NRF24L01模块多通道接收时,发现通道0~5通道的数据 处理 有优先级,导致各通道的数据处理得不好,在相关的技术手册上提到了该模块的数据通道三个处理优先级,现在我想如何将所有的数据通道处理优先级设置为一样,让所有数据通道数据处理效果一致,但时数据手册上没有提到该方法,请问有人使用过类似的功能吗?
nRF51822和nRF24LU1P之间通信问题
我在用nRF51822给nRF24LU1P发送数据时候,nRF51这边发送出去了而且nRF24LU1P那边也产生了radio中断,但是当我来读数据时候却是RX_EMPTY,请问这是怎么回事啊
关于无线鼠标的无线通信问题
自己做无线鼠标,单片机用的是STM32F103C8T6,无线接收和发射模块用的是NRF24L01,无线通信协议方面,看到网上有人说NRF24L01是2.4G频段芯片,内部集成了Nordic公司自己的协议,可以设定工作模式,又有的说可以编程序设定无线通信模式。可是2.4G不就是无线通信模式的一种吗?这几个有什么区别联系吗?无线鼠标用到的无线通信到底是哪一个?另外,计算机能够获得鼠标的移动按键信息是因为STM32里有USB通信模块吗,还是需要专门的程序?
求问NRF24L01高速切换收发模式的原理是什么
手头有源码并且调通了,想问一下原理 切换到发送模式,尝试100次后 切换到接收模式也尝试100次 其中RX模式久一点
刚学nrf24l01无线模块想让大家看一下我画的收发流程图对吗
![图片说明](https://img-ask.csdn.net/upload/201906/08/1560005882_127192.jpg)![图片说明](https://img-ask.csdn.net/upload/201906/08/1560005893_601058.jpg)
一个nrf24l01+能用来干嘛呢,没办法和其他什么东西通讯把,
现在的无线产品中用到的比较多是无线技术是那种,他们都需要至少2个产品才能进行使用,开发,调试,学习吗
芯片NRF52832如何测得高脉冲的时间?
我可以中断得到上升沿或者下降沿 ,但是怎么测得它持续的时间呢?
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
源码阅读(19):Java中主要的Map结构——HashMap容器(下1)
(接上文《源码阅读(18):Java中主要的Map结构——HashMap容器(中)》) 3.4.4、HashMap添加K-V键值对(红黑树方式) 上文我们介绍了在HashMap中table数组的某个索引位上,基于单向链表添加新的K-V键值对对象(HashMap.Node&lt;K, V&gt;类的实例),但是我们同时知道在某些的场景下,HashMap中table数据的某个索引位上,数据是按照红黑树
c++制作的植物大战僵尸,开源,一代二代结合游戏
    此游戏全部由本人自己制作完成。游戏大部分的素材来源于原版游戏素材,少部分搜集于网络,以及自己制作。 此游戏为同人游戏而且仅供学习交流使用,任何人未经授权,不得对本游戏进行更改、盗用等,否则后果自负。 目前有六种僵尸和六种植物,植物和僵尸的动画都是本人做的。qq:2117610943 开源代码下载 提取码:3vzm 点击下载--&gt; 11月28日 新增四种植物 统一植物画风,全部修
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成喔~) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
深度学习图像算法在内容安全领域的应用
互联网给人们生活带来便利的同时也隐含了大量不良信息,防范互联网平台有害内容传播引起了多方面的高度关注。本次演讲从技术层面分享网易易盾在内容安全领域的算法实践经验,包括深度学习图
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程实用技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法,并会持续更新。
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
"狗屁不通文章生成器"登顶GitHub热榜,分分钟写出万字形式主义大作
GitHub 被誉为全球最大的同性交友网站,……,陪伴我们已经走过 10+ 年时间,它托管了大量的软件代码,同时也承载了程序员无尽的欢乐。 万字申请,废话报告,魔幻形式主义大作怎么写?兄dei,狗屁不通文章生成器了解一下。这个富有灵魂的项目名吸引了众人的目光。项目仅仅诞生一周,便冲上了GitHub趋势榜榜首(Js中文网 -前端进阶资源教程)、是榜首哦
推荐几款比较实用的工具,网站
1.盘百度PanDownload 这个云盘工具是免费的,可以进行资源搜索,提速(偶尔会抽风????) 不要去某站买付费的???? PanDownload下载地址 2.BeJSON 这是一款拥有各种在线工具的网站,推荐它的主要原因是网站简洁,功能齐全,广告相比其他广告好太多了 bejson网站 3.二维码美化 这个网站的二维码美化很好看,网站界面也很...
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
相关热词 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片 c# 图片颜色调整 最快 c#多张图片上传 c#密封类与密封方法
立即提问