GD32F470_ADS1115 超小型 16位 模数转换器 ADC 4通道模块移植

news2025/1/14 18:06:53

2.9 ADS1115多路模数转换器
ADS1115 器件是兼容 IIC 的 16 位高精度低功耗模数转换器 (ADC),采用超小型无引线 X2QFN-10 封装和 VSSOP-10 封装。ADS111x 器件采用了低漂移电压基准和振荡器。ADS1114 和 ADS1115 还采用可编程增益放大器(PGA)和数字比较器。这些特性加以较宽的工作电源电压范围使得 ADS1115 非常适合功率与空间受限的传感器测量。
ADS111x 可在数据速率高达每秒 860 个样本 (SPS) 的情况下执行转换。PGA 可提供从 ±256mV 到±6.144V 的输入范围,从而实现精准的大小信号测量。ADS1115 具有 一个输入多路复用器 (MUX),可实现两次差动输入测量或四次单端输入测量。在ADS1115 中可使用数字比较器进行欠压和过压检测。 ADS1115既可在连续转换模式下工作,也可在单冲模式下工作。在单冲模式下,这些器件可在一次转换后自动断电;因此显著降低了空闲期间的功耗。
2.9.1 模块来源
采购链接:
ADS1115 超小型 16位 模数转换器 ADC 4通道
资料下载:
链接:https://pan.baidu.com/s/1yVZy_tSp5LXCBbZAZPPX4w?pwd=cd63
提取码:cd63

2.9.2 规格参数
工作电压:2.0-5.5V
工作电流:150uA
采集精度:16位
采集通道:4通道
控制方式:IIC
管脚数量:10 Pin(2.54mm间距排针)
工作电流:150uA
采集精度:16位
采集通道:4通道
控制方式:IIC
管脚数量:10 Pin(2.54mm间距排针)

2.9.3 移植过程
我们的目标是在梁山派GD32F470上能够实现4路ADC采集电压功能。首先要获取资料,查看数据手册应如何实现,再移植至我们的工程。
2.9.3.1 查看资料
ADS1115是采用的IIC通信,所以首先要了解IIC的地址与时序,再确定根据寄存器的设置。
(1)器件地址
器件地址的设置见下表。
在这里插入图片描述
说明:当模块上的ADDR引脚接入GND时,其器件地址为1001000,最后一位数据是读写位。

BIT 7BIT 6BIT 6BIT 4BIT 3BIT 2BIT 1BIT 0
1001000R/W

当模块上的ADDR引脚接入VDD时,其器件地址为1001001,最后一位数据是读写位。

BIT 7BIT 6BIT 6BIT 4BIT 3BIT 2BIT 1BIT 0
1001001R/W

本文以接入GND为地址。即后续的地址为0X90。
(2)时序
下图是读时序,步骤是:
IIC起始信号-> 发送器件地址+0(写) -> 等待模块应答 -> 应答后发送寄存器地址 -> 等待模块应答 -> 重新发送起始信号 -> 发送器件地址+1(读) -> 等待模块应答 -> 应答后读取高8位数据 -> 读取完毕主机发送应答信号 -> 读取低8位数据 -> 读取完毕主机发送应答信号 -> 发送IIC停止信号。

在这里插入图片描述
下图是写时序,步骤是:
IIC起始信号-> 发送器件地址+0(写) -> 等待模块应答 -> 应答后发送寄存器地址 -> 等待模块应答 -> 应答后写入高8位数据 -> 等待模块应答 -> 写入低8位数据 -> 等待模块应答 -> 发送IIC停止信号。
在这里插入图片描述
(3)寄存器说明
ADS1115有四个寄存器,可通过IIC接口使用地址指针进入。

  • 地址0X00为转换寄存器,它包含最后一次转换的结果。

  • 地址0X01为配置寄存器,用于更改ADS1115的工作模式和查询设备状态。

  • 另外两个寄存器,Lo_thresh和Hi_thresh,设置用于比较器函数的阈值,我们用不到。
    在这里插入图片描述
    配置寄存器说明
    配置寄存器有16位,用于控制工作模式、输入选择、数据速率、满量程范围和比较器模式。
    在这里插入图片描述
    第15位:OS,读操作时可以知道当前设备的工作状态;写操作时可以设置单次转换。本文配置为1(必须为断电模式下,当对OS写1时,设备会进入上电模式并完成一次数据转换,然后会自动将OS置0)
    第14-12位:MUX为输入多路复用器,对输入模式进行选择,如下图有八种输入模式,分别是四种差分与四种单端输入,本文配置为A0单端输入(0x04)。(单端输入就是测量的数据有两个引脚,一个输出一个地。将测量的输出接入A0引脚,测量的地与ADS1115共地)
    在这里插入图片描述
    第11-9位:PGA为可编程增益放大器,设置FSR(满刻度的范围),本文配置为±4.096V(0x01)后面电压计算公式与这个有关。
    在这里插入图片描述

    第8位:MODE选择持续转换模式与单次转换模式(单次转换模式需要OS位触发),本文配置为连续转换模式(0x00)在这里插入图片描述

    第7-5位:DR配置data rate数据传输速率,本文配置为128SPS(0x04)
    在这里插入图片描述
    第4-2位:对比较器的配置,我们不使用,默认为0即可(0x00)
    第1-0位:本位配置为关闭比较器并将ALERT/RDY引脚设置为高阻抗模式(0x03)

在这里插入图片描述
最终得到的配置结果为1100_0010_1000_0011(0xC283)。
当前配置的是A0的引脚,我们后续获取数据也是从A0引脚读取。
转换寄存器说明
16位转换寄存器以二进制的补码格式保存最后一次转换的结果。需要注意的是,在上电之后,转换寄存器被清除为0,并保持为0,直到第一次转换完成。

在这里插入图片描述
(4)实现代码说明
读取到的ADC值如何换算为电压?
以PGA设置为4.96V为例。
电压 = 采集到的ADC值 * 分辨率
分辨率 = 测量电压范围 / (2^AD位数-1) = 4.096 / 2的15次方 = 0.000125V
分辨率也可以在数据手册中查看,见右图。其中125uV = 0.125mV = 0.000125V。
在这里插入图片描述

/******************************************************************
 * 函 数 名 称:WriteADS1115
 * 函 数 说 明:向ADS1115的add地址写入dat数据
 * 函 数 形 参: add写入寄存器地址 
 *             dat_H写入的高8位数据  
 *             dat_L写入的低8位数据
 * 函 数 返 回:0写入成功 
 *             1写入器件地址无应答  
 *             2写入寄存器地址无应答 
 * 作       者:LC
 * 备       注:器件地址=0X90   
******************************************************************/
uint8_t WriteADS1115(uint8_t add,uint8_t dat_H,
                    uint8_t dat_L)
{
  IIC_Start();//起始信号
  IIC_Write(0x90);//器件地址     
  if( IIC_Wait_Ack() == 1 )
      return 1; 
  IIC_Write(add);//寄存器地址   
  if( IIC_Wait_Ack() == 1 )
      return 2;
  IIC_Write(dat_H);//写入高8位     
  IIC_Wait_Ack();//等待应答
  IIC_Write(dat_L);//写入低8位
  IIC_Wait_Ack();//等待应答
  IIC_Stop();//停止信号  
  return (0);
}
/******************************************************************
 * 函 数 名 称:ReadADS1115
 * 函 数 说 明:读取ADS1115的数据
 * 函 数 形 参:add读取的寄存器地址
 * 函 数 返 回:-1-读取失败  其他-读取成功
 * 作       者:LC
 * 备       注:无
******************************************************************/
float ReadADS1115(unsigned char add)
{
  int i =0;
  unsigned char dat[2]={0};
  unsigned int num = 0;
  float ret=0;
  IIC_Start();//起始信号
  IIC_Write(0x90);//器件地址+写
  if( IIC_Wait_Ack() == 1 ) 
      return -1;
  IIC_Write(add);//寄存器地址
  if( IIC_Wait_Ack() == 1 ) 
      return -1;  
  do{
    //超时判断
    i++;
    if( i > 20 ) return -1;  
    delay_1ms(1);
    IIC_Start();//重新发送起始信号
    IIC_Write(0x91);//器件地址+读
  }while(IIC_Wait_Ack() == 1);
    
  dat[0]=IIC_Read();//读高8位数据 
  IIC_Send_Ack(0);//应答
  dat[1]=IIC_Read();//读低8位数据 
  IIC_Send_Ack(1);//非应答  
  IIC_Stop();//发送停止信号
  //数据整合
  num =  ((dat[0]<<8) | (dat[1])); 
  //分辨率计算:测量电压范围/(2^AD位数-1)
  //    分辨率= 4.096/2^15=0.000125
  //      电压= 采集到的ADC值 * 分辨率
  if(num>32768)
      ret=(65535-num)*0.000125;
  else
      ret=num*0.000125;
   
  return ret;
}

2.9.3.2 引脚选择

ADS1115立创·梁山派
VDD5V
GNDGND
SCLPB8
SDAPB9
A0接入要测量的电压

在这里插入图片描述
2.9.3.3 移植至工程
移植步骤中的导入.c和.h文件与之前相同,只是将.c和.h文件更改为bsp_ads1115.c与bsp_ads1115.h。见2.2.3.3 移植至工程。这里不再过多讲述。移植完成后面修改相关代码。
在文件bsp_ads1115.c中,编写如下代码。

/********************************************************************************
  * 文 件 名: bsp_ads1115.c
  * 版 本 号: 初版
  * 修改作者: LC
  * 修改日期: 2023年04月06日
  * 功能介绍:          
  ******************************************************************************
  * 注意事项:
*********************************************************************************/

#include "bsp_ads1115.h"
#include "systick.h"
#include "stdio.h"

/******************************************************************
 * 函 数 名 称:ADS1115_GPIO_Init
 * 函 数 说 明:对IIC引脚初始化
 * 函 数 形 参:无
 * 函 数 返 回:无
 * 作       者:LC 
 * 备       注:1100_0010_1000_0011  WriteADS1115(0x01,0xc2,0x83);
******************************************************************/
void ADS1115_GPIO_Init(void)
{                                
        //打开SDA与SCL的引脚时钟
        rcu_periph_clock_enable(RCU_SCL);
        rcu_periph_clock_enable(RCU_SDA);

        //设置SCL引脚模式为上拉输出
        gpio_mode_set(PORT_SCL, GPIO_MODE_OUTPUT, GPIO_PUPD_PULLUP, GPIO_SCL);
        //设置引脚为开漏模式,翻转速度2MHz
        gpio_output_options_set(PORT_SCL, GPIO_OTYPE_OD, GPIO_OSPEED_2MHZ, GPIO_SCL);        
        //设置引脚输出高电平SCL等待信号
        gpio_bit_write(PORT_SCL, GPIO_SCL, SET);
        
        //设置SDA引脚
        gpio_mode_set(PORT_SDA, GPIO_MODE_OUTPUT, GPIO_PUPD_PULLUP, GPIO_SDA);
        gpio_output_options_set(PORT_SDA, GPIO_OTYPE_OD, GPIO_OSPEED_2MHZ, GPIO_SDA);        
        gpio_bit_write(PORT_SDA, GPIO_SDA, SET);
        //写入配置参数            
        WriteADS1115(0x01,0xC2,0x83);
}

/******************************************************************
 * 函 数 名 称:IIC_Start
 * 函 数 说 明:IIC起始信号
 * 函 数 形 参:无
 * 函 数 返 回:无
 * 作       者:LC
 * 备       注:无
******************************************************************/
void IIC_Start(void)
{
        SDA_OUT();
                   
        SDA(1);
        delay_1us(5);
        SCL(1); 
        delay_1us(5);
        
        SDA(0);
        delay_1us(5);
        SCL(0);
        delay_1us(5);
                       
}
/******************************************************************
 * 函 数 名 称:IIC_Stop
 * 函 数 说 明:IIC停止信号
 * 函 数 形 参:无
 * 函 数 返 回:无
 * 作       者:LC
 * 备       注:无
******************************************************************/
void IIC_Stop(void)
{
        SDA_OUT();
        SCL(0);
        SDA(0);
        
        SCL(1);
        delay_1us(5);
        SDA(1);
        delay_1us(5);
        
}
/******************************************************************
 * 函 数 名 称:IIC_Send_Ack
 * 函 数 说 明:主机发送应答
 * 函 数 形 参:0应答  1非应答
 * 函 数 返 回:无
 * 作       者:LC
 * 备       注:无
******************************************************************/
void IIC_Send_Ack(unsigned char ack)
{
        SDA_OUT();
        SCL(0);
        SDA(0);
        delay_1us(5);
        if(!ack) SDA(0);
        else     SDA(1);
        SCL(1);
        delay_1us(5);
        SCL(0);
        SDA(1);
}
/******************************************************************
 * 函 数 名 称:IIC_Wait_Ack
 * 函 数 说 明:等待从机应答
 * 函 数 形 参:无
 * 函 数 返 回:1=无应答   0=有应答
 * 作       者:LC
 * 备       注:无
******************************************************************/

unsigned char IIC_Wait_Ack(void)
{
        
        char ack = 0;
        unsigned char ack_flag = 10;
        SDA_IN();
        SDA(1);
        delay_1us(5);
        SCL(1);
        delay_1us(5);
        while( (GETSDA()==1) && ( ack_flag ) )
        {
                ack_flag--;
                delay_1us(5);
        }
        
        if( ack_flag <= 0 )
        {
                IIC_Stop();
                return 1;
        }
        else
        {
                SCL(0);
                SDA_OUT();
        }
        return ack;
}
/******************************************************************
 * 函 数 名 称:IIC_Write
 * 函 数 说 明:IIC写一个字节
 * 函 数 形 参:dat写入的数据
 * 函 数 返 回:无
 * 作       者:LC
 * 备       注:无
******************************************************************/
void IIC_Write(unsigned char dat)
{
        int i = 0;
        SDA_OUT();
        SCL(0);//拉低时钟开始数据传输
        
        for( i = 0; i < 8; i++ )
        {
                SDA( (dat & 0x80) >> 7 );
                __nop();
                __nop();
                __nop();
                dat<<=1;
                delay_1us(6); 
                SCL(1);
                delay_1us(4);
                SCL(0);
                delay_1us(4);
                
        }        
}

/******************************************************************
 * 函 数 名 称:IIC_Read
 * 函 数 说 明:IIC读1个字节
 * 函 数 形 参:无
 * 函 数 返 回:读出的1个字节数据
 * 作       者:LC
 * 备       注:无
******************************************************************/
unsigned char IIC_Read(void)
{
        unsigned char i,receive=0;
    SDA_IN();//SDA设置为输入
    for(i=0;i<8;i++ )
        {
        SCL(0);
        delay_1us(5);
        SCL(1);
        delay_1us(5);
        receive<<=1;
        if( GETSDA() )
        {        
            receive|=1;   
        }
        delay_1us(5); 
    }                
  return receive;
}

/******************************************************************
 * 函 数 名 称:WriteADS1115
 * 函 数 说 明:向ADS1115的add地址写入dat数据
 * 函 数 形 参:add写入寄存器地址 dat_H写入的高8位数据  dat_L写入的低8位数据
 * 函 数 返 回:0写入成功 1写入器件地址无应答  2写入寄存器地址无应答 
 *              3写入高8位数据无应答  4写入低8位数据无应答
 * 作       者:LC
 * 备       注:器件地址=0X90   
******************************************************************/
uint8_t WriteADS1115(uint8_t add,uint8_t dat_H,uint8_t dat_L)
{
  IIC_Start();
  IIC_Write(0x90);     
  if( IIC_Wait_Ack() == 1 )
  {      
      printf("error 1\r\n");
       return 1; 
  }
  IIC_Write(add);   
  if( IIC_Wait_Ack() == 1 ) 
  {
      printf("error 2\r\n");
      return 2;     
  }
  IIC_Write(dat_H);     
  IIC_Wait_Ack();
  IIC_Write(dat_L);     
  IIC_Wait_Ack();
  IIC_Stop();  
  return (0);
}



/******************************************************************
 * 函 数 名 称:ReadADS1115
 * 函 数 说 明:读取ADS1115的数据
 * 函 数 形 参:add读取的寄存器地址
 * 函 数 返 回:-1-读取失败  其他-读取成功
 * 作       者:LC
 * 备       注:无
******************************************************************/
float ReadADS1115(unsigned char add)
{
  int i =0;
  unsigned char dat[2]={0};
  unsigned int num = 0;
  float ret=0;
  IIC_Start();//起始信号
  IIC_Write(0x90);//器件地址+写
  if( IIC_Wait_Ack() == 1 ) 
      return -1;
  IIC_Write(add);//寄存器地址
  if( IIC_Wait_Ack() == 1 ) 
      return -1;  
  do{
    //超时判断
    i++;
    if( i > 20 ) return -1;  
    delay_1ms(1);
    IIC_Start();//重新发送起始信号
    IIC_Write(0x91);//器件地址+读
  }while(IIC_Wait_Ack() == 1);
    
  dat[0]=IIC_Read();//读高8位数据 
  IIC_Send_Ack(0);//应答
  dat[1]=IIC_Read();//读低8位数据 
  IIC_Send_Ack(1);//非应答  
  IIC_Stop();//发送停止信号
  //数据整合
  num =  ((dat[0]<<8) | (dat[1])); 

        //数值计算取决于PGA配置
    //2的15次方=32768
    //设置的最大量程4.096
//        if(num>32768)
//                ret=((float)(65535-num)/32768.0)*4.096;
//        else
//                ret=((float)num/32768.0)*4.096;

  //分辨率计算:测量电压范围/(2^AD位数-1)
  //    分辨率= 4.096/2^15=0.000125
  //      电压= 采集到的ADC值 * 分辨率
  if(num>32768)
      ret=(65535-num)*0.000125;
  else
      ret=num*0.000125;
   
  return ret;
}


在文件bsp_ads1115.h中,编写如下代码。

#ifndef _BSP_ADS1115_H_
#define _BSP_ADS1115_H_
 
#include "gd32f4xx.h"


#define RCU_SCL  RCU_GPIOB
#define PORT_SCL GPIOB
#define GPIO_SCL GPIO_PIN_8

#define RCU_SDA  RCU_GPIOB
#define PORT_SDA GPIOB
#define GPIO_SDA GPIO_PIN_9


#define SDA_IN()  {gpio_mode_set(PORT_SDA, GPIO_MODE_INPUT,  GPIO_PUPD_PULLUP, GPIO_SDA);}        //SDA输入模式
#define SDA_OUT() {gpio_mode_set(PORT_SDA, GPIO_MODE_OUTPUT, GPIO_PUPD_PULLUP, GPIO_SDA);}  //SDA输出模式

#define SCL(BIT)  gpio_bit_write( PORT_SCL, GPIO_SCL, BIT?SET:RESET)
#define SDA(BIT)  gpio_bit_write( PORT_SDA, GPIO_SDA, BIT?SET:RESET)
#define GETSDA()  gpio_input_bit_get( PORT_SDA, GPIO_SDA)


void ADS1115_GPIO_Init(void);
unsigned char WriteADS1115(unsigned char add,unsigned char dat_H,unsigned char dat_L);
float ReadADS1115(unsigned char add);
#endif


2.9.4 移植验证
在自己工程中的main主函数中,编写如下。

/********************************************************************************
  * 文 件 名: main.c
  * 版 本 号: 初版
  * 修改作者: LC
  * 修改日期: 2023年04月06日
  * 功能介绍:          
  ******************************************************************************
  * 注意事项:
*********************************************************************************/

#include "gd32f4xx.h"
#include "systick.h"
#include "bsp_usart.h"
#include "bsp_ads1115.h"
#include "stdio.h"

int main(void)
{
        nvic_priority_group_set(NVIC_PRIGROUP_PRE2_SUB2);  // 优先级分组
        systick_config();                //滴答定时器初始化 1ms
        usart_gpio_config(115200);
        ADS1115_GPIO_Init();
    
        printf("demo start\r\n");
        while(1) 
        {
            //当前设置最大量程为4.096V
            printf("A0 = %.4f\r\n", ReadADS1115(0x00) );//读取A0的值
            delay_1ms(1000);
        }
}

移植现象:将A0接入GND、3.3V和5V。

在这里插入图片描述
移植成功示例,见文件2.9.4-1 。

文件2.9.4-1

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

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

相关文章

kali报错Unable to connect to remote host: No route to host,如何解决??

&#x1f3c6;本文收录于「Bug调优」专栏&#xff0c;主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&收藏&&…

《搜广推算法指南》(2024版) 重磅发布!

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学&#xff0c;针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 结合…

全自动封箱机的工作原理:科技与效率的完美结合

随着科技的不断发展&#xff0c;越来越多的自动化设备走进了我们的日常生活和工业生产中。其中&#xff0c;全自动封箱机作为物流包装领域的重要一环&#xff0c;凭借其高效、精准的工作性能&#xff0c;正逐渐成为提升生产效率、降低劳动成本的得力助手。星派就来与大家深入探…

python调用java中的jar

一、基于IDEA生成可执行jar包 1、编写class的代码&#xff0c;注意一定要有main()方法才可以生成jar包&#xff0c;main()方法可以没有内容。例如下Java 代码&#xff1a; package Project;public class Demo {public static void main(String[] args){Demo t2 new Demo();S…

HarmonyOS(鸿蒙)——单击事件

2.4 实现ClickedListener接口并重写onClick方法 2.5 实现onClick方法中的具体逻辑&#xff0c;以此完成点击事件的相关业务操作 三、测试 3.1 登录远程模拟器 3.2 运行项目 四、精选好文 一、简介 1.1 什么是组件 组件就是文本、按钮、图片等元素的统称 1.2 什么是事件 …

NKCTF2024 re VM?VM!WP

逻辑似乎很简单&#xff08;个鬼啊&#xff09; 这个函数是把输入的字符转化为二进制并倒序存储 sub_1570太大了加载不出来&#xff0c;应该是加密的主逻辑&#xff0c;目的是需要输出1 可以通过删除栈的方法强行转化伪代码 首先删掉这部分 9A0改小点 这个也是 栈这里U一下再…

docker部署在线流程图

下载镜像 docker pull registry.cn-beijing.aliyuncs.com/wuxingge123/drawio:latestdocker-compose部署 vim docker-compose.yml version: 3 services:drawio:container_name: drawioimage: registry.cn-beijing.aliyuncs.com/wuxingge123/drawio:latestports:- 8083:8080v…

【MATLAB源码-第25期】基于matlab的8QAM调制解调仿真,手动实现未调用内置函数,星座图展示。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 8QAM调制&#xff08;8 Quadrature Amplitude Modulation&#xff09;是一种数字调制技术&#xff0c;它可以在有限带宽内传输更多的信息比特。在8QAM调制中&#xff0c;每个符号可以携带3个比特的信息。QAM调制是将数字信号…

【数据分析面试】6.计算对话总数(SQL)

题目&#xff1a;计算对话总数 给定了名为 messenger_sends 的消息发送表格&#xff0c;找出总共有多少个唯一的对话。 注&#xff1a;在某些记录中&#xff0c;receiver_id 和 sender_id 从初始消息中互换了。这些记录应视为同一个对话。 示例&#xff1a; 输入&#xff1…

ubuntu更换国内镜像源,下载增速

方法一&#xff1a;通过脚本更换源 1.备份原来的源 sudo cp /etc/apt/sources.list /etc/apt/sources_init.list 将原来的源保留一下&#xff0c;以后想用还可以继续用 2.更换源 sudo gedit /etc/apt/sources.list 使用gedit打开文档&#xff0c;将下面的阿里源复制进去&am…

微信小程序纯CSS实现好看的加载动画

进入下面小程序可以体验效果&#xff1a; WXML: <wxs module"img" src"./loading.wxs"></wxs> <view class"loading-container {{show?:loading-container-hide}}"><view class"loading-mask" wx:if"{{ma…

分享:搭建企微知识库简单易学步骤

说起企微知识库&#xff0c;可能有些人还不太清楚&#xff0c;为什么现在很懂企业选择搭建企微知识库&#xff1f;其实&#xff0c;企微知识库就是一个装满了企业的各种知识、经验和资料的载体。目的是为了方便员工随时查找和学习、有助于知识的传承和共享、加强团队协作和沟通…

《机器学习算法实战宝典》正式发布!

大家好&#xff0c;我是城哥&#xff0c;最近写了两本资料&#xff0c;一本是&#xff1a;《机器学习算法面试宝典》正式发布&#xff01;&#xff0c;内容是面试技巧、面试真题、常考题等。 今天分享的《机器学习算法实战宝典》&#xff08;以下简称《算法实战宝典》&#xf…

element-ui avatar 组件源码分享

今日简单分享 avatar 组件的源码实现&#xff0c;主要从以下四个方面&#xff1a; 1、avatar 组件页面结构 2、avatar 组件属性 3、avatar 组件事件 4、avatar 组件 slot 一、avatar 组件页面结构 二、avatar 组件属性 2.1 icon 属性&#xff0c;设置头像的图标类型&…

【Redis】分布式锁及其他常见问题

分布式锁及其他常见问题 1. 我看你的项目都用到了 Redis&#xff0c;你在最近的项目的哪些场景下用到了 Redis 呢&#xff1f; 一定要结合业务场景来回答问题&#xff01;要是没有不要硬讲&#xff0c;除非面试官问&#xff1b; 接下来面试官将深入发问。 你没用到的也可能会…

VS Code 配置 cmake

手动添加 CMake 编译器的搜索路径 如果没有设置上面的路径&#xff0c;有些编译器是找不到的

基于SpringBoot和Vue的校园周边美食探索以及分享系统

今天要和大家聊的是基于SpringBoot和Vue的校园周边美食探索以及分享系统 &#xff01;&#xff01;&#xff01; 有需要的小伙伴可以通过文章末尾名片咨询我哦&#xff01;&#xff01;&#xff01; &#x1f495;&#x1f495;作者&#xff1a;李同学 &#x1f495;&#x1f…

kali 渗透工具 - mestaploit

永恒之蓝漏洞的小知识&#xff1a; 黑客通过改造 永恒之蓝 制作 wannacry 制作病毒入侵高校内网。 mestaploit 攻击永恒之蓝流程&#xff1a; 使用模块 msfconsole配置required 模块参数运行&#xff0c;开始监听主机 msfconsole 主要模块 - 选择使用模块 search ms17_01…

工业组态 物联网组态 组态编辑器 web组态 组态插件 编辑器

体验地址&#xff1a;by组态[web组态插件] BY组态是一款非常优秀的纯前端的【web组态插件工具】&#xff0c;可无缝嵌入到vue项目&#xff0c;react项目等&#xff0c;由于是原生js开发&#xff0c;对于前端的集成没有框架的限制。同时由于BY组态只是一个插件&#xff0c;不能独…

大转盘抽奖小程序源码

源码介绍 大转盘抽奖小程序源码&#xff0c;测试依旧可用&#xff0c;无BUG&#xff0c;跑马灯旋转效果&#xff0c;非常酷炫。 小程序核心代码参考 //index.js //获取应用实例 var app getApp() Page({data: {circleList: [],//圆点数组awardList: [],//奖品数组colorCirc…