温湿度传感器(DHT11)以及光照强度传感器(BH1750)的使用

news2025/2/7 19:08:45

前言

对于一些单片机类的环境检测或者智能家居小项目中,温湿度传感器(DHT11)以及光照强度传感器(BH1750)往往是必不可少的两个外设,下面我们来剖析这两个外设的原理,以及使用。

1. 温湿度传感器(DHT11)

1.1 DHT11介绍

DHT11数字温湿度传感器是一款含有已校准数字信号输出的温湿度复合传感器。对于温度的测量范围为0到50℃,能测量的湿度范围为20~95%RH。
在这里插入图片描述
如上图所示,DTH11传感器一般有3线制和4线制两种类型,本次以3线制传感器为例进行说明,4线制传感器请参考商家提供的使用手册。对于3线制在接线上有:

  • VCC外接3.3-5V电源
  • GND外接GND
  • DATA小板开关数字量输出接口接单片机IO口

1.2 串行接口(单线双向)

DHT11的DATA口用于与单片机的通讯和同步,采用单总线数据格式,一次通讯时间为4ms左右,数据分为小数部分和整数部分,具体格式在下面说明,当前小数部分用于以后拓展,现读出为0。操作流程如下:
一次完整的数据传输为40bit,高位先出,数据格式为:

  • 8bit湿度整数数据 + 8bit湿度小数数据
  • 8bit温度整数数据 + 8bir温度小数数据
  • 8bit校验和
    数据传送正确是校验和数据等于“8bit湿度整数数据 + 8bit湿度小数数据+8bit温度整数数据 + 8bir温度小数数据 的低8bit等于8bit校验和 ”。
    例子:
    接收40位bit数据如下:
0000 00100000 00100000 00010000 00010000 0111
湿度高8位湿度低8位温度高8位温度低8位校验和

例如:0000 0001+0000 0010+0011 0001+0000 0010=0000 0111

二进制湿度数据0000 0010 0000 0010==>转化为十进制:514,除于10即为湿度值;
即湿度=51.4%RH

二进制温度数据0000 0001 0000 0010==>转化为十进制:258,除于10即为湿度值;
即温度=25.8℃

当温度低于0℃时温度数据的最高位置1
例如:-34.1℃表示为 0000 0001 0101 0101

1.3 通信过程

  1. 用户MCU发送一次开始信号后,DHT11从低功耗模式转换到高速模式,等待主机开始信号结束后,DHT11发送响应信号,送出40bit的数据,并触发一次信号采集,用户可选择读取部分数据。从模式下,DHT11接收到开始信号触发一次温湿度采集,如果没有接收到主机发送开始信号,DHT11不会主动进行温湿度采集。采集数据后转换到低速模式。
    在这里插入图片描述
  2. 总线空闲状态为高电平,主机把总线拉低等待DHT11响应,主机把总线拉低必须大于18毫秒,保证DHT11能检测到起始信号。DHT11接收到主机的开始信号后,等待主机开始信号结束,然后发送80us低电平响应信号。主机发送开始信号结束后,延时等待20-40us后,读取DHT11的响应信号,主机发送开始信号后,可以切换到输入模式,或者输出高电平均可,总线由上拉电阻拉高。
    在这里插入图片描述
  3. 总线为低电平,说明DHT11发送响应信号,DHT11发送响应信号后,再把总线拉高80us,准备发送数据,每一bit数据都以50us低电平时隙开始,高电平的长短决定了数据位是0还是1。格式如下图所示。如果读取响应信号为高电平,则DHT11没有响应,请检查线路是否连接正常。当最后一bit数据传送完毕后,DHT11拉低总线50us,随后总线由上拉电阻拉高进入空闲状态。
    数字0信号表示
    在这里插入图片描述
    数字1信号表示:
    在这里插入图片描述

1.4 DHT11代码实现

DHT11.c来源于正点原子,感谢正点原子。

#include "dht11.h"
#include "Delay.h"

 //	 
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//ALIENTEK精英STM32开发板
//DHT11数字温湿度传感器驱动代码	   
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//修改日期:2012/9/12
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 广州市星翼电子科技有限公司 2009-2019
//All rights reserved									  
//
      
//复位DHT11
void DHT11_Rst(void)	   
{                 
	DHT11_IO_OUT(); 	//SET OUTPUT
    DHT11_DQ_OUT=0; 	//拉低DQ
    Delay_ms(20);    	//拉低至少18ms
    DHT11_DQ_OUT=1; 	//DQ=1 
	Delay_us(30);     	//主机拉高20~40us
}
//等待DHT11的回应
//返回1:未检测到DHT11的存在
//返回0:存在
u8 DHT11_Check(void) 	   
{   
	u8 retry=0;
	DHT11_IO_IN();//SET INPUT	 
    while (DHT11_DQ_IN&&retry<100)//DHT11会拉低40~80us
	{
		retry++;
		Delay_us(1);
	};	 
	if(retry>=100)return 1;
	else retry=0;
    while (!DHT11_DQ_IN&&retry<100)//DHT11拉低后会再次拉高40~80us
	{
		retry++;
		Delay_us(1);
	};
	if(retry>=100)return 1;	    
	return 0;
}
//从DHT11读取一个位
//返回值:1/0
u8 DHT11_Read_Bit(void) 			 
{
 	u8 retry=0;
	while(DHT11_DQ_IN&&retry<100)//等待变为低电平
	{
		retry++;
		Delay_us(1);
	}
	retry=0;
	while(!DHT11_DQ_IN&&retry<100)//等待变高电平
	{
		retry++;
		Delay_us(1);
	}
	Delay_us(40);//等待40us
	if(DHT11_DQ_IN)return 1;
	else return 0;		   
}
//从DHT11读取一个字节
//返回值:读到的数据
u8 DHT11_Read_Byte(void)    
{        
    u8 i,dat;
    dat=0;
	for (i=0;i<8;i++) 
	{
   		dat<<=1; 
	    dat|=DHT11_Read_Bit();
    }						    
    return dat;
}
//从DHT11读取一次数据
//temp:温度值(范围:0~50°)
//humi:湿度值(范围:20%~90%)
//返回值:0,正常;1,读取失败
u8 DHT11_Read_Data(u8 *temp,u8 *humi)    
{        
 	u8 buf[5];
	u8 i;
	DHT11_Rst();
	if(DHT11_Check()==0)
	{
		for(i=0;i<5;i++)//读取40位数据
		{
			buf[i]=DHT11_Read_Byte();
		}
		if((buf[0]+buf[1]+buf[2]+buf[3])==buf[4])
		{
			*humi=buf[0];
			*temp=buf[2];
		}
	}else return 1;
	return 0;	    
}
//初始化DHT11的IO口 DQ 同时检测DHT11的存在
//返回1:不存在
//返回0:存在    	 
u8 DHT11_Init(void)
{	 
 	GPIO_InitTypeDef  GPIO_InitStructure;
 	
 	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);	 //使能PG端口时钟
	
 	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;				 //PG11端口配置
 	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; 		 //推挽输出
 	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
 	GPIO_Init(GPIOB, &GPIO_InitStructure);				 //初始化IO口
 	GPIO_SetBits(GPIOB,GPIO_Pin_11);						 //PG11 输出高
			    
	DHT11_Rst();  //复位DHT11
	return DHT11_Check();//等待DHT11的回应
} 

DHT11.h同样来源于正点原子

#ifndef __DHT11_H
#define __DHT11_H 
#include "sys.h"   
//	 
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//ALIENTEK战舰STM32开发板
//DHT11数字温湿度传感器驱动代码	   
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//修改日期:2012/9/12
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 广州市星翼电子科技有限公司 2009-2019
//All rights reserved									  
//
 
//IO方向设置
#define DHT11_IO_IN()  {GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=8<<12;}
#define DHT11_IO_OUT() {GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=3<<12;}
IO操作函数											   
#define	DHT11_DQ_OUT PBout(11) //数据端口	PA0 
#define	DHT11_DQ_IN  PBin(11)  //数据端口	PA0 


u8 DHT11_Init(void);//初始化DHT11
u8 DHT11_Read_Data(u8 *temp,u8 *humi);//读取温湿度
u8 DHT11_Read_Byte(void);//读出一个字节
u8 DHT11_Read_Bit(void);//读出一个位
u8 DHT11_Check(void);//检测是否存在DHT11
void DHT11_Rst(void);//复位DHT11    
#endif

2 光强度传感器(BH1750)

2.1 BH1750介绍

BH1750是一种用于两线式串行总线接口的数字型光强度传感器集成电路。所能测量的范围为1~65535Lx。最小误差变动 ± 20 % \pm20\% ±20%。且受红外线的影响很小。
图片来源于淘宝“JXINW旗舰店”
该传感器的管教定义如上所示。

名称注释
GND电源地
VCC电源(3.3~5v)
SCLIIC的时钟线
SDAIIC的数据线
ADDR设备地址引脚(空着)

2.1 BH1750代码实现

bh1750.c

#include "bh1750.h"
 
/*
  应用说明:
  在访问I2C设备前,请先调用 i2c_CheckDevice() 检测I2C设备是否正常,该函数会配置GPIO
*/
 
 
static void I2C_BH1750_GPIOConfig(void);
 
 
/*
*********************************************************************************************************
* 函 数 名: i2c_Delay
* 功能说明: I2C总线位延迟,最快400KHz
* 形    参:无
* 返 回 值: 无
*********************************************************************************************************
*/
static void i2c_Delay(void)
{
  uint8_t i;
  /* 
    下面的时间是通过逻辑分析仪测试得到的。
    工作条件:CPU主频72MHz ,MDK编译环境,1级优化
  
    循环次数为10时,SCL频率 = 205KHz  
    循环次数为7时,SCL频率 = 347KHz, SCL高电平时间1.5us,SCL低电平时间2.87us 
    循环次数为5时,SCL频率 = 421KHz, SCL高电平时间1.25us,SCL低电平时间2.375us 
  */
  for (i = 0; i < 10; i++);
}
/*
*********************************************************************************************************
* 函 数 名: i2c_Start
* 功能说明: CPU发起I2C总线启动信号
* 形    参:无
* 返 回 值: 无
*********************************************************************************************************
*/
void i2c_Start(void)
{
  /* 当SCL高电平时,SDA出现一个下跳沿表示I2C总线启动信号 */
  BH1750_I2C_SDA_1();
  BH1750_I2C_SCL_1();
  i2c_Delay();
  BH1750_I2C_SDA_0();
  i2c_Delay();
  BH1750_I2C_SCL_0();
  i2c_Delay();
}
/*
*********************************************************************************************************
* 函 数 名: i2c_Start
* 功能说明: CPU发起I2C总线停止信号
* 形    参:无
* 返 回 值: 无
*********************************************************************************************************
*/
void i2c_Stop(void)
{
  /* 当SCL高电平时,SDA出现一个上跳沿表示I2C总线停止信号 */
  BH1750_I2C_SDA_0();
  BH1750_I2C_SCL_1();
  i2c_Delay();
  BH1750_I2C_SDA_1();
}
/*
*********************************************************************************************************
* 函 数 名: i2c_SendByte
* 功能说明: CPU向I2C总线设备发送8bit数据
* 形    参:_ucByte : 等待发送的字节
* 返 回 值: 无
*********************************************************************************************************
*/
void i2c_SendByte(uint8_t _ucByte)
{
  uint8_t i;
 
  /* 先发送字节的高位bit7 */
  for (i = 0; i < 8; i++)
  {   
    if (_ucByte & 0x80)
    {
      BH1750_I2C_SDA_1();
    }
    else
    {
      BH1750_I2C_SDA_0();
    }
    i2c_Delay();
    BH1750_I2C_SCL_1();
    i2c_Delay();  
    BH1750_I2C_SCL_0();
    if (i == 7)
    {
       BH1750_I2C_SDA_1(); // 释放总线
    }
    _ucByte <<= 1;  /* 左移一个bit */
    i2c_Delay();
  }
}
/*
*********************************************************************************************************
* 函 数 名: i2c_ReadByte
* 功能说明: CPU从I2C总线设备读取8bit数据
* 形    参:无
* 返 回 值: 读到的数据
*********************************************************************************************************
*/
uint8_t i2c_ReadByte(void)
{
  uint8_t i;
  uint8_t value;
  /* 读到第1个bit为数据的bit7 */
  value = 0;
  for (i = 0; i < 8; i++)
  {
    value <<= 1;
    BH1750_I2C_SCL_1();
    i2c_Delay();
    if (BH1750_I2C_SDA_READ())
    {
      value++;
    }
    BH1750_I2C_SCL_0();
    i2c_Delay();
  }
  return value;
}
/*
*********************************************************************************************************
* 函 数 名: i2c_WaitAck
* 功能说明: CPU产生一个时钟,并读取器件的ACK应答信号
* 形    参:无
* 返 回 值: 返回0表示正确应答,1表示无器件响应
*********************************************************************************************************
*/
uint8_t i2c_WaitAck(void)
{
  uint8_t re;
 
  BH1750_I2C_SDA_1(); /* CPU释放SDA总线 */
  i2c_Delay();
  BH1750_I2C_SCL_1(); /* CPU驱动SCL = 1, 此时器件会返回ACK应答 */
  i2c_Delay();
  if (BH1750_I2C_SDA_READ())  /* CPU读取SDA口线状态 */
    re = 1;
  else
    re = 0;
  BH1750_I2C_SCL_0();
  i2c_Delay();
  return re;
}
/*
*********************************************************************************************************
* 函 数 名: i2c_Ack
* 功能说明: CPU产生一个ACK信号
* 形    参:无
* 返 回 值: 无
*********************************************************************************************************
*/
void i2c_Ack(void)
{
  BH1750_I2C_SDA_0(); /* CPU驱动SDA = 0 */
  i2c_Delay();
  BH1750_I2C_SCL_1(); /* CPU产生1个时钟 */
  i2c_Delay();
  BH1750_I2C_SCL_0();
  i2c_Delay();
  BH1750_I2C_SDA_1(); /* CPU释放SDA总线 */
}
/*
*********************************************************************************************************
* 函 数 名: i2c_NAck
* 功能说明: CPU产生1个NACK信号
* 形    参:无
* 返 回 值: 无
*********************************************************************************************************
*/
void i2c_NAck(void)
{
  BH1750_I2C_SDA_1(); /* CPU驱动SDA = 1 */
  i2c_Delay();
  BH1750_I2C_SCL_1(); /* CPU产生1个时钟 */
  i2c_Delay();
  BH1750_I2C_SCL_0();
  i2c_Delay();  
}
/*
*********************************************************************************************************
* 函 数 名: I2C_BH1750_GPIOConfig
* 功能说明: 配置I2C总线的GPIO,采用模拟IO的方式实现
* 形    参:无
* 返 回 值: 无
*********************************************************************************************************
*/
static void I2C_BH1750_GPIOConfig(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
  RCC_APB2PeriphClockCmd(BH1750_RCC_I2C_PORT, ENABLE);  /* 打开GPIO时钟 */
  GPIO_InitStructure.GPIO_Pin = BH1750_I2C_SCL_PIN | BH1750_I2C_SDA_PIN;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;    /* 开漏输出 */
  GPIO_Init(BH1750_GPIO_PORT_I2C, &GPIO_InitStructure);
  /* 给一个停止信号, 复位I2C总线上的所有设备到待机模式 */
  i2c_Stop();
}
/*
*********************************************************************************************************
* 函 数 名: i2c_CheckDevice
* 功能说明: 检测I2C总线设备,CPU向发送设备地址,然后读取设备应答来判断该设备是否存在
* 形    参:_Address:设备的I2C总线地址
* 返 回 值: 返回值 0 表示正确, 返回1表示未探测到
*********************************************************************************************************
*/
uint8_t i2c_CheckDevice(uint8_t _Address)
{
  uint8_t ucAck;
  i2c_Start();    /* 发送启动信号 */
  /* 发送设备地址+读写控制bit(0 = w, 1 = r) bit7 先传 */
  i2c_SendByte(_Address | BH1750_I2C_WR);
  ucAck = i2c_WaitAck();  /* 检测设备的ACK应答 */
  i2c_Stop();     /* 发送停止信号 */
  return ucAck;
}
//BH1750写一个字节
//返回值 成功:0    失败:非0 
uint8_t BH1750_Byte_Write(uint8_t data)
{
  i2c_Start();
  //发送写地址
  i2c_SendByte(BH1750_Addr|0);
  if(i2c_WaitAck()==1)
    return 1;
  //发送控制命令
  i2c_SendByte(data);
  if(i2c_WaitAck()==1)
    return 2;
  i2c_Stop();
  return 0;
}
//BH1750读取测量数据
//返回值 成功:返回光照强度   失败:返回0
uint16_t BH1750_Read_Measure(void)
{
  uint16_t receive_data=0; 
  i2c_Start();
  //发送读地址
  i2c_SendByte(BH1750_Addr|1);
  if(i2c_WaitAck()==1)
    return 0;
  //读取高八位
  receive_data=i2c_ReadByte();
  i2c_Ack();
  //读取低八位
  receive_data=(receive_data<<8)+i2c_ReadByte();
  i2c_NAck();
  i2c_Stop();
  return receive_data;  //返回读取到的数据
}
 
//BH1750s上电
void BH1750_Power_ON(void)
{
  BH1750_Byte_Write(POWER_ON);
}
//BH1750s断电
void BH1750_Power_OFF(void)
{
  BH1750_Byte_Write(POWER_OFF);
}
//BH1750复位  仅在上电时有效
void BH1750_RESET(void)
{
  BH1750_Byte_Write(MODULE_RESET);
}
 
//BH1750初始化
uint8_t BH1750_Init(void)
{
  I2C_BH1750_GPIOConfig();    /* 配置GPIO */
  
  BH1750_Power_ON();  //BH1750s上电
  //BH1750_RESET();     //BH1750复位
  return BH1750_Byte_Write(Measure_Mode);
  //SysTick_Delay_ms(120);
}
//获取光照强度
int LIght_Intensity(void)
{
  float v;
  v = (float)(BH1750_Read_Measure()/1.1f*Resolurtion);
  return (int) v;
}

bh1750.h

#ifndef __BH1750_H
#define __BH1750_H   
#include "stm32f10x.h"
//BH1750的地址
#define BH1750_Addr       0x46//0x46
 
//BH1750指令码
#define POWER_OFF         0x00
#define POWER_ON          0x01
#define MODULE_RESET      0x07
#define CONTINUE_H_MODE   0x10
#define CONTINUE_H_MODE2  0x11
#define CONTINUE_L_MODE   0x13
#define ONE_TIME_H_MODE   0x20
#define ONE_TIME_H_MODE2  0x21
#define ONE_TIME_L_MODE   0x23
 
//测量模式
#define Measure_Mode      CONTINUE_H_MODE
 
//分辨率 光照强度(单位lx)=(High Byte  + Low Byte)/ 1.2 * 测量精度
#if ((Measure_Mode==CONTINUE_H_MODE2)|(Measure_Mode==ONE_TIME_H_MODE2))
  #define Resolurtion   0.5
#elif ((Measure_Mode==CONTINUE_H_MODE)|(Measure_Mode==ONE_TIME_H_MODE))
  #define Resolurtion   1
#elif ((Measure_Mode==CONTINUE_L_MODE)|(Measure_Mode==ONE_TIME_L_MODE))
  #define Resolurtion   4
#endif
 
#define BH1750_I2C_WR 0   /* 写控制bit */
#define BH1750_I2C_RD 1   /* 读控制bit */
 
 
/* 定义I2C总线连接的GPIO端口, 只需要修改下面4行代码即可任意改变SCL和SDA的引脚 */
#define BH1750_GPIO_PORT_I2C  GPIOB     /* GPIO端口 */
#define BH1750_RCC_I2C_PORT   RCC_APB2Periph_GPIOB    /* GPIO端口时钟 */
#define BH1750_I2C_SCL_PIN    GPIO_Pin_14      /* 连接到SCL时钟线的GPIO */
#define BH1750_I2C_SDA_PIN    GPIO_Pin_15      /* 连接到SDA数据线的GPIO */
 
 
/* 定义读写SCL和SDA的宏,已增加代码的可移植性和可阅读性 */
  #define BH1750_I2C_SCL_1()  GPIO_SetBits(BH1750_GPIO_PORT_I2C, BH1750_I2C_SCL_PIN)    /* SCL = 1 */
  #define BH1750_I2C_SCL_0()  GPIO_ResetBits(BH1750_GPIO_PORT_I2C, BH1750_I2C_SCL_PIN)    /* SCL = 0 */
  
  #define BH1750_I2C_SDA_1()  GPIO_SetBits(BH1750_GPIO_PORT_I2C, BH1750_I2C_SDA_PIN)    /* SDA = 1 */
  #define BH1750_I2C_SDA_0()  GPIO_ResetBits(BH1750_GPIO_PORT_I2C, BH1750_I2C_SDA_PIN)    /* SDA = 0 */
  
  #define BH1750_I2C_SDA_READ()  GPIO_ReadInputDataBit(BH1750_GPIO_PORT_I2C, BH1750_I2C_SDA_PIN)  /* 读SDA口线状态 */
 
 
void i2c_Start(void);
void i2c_Stop(void);
void i2c_SendByte(uint8_t _ucByte);
uint8_t i2c_ReadByte(void);
uint8_t i2c_WaitAck(void);
void i2c_Ack(void);
void i2c_NAck(void);
uint8_t i2c_CheckDevice(uint8_t _Address);
 
uint8_t BH1750_Init(void);      //未包含IIC初始化
int LIght_Intensity(void);  //读取光照强度的值
uint8_t BH1750_Byte_Write(uint8_t data);
uint16_t BH1750_Read_Measure(void);
void BH1750_Power_ON(void);
void BH1750_Power_OFF(void);
void BH1750_RESET(void);
 
                
#endif

3. 参考文献

[1] 原创力文档:https://max.book118.com/html/2022/0404/5140311013004211.shtm

4. 总结

以上即是本次的内容。
1.代码中的"dht11.c"、“dht11.h”、“sys.h”、“bh1750.c”、"bh1750.h"可在我的博客中下载。
2. 部分资料来源于网络和开发手册,如有侵权请联系我删除

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

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

相关文章

仿真服务器介绍及应用

仿真服务器是一种高性能的计算设备&#xff0c;专门用于运行复杂的仿真软件和处理大量的计算任务。 仿真服务器通常具备以下特点&#xff1a; 1. 高性能硬件配置&#xff1a;为了满足仿真软件对计算能力的要求&#xff0c;仿真服务器通常配备高性能的CPU、大量的内存以及高速的…

Ollama教程——使用langchain:ollama与langchain的强强联合

相关文章: Ollama教程——入门&#xff1a;开启本地大型语言模型开发之旅 Ollama教程——模型&#xff1a;如何将模型高效导入到ollama框架 Ollama教程——兼容OpenAI API&#xff1a;高效利用兼容OpenAI的API进行AI项目开发 Ollama教程——使用langchain&#xff1a;ollama与…

【Windows】SecureCRT v9.2.3永久使用教程亲测可用

​ 软件介绍 SecureCRT 是一款常用的 SSH&#xff08;安全外壳协议&#xff09;和 Telnet 客户端软件&#xff0c;主要用于远程服务器管理和网络设备配置。它具有以下主要功能&#xff1a; 1.安全连接&#xff1a;SecureCRT 提供了强大的加密算法&#xff0c;保障用户与服务…

线性表概念及顺序表的实现

文章目录 前言一、线性表1.定义2.特点3.一般线性表的抽象数据类型定义 二、线性表的顺序存储&#xff08;顺序表&#xff09;1.基本概念2.数组实现顺序表3.顺序表中基本操作的具体实现4.顺序表总结 总结 前言 T_T此专栏用于记录数据结构及算法的&#xff08;痛苦&#xff09;学…

计算机虚拟机服务器中了mallox勒索病毒怎么办Mallox勒索病毒解密流程工具

在当今社会&#xff0c;人们的工作生活离不开网络&#xff0c;尤其企业离不开网络办公&#xff0c;网络为企业提供了极大便利&#xff0c;大大提升了企业的生产效率与办公水平&#xff0c;但网络是一把双刃剑&#xff0c;在为企业提供便利的同时也为企业的数据带来严重威胁。近…

第10章 物理安全要求

10.1 站点与设施设计的安全原则 假如没有对物理环境的控制&#xff0c;任何管理的、技术的或逻辑的访问控制技术都无法提供足够的安全性。 如果怀有恶意的人员获取了对设施及设备的物理访问权&#xff0c;那么他们几乎可以为所欲为&#xff0c;包括肆意破坏或窃取、更改数据。…

管理和维护索引

本文接上一篇创建、更改、删除索引继续讨论如何管理和维护SinoDB数据库的B树索引。 1. 索引的好处 ① 基于索引的排序 一列或多列的索引可用于按序取回数据。使用索引读取数据可以让数据库服务器按照请求的顺序直接返回数据&#xff0c;免去了排序的操作。 ② 强制保证唯一性…

使用matlab GUI设计离线问卷

很久没有更新了。没有更新的日子&#xff0c;也在努力学习&#xff0c;坚定了继续搞科研的决心&#xff0c;至死不渝。希望我们每个人都能有远大的理想&#xff0c;并为之付出不懈的奋斗。 目录 一、为什么 二、怎么设计 1. 问题和答案的显示 2. 答案的记录和保存 三、代…

V神演讲展望Web3发展并认为可引入人工智能

前言 2024 香港 Web3 嘉年华期间&#xff0c;以太坊联合创始人 Vitalik Buterin 发表主旨演讲《Reaching the Limits of Protocol Design》。以下是演讲内容&#xff1a; 区块链与ZK-SNARKS 我们用来构建协议的技术类型在过去 10 年里发生了很大变化。那么&#xff0c;当 2…

德国高速主轴SycoTec代理 高精度高转速主轴一览

速科德电机科技&#xff0c;作为德国高速主轴品牌SycoTec代理以及亚太服务中心&#xff0c;一直致力于将最先进、最可靠的高速电主轴技术带给广大机械加工企业。在现代精密机械制造业中&#xff0c;高速电主轴的应用已经变得不可或缺&#xff0c;而SycoTec高速电主轴以其卓越的…

【七 (1)FineBI FCP模拟试卷-股票收盘价分析】

目录 文章导航一、字段解释二、需求三、操作步骤1、添加计算字段&#xff08;每月最后一天的收盘价&#xff09;2、绘制折线图 文章导航 【一 简明数据分析进阶路径介绍&#xff08;文章导航&#xff09;】 一、字段解释 Company Name&#xff1a;公司名称 Date&#xff1a;…

UE5 C++ 创建3DWidgete 血条 再造成伤害

一&#xff0e;创建 二&#xff0e;&#xff35;&#xff29;里声明变量 创建类 public:UPROPERTY(EditAnywhere,BlueprintReadWrite,Category "MyWidget")float CurrentHealth 100.0f;UPROPERTY(EditAnywhere,BlueprintReadWrite,Category "MyWidget"…

【嵌入式】嵌入式开发中常见的面试题(持续更新中)

&#x1f9d1; 作者简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟,欢迎关注。提供嵌入式方向的学习指导…

Linux--进程间的通信--进程池

进程间的通信–匿名管道 进程池的概念 进程池是一种将多个进程组织起来以执行特定任务的机制。它由多个预先创建好的资源进程和一个管理进程组成。这些资源进程被管理进程负责分配和调度&#xff0c;用于处理任务。 当有新的任务提交时&#xff0c;管理进程会从进程池中取出一…

主线程捕获子线程异常

正常情况下使用多线程出现异常时&#xff0c;都是按照单个任务去处理异常&#xff0c;在线程间不需要通信的情况下&#xff0c;任务之间互不影响&#xff0c;主线程也不必知道子线程是否发成异常。 那么只需要处理子线程异常即可 Task.Run(() > {try{throw new Exception(&…

苍穹外卖学习记录(二)

本节&#xff0c;主要是学习业务逻辑&#xff0c;我们以菜品管理为例&#xff1a; 在实现这部分前&#xff0c;我们要完成Mybatis的配置&#xff0c;即指定映射的mapper.xml文件路径以及对应的实体类&#xff0c;这部分配置是在application.yml文件中实现的。 mybatis:#mapper…

计算机网络(四)网络层

网络层 基本概念 网络互联&#xff1a; 将两个以上的计算机网络&#xff0c;通过一定的办法&#xff0c;用一种或多种通信处理设备(即中间设备)相互连接起来&#xff0c;以构成更大的网络系统。中间设备又称中间系统或中继系统 中继系统分为4种&#xff1a; 物理层中继系统…

thinkphp 框架封装curl请求

tp6 或者 tp8框架 在框架的app/common.php 文件里加一些方法就可以 app\common.php 在这个文件里加 以下代码 就可以实现基于 curl的请求方法 (记得要开启 php的curl扩展) 查看方法 cmd里输入 php -m if (!function_exists(get)) {/*** 发送get请求* param string $url 请求…

ChatGPT实用指南2024

随着ChatGPT技术的演进&#xff0c;越来越多的人开始在工作中利用此工具。以下是关于ChatGPT的实用指南&#xff0c;适合不太熟悉此技术的朋友参考。 一、ChatGPT概述 1. ChatGPT是什么&#xff1f; ChatGPT是基于OpenAI开发的GPT大型语言模型的智能对话工具。它能够通过自然语…

前端框架模板

前端框架模板 1、vue-element-admin vue-element-admin是基于element-ui 的一套后台管理系统集成方案。 **功能&#xff1a;**https://panjiachen.github.io/vue-element-admin-site/zh/guide/#功能 **GitHub地址&#xff1a;**GitHub - PanJiaChen/vue-element-admin: :t…