嵌入式学习——硬件(IIC、ADC)——day56

news2025/1/24 18:02:06

1. IIC

1.1 定义(同步串行半双工通信总线)

        IIC(Inter-Integrated Circuit)又称I2C,是是IICBus简称,所以中文应该叫集成电路总线。是飞利浦公司在1980年代为了让主板、嵌入式系统或手机用以连接低速周边设备而发展而来的一种同步串行半双工通信总线方式。该总线允许同时连接多个设备(芯片)。每块芯片在总线上拥有特定的地址。自2006年10月1日起,使用I²C协议已经不需要支付专利费,但制造商仍然需要付费以获取IIC从属设备地址。

1.2 作用

  1. 设备间通信:I²C用于微控制器和各种外围设备(如传感器、EEPROM、ADC/DAC、LCD显示器等)之间的数据传输。
  2. 多主多从结构:I²C支持多主多从架构,允许多个主设备和多个从设备在同一总线上通信。
  3. 地址分配:每个从设备在总线上都有一个唯一的地址,主设备通过该地址来选择并与特定从设备通信。
  4. 时钟同步:I²C使用单主时钟同步,主设备生成时钟信号,从设备响应时钟信号进行数据传输。
  5. 双向数据传输:I²C支持双向数据传输,主设备可以向从设备发送数据,也可以从从设备读取数据。

1.3 IIC的组网模式

       上图所示是IIC的总线的使用场景,所有挂载在IIC总线上的设备都有两根信号线,一根是数据线SDA,另一根是时钟线SCL。这两个信号线都是双向的。

       作为一种通信方式,IIC总线在某一时刻,总线只允许有一个设备处于发送状态,所发出的数据被总线上所有的设备所接收。IIC通信协议包含有设备地址,只有发送方携带的地址与某个接收方的地址相同时,接收方才真正执行相关的指令。

       IIC总线规定,设备在空闲时,两根总线都处于高电平状态。为保证这种状态,数据线SDA和时钟线SCL都要外接上拉电阻。上拉电阻的阻值一般位4.7~10K。。I2C 总线标准模式下速度可以达到 100Kb/S,快速模式下可以达到 400Kb/S。I2C 总线工作是按照一定的协议来运行的,接下来就看一下 I2C 协议。

1.4 IIC代码

#include <s3c2440.h>
#include <string.h>
#include <stdio.h>
#include "led.h"
#include "key.h"
#include "interrupt.h"
#include "delay.h"
#include "pwm.h"

#define ADDRESS 0X08

void init_wdt(void)	//初始化看门狗,禁止启动,关闭看门狗
{
	WTCON &= ~(1 << 0);
}

void init_clk(void)
{
	unsigned int t = MPLLCON; //将PCLK频率存入变量设置好再进行修改,防止频率修改中途器件因为频率过高而短路
	t &= ~((0xff << 12) | (0x3f << 4) | (3 << 0)); //利用锁相环将12MHz倍频
	t |= ((127 << 12) | (2 << 4) | (1 << 0)); //配置fclk频率大约为400Mhz
	CLKDIVN |= ((2 << 1) | (1 << 0));//分频,配置HCLK为100MHz,HCLK为50MHz	
	MPLLCON = t;//将所有频率配置好再进行设置,防止器件被烧坏
}

unsigned char buffer[128] = {0};//存储pc给s3c2440发送,s3c2440接收到的字符串
unsigned char tmpbuffer[128];
unsigned int pos;//已经收到字符的个数,下一个要收到字符的位置

void uart0_handler(void)
{
	if (SUBSRCPND & (1 << 0))//如果UART0接收到了数据
	{
		buffer[pos++] = URXH0;			
	}
	SUBSRCPND = SUBSRCPND;	
}

void init_uart0(void)
{
	unsigned int t = 0;

	GPHCON &= ~(0x0f << 4);
	GPHCON |= ((2 << 6) | (2 << 4));//设置中断模式,串口电路引脚寄存器功能

	t = ULCON0;		//9600 n 8 1 波特率? 校验位? 数据位? 停止位
	t &= ~(1 << 6);//不使用红外模式
	t &= ~(7 << 3);//无奇偶校验
	t &= ~(1 << 2);//每帧 1 个停止位
	t |= (3 << 0);//每帧用于发送或接收的数据位的个数8位
	ULCON0 = t;

	t = UCON0;	 //s3c2440给电脑发送数据用轮询   电脑给s3c2440发送数据,s3c2440接收数据触发中断
	t &= ~(3 << 10);//选PCLK给 UART 波特率
	t &= ~(3 << 8);//发送接收方式改为脉冲方式
	t &= ~(0x0f << 4);// 都设置为普通模式
	t &= ~(0x0f << 0);
	t |= (0x05 << 0);//设置UART模式发送轮询  接收模式为中断
	UCON0 = t;

	INTSUBMSK &= ~(1 << 0);//uart子中断改为可服务状态
	enable_irq(IRQ_UART0);//配置中断为IRQ模式,让中断处于可服务模式	  //配置接收的中断
	register_irq(IRQ_UART0 ,uart0_handler);

	UBRDIV0 = 325;//波特率分频寄存器 50000000/9600/16-1约等于325
	pos = 0;		 	 
}

void uart0_send_char(unsigned char ch)
{
	UTXH0 = ch;	// UART0 要发送的数据   UART 发送缓冲 寄存器
	while(0 == (UTRSTAT0 & (1 << 2)));//数据发完的标志   UART TX/RX 状态 寄存器	
}

void send_buffer(const char *p, unsigned int len)
{
	unsigned int i;

	for(i = 0;i < len;++i)
	{
		uart0_send_char(*p++);
	}
}

int parse(const char *p, unsigned int len)//分析上位机pc端发送的信息
{
	int i = 0;
	int n = 0;
	unsigned char tmpnum = 0;

	if (p[0] != 0xaa || p[len-1] != 0x0D)//判断起始校验位
	{
		n = 0;
	}
	if (p[1] != ADDRESS) //判断是否为正确的下位机
	{
		n = 0;
	}

	for (i = 0; i < 8; i++)
	{
		tmpnum += p[i];
	}
	if (p[8] != tmpnum)	 //判断校验位是否正确
	{
		n = 0;
	}

	if (0x01 == p[2])//调频
	{
		n = 1;
	}
	else if (0x02 == p[2]) //点灯
	{
		n = 2;
	}
	
	return n;	
}



int i2c_finished = 0; //中断触发条件

void i2c_handler(void)//一条指令发送结束当ACK回复结束触发中断
{
	i2c_finished = 1;	
} 

void init_i2c(void)//初始化IIC
{
	GPECON &= ~((unsigned int)0x0f << 28);
	GPECON |= ((unsigned int)0x0a << 28);//初始化24C02的I2CSDA、I2CSCL

	IICCON |= (1 << 7);//允许IIC 总线应答使能位  回复ACK
	IICCON |= (1 << 6);//50000000/512约等于96000 小于100k IIC 总线发送时钟预分频器的时钟源选择位
	IICCON |= (1 << 5);//IIC 总线 Tx/Rx 中断使能/禁止位	允许

	enable_irq(IRQ_I2C);//使能中断
	register_irq(IRQ_I2C, i2c_handler);//注册中断

//	GPECON &= ~((unsigned int)0x0F << 28);
//	GPECON |= ((unsigned int)2 << 30) | (2 << 28);
//
//	IICCON |= (1 << 7) | (1 << 6) | (1 << 5);
//	IICCON &= ~(0x0F << 0);
//
//    enable_irq(IRQ_I2C);
//	register_iqr(IRQ_I2C, i2c_handler);
}

void do_and_wait_ack(void)
{
	i2c_finished = 0;
	IICCON &= ~(1 << 4); //发送使能,清除挂起位
	while (0 == i2c_finished)//判断是否发送完成
	{
		udelay(100);//不能立马读取,要等一下	
	}	
}

void at24c02_write(unsigned char device_address, unsigned char reg_address, const unsigned char *data, unsigned char n)//主机写——设备地址、寄存器地址、要写入数据的指针、数据字节数 
{
	unsigned int i = 0;

	IICDS = device_address;//写设备地址
	IICSTAT = 0xF0;	//模式选择 主发送模式、产生起始信号、使能 Rx/Tx
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	IICDS = reg_address;//写设备中寄存器地址
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	for (i = 0; i < n; ++i)//页写,循环发送所有数据
	{
		IICDS = *data++;
		do_and_wait_ack();	
	}

	IICSTAT = 0xD0;//模式选择 主发送信号、产生停止信号、使能 Rx/Tx
	IICCON &= ~(1 << 4); //发送使能,清除挂起位
	udelay(100);//		
}

void at24c02_read(unsigned char device_address, unsigned char reg_address, unsigned char *data, unsigned char n)//主机读(从机发数据给主机)——设备地址、寄存器地址、要读出数据的指针、数据字节数
{
	unsigned int i = 0;

	IICDS = device_address;//写设备地址
	IICSTAT = 0xF0;	//模式选择 主发送模式、产生起始信号、使能 Rx/Tx
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	IICDS = reg_address;//写设备中寄存器地址
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	IICDS = device_address;//写设备地址
	IICSTAT = 0xB0;	//模式选择 主接收模式、产生起始信号、使能 Rx/Tx
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	*data = IICDS;	//第一次没用
	do_and_wait_ack();	

	for (i = 0; i < n; ++i)
	{
		if ((n - 1) == i)
		{
			IICCON &= ~(1 << 7);//回复NACK			
		}
		*data++ = IICDS;
		do_and_wait_ack();		
	}

	IICSTAT = 0x90;
	IICCON |= (1 << 7);
	IICCON &= ~(1 << 4);
	udelay(100);	
}


int main(void)
{
	char s[100] = {0};
	init_wdt();
	init_led();
	init_key();
	init_clk();
	init_delay();
	init_uart0();
	init_i2c();

	at24c02_write(0xA0, 0x00, "ABCDEF", 6);

	at24c02_read(0xA0, 0x00, (unsigned char *)s, 6);

	while(1)
	{
		if(pos != 0)
		{
			mdelay(100);
			at24c02_write(0xA0, 0x00, buffer, pos);
			at24c02_read(0xA0, 0x00, (unsigned char *)s, pos);
			send_buffer(s, pos);
			pos = 0;
		}		
	}

}

2. ADC滤波(中值滤波、高斯滤波、高斯加权均值滤波、最小二乘法)

#include <s3c2440.h>
#include <string.h>
#include <stdio.h>
#include "led.h"
#include "key.h"
#include "interrupt.h"
#include "delay.h"
#include "pwm.h"

#define ADDRESS 0X08

void init_wdt(void)	//初始化看门狗,禁止启动,关闭看门狗
{
	WTCON &= ~(1 << 0);
}

void init_clk(void)
{
	unsigned int t = MPLLCON; //将PCLK频率存入变量设置好再进行修改,防止频率修改中途器件因为频率过高而短路
	t &= ~((0xff << 12) | (0x3f << 4) | (3 << 0)); //利用锁相环将12MHz倍频
	t |= ((127 << 12) | (2 << 4) | (1 << 0)); //配置fclk频率大约为400Mhz
	CLKDIVN |= ((2 << 1) | (1 << 0));//分频,配置HCLK为100MHz,HCLK为50MHz	
	MPLLCON = t;//将所有频率配置好再进行设置,防止器件被烧坏
}

unsigned char buffer[128] = {0};//存储pc给s3c2440发送,s3c2440接收到的字符串
unsigned char tmpbuffer[128];
unsigned int pos;//已经收到字符的个数,下一个要收到字符的位置

void uart0_handler(void)
{
	if (SUBSRCPND & (1 << 0))//如果UART0接收到了数据
	{
		buffer[pos++] = URXH0;			
	}
	SUBSRCPND = SUBSRCPND;	
}

void init_uart0(void)
{
	unsigned int t = 0;

	GPHCON &= ~(0x0f << 4);
	GPHCON |= ((2 << 6) | (2 << 4));//设置中断模式,串口电路引脚寄存器功能

	t = ULCON0;		//9600 n 8 1 波特率? 校验位? 数据位? 停止位
	t &= ~(1 << 6);//不使用红外模式
	t &= ~(7 << 3);//无奇偶校验
	t &= ~(1 << 2);//每帧 1 个停止位
	t |= (3 << 0);//每帧用于发送或接收的数据位的个数8位
	ULCON0 = t;

	t = UCON0;	 //s3c2440给电脑发送数据用轮询   电脑给s3c2440发送数据,s3c2440接收数据触发中断
	t &= ~(3 << 10);//选PCLK给 UART 波特率
	t &= ~(3 << 8);//发送接收方式改为脉冲方式
	t &= ~(0x0f << 4);// 都设置为普通模式
	t &= ~(0x0f << 0);
	t |= (0x05 << 0);//设置UART模式发送轮询  接收模式为中断
	UCON0 = t;

	INTSUBMSK &= ~(1 << 0);//uart子中断改为可服务状态
	enable_irq(IRQ_UART0);//配置中断为IRQ模式,让中断处于可服务模式	  //配置接收的中断
	register_irq(IRQ_UART0 ,uart0_handler);

	UBRDIV0 = 325;//波特率分频寄存器 50000000/9600/16-1约等于325
	pos = 0;		 	 
}

void uart0_send_char(unsigned char ch)
{
	UTXH0 = ch;	// UART0 要发送的数据   UART 发送缓冲 寄存器
	while(0 == (UTRSTAT0 & (1 << 2)));//数据发完的标志   UART TX/RX 状态 寄存器	
}

void send_buffer(const char *p, unsigned int len)
{
	unsigned int i;

	for(i = 0;i < len;++i)
	{
		uart0_send_char(*p++);
	}
}

int parse(const char *p, unsigned int len)//分析上位机pc端发送的信息
{
	int i = 0;
	int n = 0;
	unsigned char tmpnum = 0;

	if (p[0] != 0xaa || p[len-1] != 0x0D)//判断起始校验位
	{
		n = 0;
	}
	if (p[1] != ADDRESS) //判断是否为正确的下位机
	{
		n = 0;
	}

	for (i = 0; i < 8; i++)
	{
		tmpnum += p[i];
	}
	if (p[8] != tmpnum)	 //判断校验位是否正确
	{
		n = 0;
	}

	if (0x01 == p[2])//调频
	{
		n = 1;
	}
	else if (0x02 == p[2]) //点灯
	{
		n = 2;
	}
	
	return n;	
}



int i2c_finished = 0; //中断触发条件

void i2c_handler(void)//一条指令发送结束当ACK回复结束触发中断
{
	i2c_finished = 1;	
} 

void init_i2c(void)//初始化IIC
{
	GPECON &= ~((unsigned int)0x0f << 28);
	GPECON |= ((unsigned int)0x0a << 28);//初始化24C02的I2CSDA、I2CSCL

	IICCON |= (1 << 7);//允许IIC 总线应答使能位  回复ACK
	IICCON |= (1 << 6);//50000000/512约等于96000 小于100k IIC 总线发送时钟预分频器的时钟源选择位
	IICCON |= (1 << 5);//IIC 总线 Tx/Rx 中断使能/禁止位	允许

	enable_irq(IRQ_I2C);//使能中断
	register_irq(IRQ_I2C, i2c_handler);//注册中断

//	GPECON &= ~((unsigned int)0x0F << 28);
//	GPECON |= ((unsigned int)2 << 30) | (2 << 28);
//
//	IICCON |= (1 << 7) | (1 << 6) | (1 << 5);
//	IICCON &= ~(0x0F << 0);
//
//    enable_irq(IRQ_I2C);
//	register_iqr(IRQ_I2C, i2c_handler);
}

void do_and_wait_ack(void)
{
	i2c_finished = 0;
	IICCON &= ~(1 << 4); //发送使能,清除挂起位
	while (0 == i2c_finished)//判断是否发送完成
	{
		udelay(100);//不能立马读取,要等一下	
	}	
}

void at24c02_write(unsigned char device_address, unsigned char reg_address, const unsigned char *data, unsigned char n)//主机写——设备地址、寄存器地址、要写入数据的指针、数据字节数 
{
	unsigned int i = 0;

	IICDS = device_address;//写设备地址
	IICSTAT = 0xF0;	//模式选择 主发送模式、产生起始信号、使能 Rx/Tx
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	IICDS = reg_address;//写设备中寄存器地址
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	for (i = 0; i < n; ++i)//页写,循环发送所有数据
	{
		IICDS = *data++;
		do_and_wait_ack();	
	}

	IICSTAT = 0xD0;//模式选择 主发送信号、产生停止信号、使能 Rx/Tx
	IICCON &= ~(1 << 4); //发送使能,清除挂起位
	udelay(100);//		
}

void at24c02_read(unsigned char device_address, unsigned char reg_address, unsigned char *data, unsigned char n)//主机读(从机发数据给主机)——设备地址、寄存器地址、要读出数据的指针、数据字节数
{
	unsigned int i = 0;

	IICDS = device_address;//写设备地址
	IICSTAT = 0xF0;	//模式选择 主发送模式、产生起始信号、使能 Rx/Tx
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	IICDS = reg_address;//写设备中寄存器地址
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	IICDS = device_address;//写设备地址
	IICSTAT = 0xB0;	//模式选择 主接收模式、产生起始信号、使能 Rx/Tx
	do_and_wait_ack();//使能数据发送并等待发送结束返回ack触发中断

	*data = IICDS;	//第一次没用
	do_and_wait_ack();	

	for (i = 0; i < n; ++i)
	{
		if ((n - 1) == i)
		{
			IICCON &= ~(1 << 7);//回复NACK			
		}
		*data++ = IICDS;
		do_and_wait_ack();		
	}

	IICSTAT = 0x90;
	IICCON |= (1 << 7);
	IICCON &= ~(1 << 4);
	udelay(100);	
}

void init_adc(void)	//初始化ADC
{
	unsigned int t;
	t = ADCCON;
	t |= (1 << 14);	//使能预分频
	t &= ~(0xff << 6);
	t |= (49 << 6);//给预分频值
	t &= ~(0x07 << 3);// 模拟输入通道选择AIN0(引脚)
	t &= ~(1 << 2);// 正常工作模式
	t |= (1 << 1);//使能ADC转换
    ADCCON = t;
}

void do_adc(void)
{
	int i = 0;
	unsigned int ret = 0;//存每次转换好的ADC的值
	unsigned int adc_buffer[10];//存十次adc采样的值
	unsigned long long sum = 0;//存十次采样的总和
	char s[10] = {0};

	ret = ADCDAT0;//取出转化的值

	for (i = 0; i < 10; ++i)
	{
		while (0 == (ADCCON & (1 << 15)))//转换结束标志位、判断ADC是否处理结束
		ret = ADCDAT0 & 0x3ff;//取出转化的值(只要低十位) 
		adc_buffer[i] = ret;
	}

	for (i = 0; i < 10; ++i)
	{
		sum += adc_buffer[i];
	}

	sprintf(s, "%llu\n", sum / 10);//求平均值
	send_buffer((const char *)s, strlen(s));
}

int main(void)
{
//	char s[100] = {0};
	init_wdt();
	init_led();
	init_key();
	init_clk();
	init_delay();
	init_uart0();
	init_i2c();
	init_adc();
	
	do_adc();
//	at24c02_write(0xA0, 0x00, "ABCDEF", 6);
//	at24c02_read(0xA0, 0x00, (unsigned char *)s, 6);

	while(1)
	{
		do_adc();
//		if(pos != 0)
//		{
//			mdelay(100);
//			at24c02_write(0xA0, 0x00, buffer, pos);
//			at24c02_read(0xA0, 0x00, (unsigned char *)s, pos);
//			send_buffer(s, pos);
//			pos = 0;
//		}		
	}
}

1. eeprom电容可擦除、可编程的rom

2. IIC总线上两根线都给高电平,如何保证两根总线上为高电平,给两根总线上都加上拉电阻

10k或4.7k

3.IIC数据高位先行

SCK时钟信号主机提供、数据信号SDA

主机在时钟高电平拉低数据线为起始,主机在时钟高电平拉高终止

红主机、绿从机

主机写,从机给主机应答ACK、

主机读,主机给从机非应答NACK

时钟高电平数据要保持稳定

4. 面试问题

简述IIC时序

5. 

末尾0往硬盘写数据,1从硬盘读数据

6. 每完成一步, 产生一次中断

7. 应答ack不应答nack

发ACK时刻,产生中断

7. 第一次读取的数据是无效的

8. 

ADC只能转电压

八位0~255

十位0~1023

十二位0~4095

n位ADC为比较器的个数

ADC工作原理:逐次逼近法(类似于二分查找)

ksps

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

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

相关文章

Pytorch实战(二)

文章目录 前言一、LeNet5原理1.1LeNet5网络结构1.2LeNet网络参数1.3LeNet5网络总结 二、AlexNext2.1AlexNet网络结构2.2AlexNet网络参数2.3Dropout操作2.4PCA图像增强2.5LRN正则化2.6AlexNet总结 三、LeNet实战3.1LeNet5模型搭建3.2可视化数据3.3加载训练、验证数据集3.4模型训…

在 Postman 中使用 Body 进行 POST 请求

Postman 是开发者日常工具箱中不可缺少的一部分&#xff0c;特别是在 API 开发和调试环节中。 为什么使用 POST 请求 POST 请求用于向服务器发送数据&#xff0c;这些数据通常被处理后存储。与 GET 请求不同&#xff0c;POST 请求将数据嵌入请求体&#xff08;Body&#xff0…

最细最有条理解析:事件循环(消息循环)是什么?进程与线程的定义、关系与差异

目录 事件循环&#xff1a;引入 一、浏览器的进程模型 1.1、什么是进程&#xff08;Process&#xff09; 1.2、什么是线程&#xff08;Thread&#xff09; 1.3、进程与线程之间的关系联系与区别 二、浏览器有哪些进程和线程 2.1、浏览器的主要进程 ①浏览器进程 ②网络…

Vue 快速入门案例

步骤一&#xff1a;引入vue.js文件 添加<script>标签并标明路径 步骤二&#xff1a;定义Vue对象 el Vue接管区域 data 定义数据模型 步骤三&#xff1a;编写视图层的展示 v-model 绑定数据模型 {{要展示的数据模型}} 运行效果 总结 文本框里的值&a…

顺序表(C语言详细版)

1. 线性表 线性表(lina list)是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使用的数据结构&#xff0c;常见的线性表&#xff1a;顺序表、链表、栈、队列、字符串...... 线性表在逻辑上是线性结构&#xff0c;也就是说连续的一条直线。但是在物理结构上并…

进程,线程,虚拟内存,交换技术

参考资料&#xff1a; 参考视频1https://www.bilibili.com/video/BV1Hs421M78w/?spm_id_from333.999.0.0&vd_source97411b9a8288d7869f5363f72b0d7613 参考视频2https://www.bilibili.com/video/BV1jE411W7e8/?spm_id_from333.337.search-card.all.click&vd_source…

动手学深度学习5.6 GPU-笔记练习(PyTorch)

以下内容为结合李沐老师的课程和教材补充的学习笔记&#xff0c;以及对课后练习的一些思考&#xff0c;自留回顾&#xff0c;也供同学之人交流参考。 本节课程地址&#xff1a;17 使用和购买 GPU【动手学深度学习v2】_哔哩哔哩_bilibili 本节教材地址&#xff1a;5.6. GPU —…

STM32第十四课:低功耗模式和RTC实时时钟

文章目录 需求一、低功耗模式1.睡眠模式2.停止模式3.待机模式 二、RTC实现实时时钟1.寄存器配置流程2.标准库开发3.主函数调用 三、需求实现代码 需求 1.实现睡眠模式、停止模式和待机模式。 2.实现RTC实时时间显示。 一、低功耗模式 电源对电子设备的重要性不言而喻&#xff…

springboot校园购物网站APP-计算机毕业设计源码041037

摘 要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们所认识&#xff0c;科学化的管理&#xff0c;使信息存…

以太网常用协议——ARP协议

文章目录 一、 ARP协议与MAC层1.TCP/IP协议2. MAC地址3. ARP映射4. ARP请求和ARP应答 二、以太网帧格式三、ARP协议1. 以太网ARP通信测试&#xff1a; 以太网使用的协议很多&#xff0c;常用的有ARP、UDP等。 再介绍具体协议之前需要先知道一些基本的概念&#xff1a; 一、 AR…

生产环境部署与协同开发-Docker(原创超全)

关闭防火墙 systemctl stop firewalld.service 关闭SELinux vim /etc/selinux/config 查看yum支持的包并安装docker引擎 yum listyum install -y docker 启动docker设置docker自启动测试docker是否安装成功&#xff1f; systemctl start dockersystemctl enable dockerdoc…

HCIE实验这样玩太高级了吧?实现FRR+BFD+OSPF与BGP的联动

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部 晚上好&#xff0c;我的网工朋友。 今天搞个HCIE实验玩玩&#xff0c;上回分享了个张总讲解的防火墙配置实验思路&#xff0c;后来还特地搞了个视…

【电路笔记】-A类放大器

A类放大器 文章目录 A类放大器1、A类放大器概述2、A类放大器基本通用发射极配置3、变压器耦合配置4、总结在 放大器类型简介的文章中,我们介绍了不同类别的放大器。 在本文中,我们将更详细地介绍A类放大器。 在介绍不同的A类放大器配置前,首先的是要记住放大器类别的选择标…

面向优秀SCI论文写作的语言大模型提示词设计

模板1&#xff1a;Abstract 润色 I want you to act as an SCI reviewer and evaluate the abstract of a research paper. You may check if the abstract is well-written and serves as an informative and descriptive overview of the research. You may also check if it…

Centos7网络配置(设置固定ip)

文章目录 1进入虚拟机设置选中【网络适配器】选择【NAT模式】2 进入windows【控制面板\网络和 Internet\网络和共享中心\更改适配器设置】设置网络状态。3 设置VM的【虚拟网络编辑器】4 设置系统网卡5 设置虚拟机固定IP 刚安装完系统&#xff0c;有的人尤其没有勾选自动网络配置…

IOS17闪退问题Assertion failure in void _UIGraphicsBeginImageContextWithOptions

最近项目更新到最新版本IOS17&#xff0c;发现一个以前的页面突然闪退了。原来是IOS17下&#xff0c;这个方法 UIGraphicsBeginImageContext(CGSize size) 已经被移除&#xff0c;原参数如果size为0的话&#xff0c;会出现闪退现象。 根据说明&#xff0c;上述方法已经被替换…

Python + OpenCV 酷游地址教学V鄋KWK3589

本篇文章汇整了一系列的Python OpenCV 教学&#xff0c;只要按照教学文的顺序阅读和实作&#xff0c;就可以轻松入门OpenCV&#xff0c;并透过OpenCV 实现许多影像相关的创意应用。 接下来我们来介绍OpenCV-- OpenCV 是一个跨平台的电脑视觉函式库( 模组) &#xff0c;可应用…

Supabase 自托管部署实践

Supabase 是 Firebase 的开源替代品。使用 Postgres 数据库、身份验证、即时 API、边缘函数、实时订阅、存储和向量嵌入来启动您的项目。 Supabase介绍 Supabase 是一个开源的后端即服务&#xff08;BaaS&#xff09;平台&#xff0c;提供了一系列工具和服务&#xff0c;帮助…

qt中数据库和excel互导数据————附带详细步骤和代码

文章目录 0 背景1 准备QXlsx环境1.1 cmake安装使用1.2 qmake使用 2 把excel数据导出到mysql数据库3 把mysql数据库的数据写入到excel4 完整代码5 项目代码仓库 0 背景 因为需要批量导入和导出数据&#xff0c;所以需要用到excel。实现把数据库的数据导入到excel中&#xff0c;…

matrix-breakout-2-morpheus靶场

1 信息收集 1.1 主机发现 arp-scan -l 1.2 端口与服务扫描 发现开放22、80、81端口 2 访问服务 2.1 访问80端口 查看源代码 2.2 访问81端口 3 目录扫描 3.1 dirsearch目录扫描 dirsearch -u 192.168.1.14 发现robots.txt文件和javascript文件 访问文件 http://192.168…