当前位置: 首页 > news >正文

项目二十三:电阻测量(需要简单的外围检测电路,将电阻转换为电压)测量100,1k,4.7k,10k,20k的电阻阻值,由数码管显示。要求测试误差 <10%

资料查找:

01 方案选择

使用单片机测量电阻有多种方法,以下是一些常见的方法及其原理:

  1. 串联分压法(ADC)
    • 原理:根据串联电路的分压原理,通过测量已知电阻和待测电阻上的电压,计算出待测电阻的阻值。
    • 优点:电路简单,易于实现。
    • 缺点:测量精度受电源电压稳定性和电压测量精度的影响。

对于89C5x单片机一般需要外接PCF8591(A/D转换芯片)

  1. 直流电桥法
    • 原理:利用直流电桥的平衡原理,通过调节电位器使电桥平衡,从而计算出待测电阻的阻值。
    • 优点:测量精度较高。
    • 缺点:电路相对复杂,调节较为麻烦。
  2. 恒流源法
    • 原理:将恒流源施加到待测电阻上,通过测量电阻两端的电压来计算电阻值。
    • 优点:测量精度较高,不受电源电压波动的影响。
    • 缺点:需要稳定的恒流源电路,实现相对复杂。
  3. 频率法
    • 原理:利用RC振荡电路和555定时器电路,将电阻转换为频率信号,通过测量频率来计算电阻值。
    • 优点:测量速度快,适用于动态测量。
    • 缺点:测量精度受振荡电路稳定性和频率测量精度的影响。
  4. IO口测量法
    • 原理:使用单片机的IO口通过电容充电时间来测量电阻。电容充电时间与电阻成正比,通过测量充电时间来计算电阻值。
    • 优点:不需要额外的AD转换电路,利用单片机IO口即可实现。
    • 缺点:测量精度受单片机定时器精度和电容稳定性的影响。

以为大部分单片机通用,试了一下,发现STC89C52内部上拉有干扰

 

 

2 使用单片机的IO口通过电容充电时间来测量电阻

测量原理

  1. 使用两个单片机IO口,连接两个电阻,向同一个电容充电。设置一个IO口为输出端口,另一个为输入端口。
  2. 输出端口通过连接的电阻向电容充电。电容上的电压上升,当超过一定阈值,输入端口逻辑电平就会变成1。

关于阈值可以通过输入三角波得到,但是我们并不需要知道(比值可消)99126bcfc5a84b4aa57d25850d074516.png

  1. 这个充电时间与终止电压、阈值电压以及RC对应的时间常数有关系。具体数值由这个公式决定: 30fcd464644a4d1b9cb8b1ea4229dad3.png

 

 

  1. 对应的时间与R2成正比。因此,两次时间的比值,就等于电阻的比值。如果已知其中一个电阻阻值,另外一个电阻便可以根据时间比值计算出来。12

实验步骤

  1. 需要一个电容和两个电阻。电容容值为313.8nF,电阻1的阻值为19.545kΩ;电阻2的阻值为4.718kΩ。
  2. 电容一端接地,另外一端与两个电阻相连。两个电阻分别与单片机的PF0,PF1端口相连。
  3. 设置PF0为输出端口,PF1为输入端口。周期改变PF0高低电平。分别测量PF0,以及电容上的电压信号。
  4. 测量软件先将PF0,PF1输出0电平,对于电容进行放电。然后将其中一个设置为输入端口,另外一个置为高电平,对电容充电。同时启动定时器1进行计时。
  5. 在此过程中,监视输入端口逻辑电平是否为1。当输入端口变为1时,停止定时器,并读取时间。然后再进行放电,更换另外一个端口为输入端口。测试充电时间。1

实验结果

  1. 测试298个数据进行统计。数据的平均值为4.119,标准方差为0.043。测量平均值比实际电阻比值4.143小了0.6%。1

 

 

3 硬件部分

e9f4b94ced6a4c16ad5335c27db2d68c.png

 

 

 

4 软件部分

 

介绍:

STC89C52的端口P2是一个双向I/O口,每个引脚(如P2.0、P2.1等)

P0=1时为上拉输出,P0=0时为低电平输出

因此在已有上拉输入的条件下,也同样理论可行

6ac84b4801f64f76ae51e13641b7fbba.png最终按照如图思路把代码改出来了,但发现因为单片机太低级了,影响了开发效率

那就准备直接ADC写了算了

main.c

#include <reg52.h>//0.000 001 085069444444444=1
sbit  IO1 = P2^2;
sbit  IO2 = P2^3;
sbit ADDR0 = P1^0;
sbit ADDR1 = P1^1;
sbit ADDR2 = P1^2;
sbit ADDR3 = P1^3;
sbit ENLED = P1^4;void Delay_ms(int ms)	//@11.0592MHz
{unsigned char data i, j;do{i = 15;j = 90;do{while (--j);} while (--i);}while (--ms);
}unsigned char code LedChar[] = {  //数码管显示字符转换表0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8,0x80, 0x90, 0x88, 0x83, 0xC6, 0xA1, 0x86, 0x8E
};
unsigned char LedBuff[6] = {  //数码管显示缓冲区0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF
};bit StopwatchRunning = 0;  //秒表运行标志
bit StopwatchRefresh = 1;  //秒表计数刷新标志
unsigned char DecimalPart = 0;  //秒表的小数部分
unsigned int  IntegerPart = 0;  //秒表的整数部分
unsigned char T0RH = 0;  //T0重载值的高字节
unsigned char T0RL = 0;  //T0重载值的低字节
unsigned long time_R1, time_R2; // 用于存储充电时间
unsigned long Rx = 0; 
float ratio =0;
unsigned char flag1s = 0;
void ConfigTimer0(unsigned int ms);
unsigned long timer_read();
void U_Measure();
void LedScan();
void LCD_paly();
void main()
{EA = 1;      //开总中断ENLED = 0;   //使能选择数码管ADDR3 = 1;P2 = 0xFE;   //P2.0置0,选择第4行按键作为独立按键ConfigTimer0(6);  //配置T0定时2mswhile (1){U_Measure();while (1){LedScan();LCD_paly();}}
}void U_Measure()
{// 第一步:放电IO1 = 1;IO2 = 1;TR0 = 0;Delay_ms(20); // 确保电容放电干净// 第二步:测量参考电阻回路上的充电时间IO1 = 0;IO2 = 1;TR0 = 1;while(IO2<=0); // 等待充电结束time_R1 = timer_read(); // 读取计时器值// 第三步:放电IO1 = 1;IO2 = 1;TR0 = 0;Delay_ms(20); // 确保电容放电干净// 第四步:测温度电阻回路上的充电时间IO1 = 1;IO2 = 0;TR0 = 1;while(IO1<=0); // 等待充电结束time_R2 = timer_read(); // 读取计时器值// 第五步:计算电阻比率ratio = ((time_R1*10) / (time_R2*10))/10;Rx=ratio;//flag1s = 1;}
/* 配置并启动T0,ms-T0定时时间 */
void ConfigTimer0(unsigned int ms)//最大71ms
{unsigned long tmp;  //临时变量tmp = 11059200 / 12;      //定时器计数频率tmp = (tmp * ms) / 1000;  //计算所需的计数值tmp = 65536 - tmp;        //计算定时器重载值tmp = tmp + 18;           //补偿中断响应延时造成的误差(经验值)
//    T0RH = (unsigned char)(tmp>>8);  //定时器重载值拆分为高低字节
//    T0RL = (unsigned char)tmp;T0RH = 0;  //定时器重载值拆分为高低字节T0RL = 0;TMOD &= 0xF0;   //清零T0的控制位TMOD |= 0x01;   //配置T0为模式1=16位TH0 = T0RH;     //加载T0重载值TL0 = T0RL;ET0 = 1;        //使能T0中断}
/* 秒表计数显示函数 */
void LedScan()
{// flag1s = 0;   //1秒定时标志清零//以下代码将Rx按十进制位从低到高依次提取并转为数码管显示字符LedBuff[0] = LedChar[Rx%10];LedBuff[1] = LedChar[Rx/10%10];LedBuff[2] = LedChar[Rx/100%10];LedBuff[3] = LedChar[Rx/1000%10];LedBuff[4] = LedChar[Rx/10000%10];LedBuff[5] = LedChar[Rx/100000%10];}
void LCD_paly()
{static signed char i;P0 = 0xFF;   //显示消隐switch (i){case 0: ADDR2=0; ADDR1=0; ADDR0=0; i++; P0=LedBuff[0]; break;case 1: ADDR2=0; ADDR1=0; ADDR0=1; i++; P0=LedBuff[1]; break;case 2: ADDR2=0; ADDR1=1; ADDR0=0; i++; P0=LedBuff[2]; break;case 3: ADDR2=0; ADDR1=1; ADDR0=1; i++; P0=LedBuff[3]; break;case 4: ADDR2=1; ADDR1=0; ADDR0=0; i++; P0=LedBuff[4]; break;case 5: ADDR2=1; ADDR1=0; ADDR0=1; i=0; P0=LedBuff[5]; break;default: break;}}/* 定时停止函数 */
unsigned long timer_read()
{unsigned long tmp1 =0;TR0 = 0;      tmp1 =  (unsigned char)((TH0-T0RH)<<8)|(unsigned char)(TL0-T0RL);  //定时器重载值拆分为高低字节TH0 = T0RH;  //重新加载重载值TL0 = T0RL;return tmp1;
}/* T0中断服务函数,完成数码管、按键扫描与秒表计数 */
void InterruptTimer0() interrupt 1
{TH0 = T0RH;  //重新加载重载值TL0 = T0RL;	 
//  LedScan();   //数码管扫描显示}

 

02 使用方法——串联分压法(ADC)测电阻

 完整工程代码部分,待课设结束再公开

 如果需要技术支持可以加我的QQ交流:

27969203789

02 实验现象

0c9a2302e6cb4fcead1f7888bd76e76b.png

 

03 硬件部分

金沙滩51单片机+需要测量相近的电阻

 

04 软件部分

核心部分:

val = (GetADCValue(0)*2.5);   //获取ADC通道0的转换值  电压值=转换结果*2.48V/255,式中的25隐含了一位十进制小数
Rx=(val/(6375-val))*R1;

 

XX 拓展资料(收集资料仅供参考):

虽然STC89C52无法配置上下拉操作,但是一般现代翻新的芯片都可以配置,至于配置方法可能类似如下:

 0b066ca1783342cd97054dcc4d8737eb.png818f3de66bbe43e6964c653b5b169223.png

例如:

有些单片机的端口P2的输入和输出模式通过配置端口的P2M0P2M1寄存器来控制。P2M0和P2M1分别是P2端口的输入/输出模式控制寄存器。

 

关于P2M1 和 P2M0 寄存器介绍:

P2M1 和 P2M0 寄存器是常见的微控制器(例如 51 系列单片机)中的特定控制寄存器,用于设置端口(特别是端口 2)的功能模式。

通常在 51 系列单片机中,P2M1 和 P2M0 寄存器用于控制端口 2 的工作模式(例如是否作为 I/O 端口,或者是否用于特殊功能)。

1. P2M1 寄存器:

P2M1 寄存器的位数通常是 8 位,每一位对应于端口 2 的各个引脚的模式。具体来说,P2M1 中的每一位控制端口 2 的每一个引脚的工作方式。

  • 位 7 (P2.7):

    • 0: 作为 I/O 端口;
    • 1: 用于特殊功能。
  • 位 6 (P2.6)

    • 0: 作为 I/O 端口;
    • 1: 用于特殊功能。
  • 依此类推,P2M1 的每一位控制对应的端口引脚的模式。

2. P2M0 寄存器:

P2M0 寄存器也是 8 位,与 P2M1 配合使用,进一步控制端口 2 的引脚模式。它的每一位也用于设置端口 2 上每个引脚的功能模式。例如:

  • 位 7 (P2.7):可以通过设置此位来选择端口引脚的功能(是 I/O,还是其他功能)。
  • 位 6 (P2.6):控制端口引脚的工作模式。

P2M1 和 P2M0 的配合:

P2M1 和 P2M0 配合使用,通常具有以下几个常见的工作模式(以位 P2.x 为例):

  • 00:作为普通的数字 I/O 端口;
  • 01:用于某些特定的功能,如外部中断等;
  • 10:用于其他一些特殊功能,例如定时器、串口等;
  • 11:也可以用于其他特定功能模式。

总结:

  • P2M1 和 P2M0 寄存器通常是 8 位,每一位对应端口 2 上的一个引脚(P2.0 到 P2.7)的功能控制。
  • 每一位设置为 0 或 1,控制对应引脚是作为 I/O 端口,还是用于特定的功能模式

 

P2 引脚P2M1P2M0描述
P2.x00普通输入(无上下拉电阻)
P2.x01带下拉电阻输入模式(低电平有效)
P2.x10推挽输出模式
P2.x11开漏输出模式

一般高级的51单片机的寄存器操作,可以通过P2M1和P2M0的配置来控制P2口的工作模式

配置P2.0为下拉输入模式。我们清除P2M1的对应位(即 P2M1 &= 0xFE),然后设置P2M0的对应位(即 P2M0 |= 0x01)来启用下拉电阻。

配置P2.0为推挽输出模式。我们设置P2M1的对应位(即 P2M1 |= 0x01)并清除P2M0的对应位(即 P2M0 &= 0xFE


int IN1(void)
{
// 设置P2.0为下拉输入模式P2M1 &= 0xFE;   // P2M1位为0P2M0 |= 0x01;   // 设置P2M0位为1,启用下拉输入模式}int IN2(void)
{
// 设置P2.0为下拉输入模式P2M1 &= 0xFD;   // P2M1位为0P2M0 |= 0x02;   // 设置P2M0位为1,启用下拉输入模式}void ON1(void)
{// 设置P2.0为推挽输出模式P2M1 |= 0x01;   // 设置P2M1位为1P2M0 &= 0xFE;   // 设置P2M0位为0,设置为推挽输出模式
}void ON2(void)
{// 设置P2.0为推挽输出模式P2M1 |= 0x02;   // 设置P2M1位为1P2M0 &= 0xFD;   // 设置P2M0位为0,设置为推挽输出模式
}

 

 

相关文章:

项目二十三:电阻测量(需要简单的外围检测电路,将电阻转换为电压)测量100,1k,4.7k,10k,20k的电阻阻值,由数码管显示。要求测试误差 <10%

资料查找&#xff1a; 01 方案选择 使用单片机测量电阻有多种方法&#xff0c;以下是一些常见的方法及其原理&#xff1a; 串联分压法&#xff08;ADC&#xff09; 原理&#xff1a;根据串联电路的分压原理&#xff0c;通过测量已知电阻和待测电阻上的电压&#xff0c;计算出…...

【NLP 17、NLP的基础——分词】

我始终相信&#xff0c;世间所有的安排都有它的道理&#xff1b;失之东隅&#xff0c;收之桑榆 —— 24.12.20 一、中文分词的介绍 1.为什么讲分词&#xff1f; ① 分词是一个被长期研究的任务&#xff0c;通过了解分词算法的发展&#xff0c;可以看到NLP的研究历程 ② 分词…...

uniapp blob格式转换为video .mp4文件使用ffmpeg工具

前言 介绍一下这三种对象使用场景 您前端一旦涉及到文件或图片上传Q到服务器&#xff0c;就势必离不了 Blob/File /base64 三种主流的类型它们之间 互转 也成了常态 Blob - FileBlob -Base64Base64 - BlobFile-Base64Base64 _ File uniapp 上传文件 现在已获取到了blob格式的…...

【无标题】 [蓝桥杯 2024 省 B] 好数

[蓝桥杯 2024 省 B] 好数 好数 一个整数如果按从低位到高位的顺序&#xff0c;奇数位&#xff08;个位、百位、万位……&#xff09;上的数字是奇数&#xff0c;偶数位&#xff08;十位、千位、十万位……&#xff09;上的数字是偶数&#xff0c;我们就称之为“好数”。 给定一…...

Leecode刷题C语言之同位字符串连接的最小长度

执行结果:通过 执行用时和内存消耗如下&#xff1a; bool check(char *s, int m) {int n strlen(s), count0[26] {0};for (int j 0; j < n; j m) {int count1[26] {0};for (int k j; k < j m; k) {count1[s[k] - a];}if (j > 0 && memcmp(count0, cou…...

Pytorch | 利用BIM/I-FGSM针对CIFAR10上的ResNet分类器进行对抗攻击

Pytorch | 利用BIM/I-FGSM针对CIFAR10上的ResNet分类器进行对抗攻击 CIFAR数据集BIM介绍基本原理算法流程特点应用场景 BIM代码实现BIM算法实现攻击效果 代码汇总bim.pytrain.pyadvtest.py 之前已经针对CIFAR10训练了多种分类器&#xff1a; Pytorch | 从零构建AlexNet对CIFAR1…...

音频进阶学习八——傅里叶变换的介绍

文章目录 前言一、傅里叶变换1.傅里叶变换的发展2.常见的傅里叶变换3.频域 二、欧拉公式1.实数、虚数、复数2.对虚数和复数的理解3.复平面4.复数和三角函数5.复数的运算6.欧拉公式 三、积分运算1.定积分2.不定积分3.基本的积分公式4.积分规则线性替换法分部积分法 5.定积分计算…...

将4G太阳能无线监控的视频接入电子监控大屏,要考虑哪些方面?

随着科技的飞速发展&#xff0c;4G太阳能无线监控系统以其独特的优势在远程监控领域脱颖而出。这种系统结合了太阳能供电的环保特性和4G无线传输的便捷性&#xff0c;为各种环境尤其是无电或电网不稳定的地区提供了一种高效、可靠的视频监控解决方案。将这些视频流接入大屏显示…...

使用docker拉取镜像很慢或者总是超时的问题

在拉取镜像的时候比如说mysql镜像&#xff0c;在拉取 时总是失败&#xff1a; 像这种就是网络的原因&#xff0c;因为你是连接到了外网去进行下载的&#xff0c;这个时候可以添加你的访问镜像源。也就是daemon.json文件&#xff0c;如果你没有这个文件可以输入 vim /etc/dock…...

Redis数据库笔记

Spring cache 缓存的介绍 在springboot中如何使用redis的缓存 1、使用Cacheable的例子【一般都是在查询的方法上】 /*** 移动端的套餐查询* value 就是缓存的名称* key 就是缓存id &#xff0c;就是一个缓存名称下有多个缓存&#xff0c;根据id来区分* 这个id一般就是多个查询…...

U盘出现USBC乱码文件的全面解析与恢复指南

一、乱码现象初探&#xff1a;USBC乱码文件的神秘面纱 在数字时代&#xff0c;U盘已成为我们日常生活中不可或缺的数据存储工具。然而&#xff0c;当U盘中的文件突然变成乱码&#xff0c;且文件名前缀显示为“USBC”时&#xff0c;这无疑给用户带来了极大的困扰。这些乱码文件…...

多线程 - 自旋锁

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 多线程 - 自旋锁 收录于专栏[Linux学习] 本专栏旨在分享学习Linux的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 概述 原理 优点与…...

vue2 - Day02 -计算属性(computed)、侦听器(watch)和方法(methods)

在 Vue.js 中&#xff0c;计算属性&#xff08;computed&#xff09;、侦听器&#xff08;watch&#xff09;和方法&#xff08;methods&#xff09;都是响应式的数据处理方式 文章目录 1. 方法&#xff08;Methods&#xff09;1.1. 是什么1.2. 怎么用示例&#xff1a; 1.3. 特…...

Linux C 程序 【05】异步写文件

1.开发背景 Linux 系统提供了各种外设的控制方式&#xff0c;其中包括文件的读写&#xff0c;存储文件的介质可以是 SSD 固态硬盘或者是 EMMC 等。 其中常用的写文件方式是同步写操作&#xff0c;但是如果是写大文件会对 CPU 造成比较大的负荷&#xff0c;采用异步写的方式比较…...

Liveweb视频汇聚平台支持WebRTC协议赋能H.265视频流畅传输

随着科技的飞速发展和网络技术的不断革新&#xff0c;视频监控已经广泛应用于社会各个领域&#xff0c;成为现代安全管理的重要组成部分。在视频监控领域&#xff0c;视频编码技术的选择尤为重要&#xff0c;它不仅关系到视频的质量&#xff0c;还直接影响到视频的传输效率和兼…...

SQL组合查询

本文讲述如何利用 UNION 操作符将多条 SELECT 语句组合成一个结果集。 1. 组合查询 多数 SQL 查询只包含从一个或多个表中返回数据的单条 SELECT 语句。但是&#xff0c;SQL 也允许执行多个查询&#xff08;多条 SELECT 语句&#xff09;&#xff0c;并将结果作为一个查询结果…...

方正畅享全媒体新闻采编系统 screen.do SQL注入漏洞复现

0x01 产品简介 方正畅享全媒体新闻生产系统是以内容资产为核心的智能化融合媒体业务平台,融合了报、网、端、微、自媒体分发平台等全渠道内容。该平台由协调指挥调度、数据资源聚合、融合生产、全渠道发布、智能传播分析、融合考核等多个平台组成,贯穿新闻生产策、采、编、发…...

【机器学习】【集成学习——决策树、随机森林】从零起步:掌握决策树、随机森林与GBDT的机器学习之旅

这里写目录标题 一、引言机器学习中集成学习的重要性 二、决策树 (Decision Tree)2.1 基本概念2.2 组成元素2.3 工作原理分裂准则 2.4 决策树的构建过程2.5 决策树的优缺点&#xff08;1&#xff09;决策树的优点&#xff08;2&#xff09;决策树的缺点&#xff08;3&#xff0…...

Flink执行模式(批和流)如何选择

DataStream API支持不同的运行时执行模式(batch/streaming),你可以根据自己的需求选择对应模式。 DataStream API的默认执行模式就是streaming,用于需要连续增量处理并且预计会一直保持在线的无界(数据源输入是无限的)作业。 而batch执行模式则用于有界(输入有限)作业…...

LeetCode:101. 对称二叉树

跟着carl学算法&#xff0c;本系列博客仅做个人记录&#xff0c;建议大家都去看carl本人的博客&#xff0c;写的真的很好的&#xff01; 代码随想录 LeetCode&#xff1a;101. 对称二叉树 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输…...

多模态2025:技术路线“神仙打架”,视频生成冲上云霄

文&#xff5c;魏琳华 编&#xff5c;王一粟 一场大会&#xff0c;聚集了中国多模态大模型的“半壁江山”。 智源大会2025为期两天的论坛中&#xff0c;汇集了学界、创业公司和大厂等三方的热门选手&#xff0c;关于多模态的集中讨论达到了前所未有的热度。其中&#xff0c;…...

【网络安全产品大调研系列】2. 体验漏洞扫描

前言 2023 年漏洞扫描服务市场规模预计为 3.06&#xff08;十亿美元&#xff09;。漏洞扫描服务市场行业预计将从 2024 年的 3.48&#xff08;十亿美元&#xff09;增长到 2032 年的 9.54&#xff08;十亿美元&#xff09;。预测期内漏洞扫描服务市场 CAGR&#xff08;增长率&…...

【JVM】- 内存结构

引言 JVM&#xff1a;Java Virtual Machine 定义&#xff1a;Java虚拟机&#xff0c;Java二进制字节码的运行环境好处&#xff1a; 一次编写&#xff0c;到处运行自动内存管理&#xff0c;垃圾回收的功能数组下标越界检查&#xff08;会抛异常&#xff0c;不会覆盖到其他代码…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted&#xff08;&#xff09;是OpenCV库中用于图像处理的函数&#xff0c;主要功能是将两个输入图像&#xff08;尺寸和类型相同&#xff09;按照指定的权重进行加权叠加&#xff08;图像融合&#xff09;&#xff0c;并添加一个标量值&#x…...

基于当前项目通过npm包形式暴露公共组件

1.package.sjon文件配置 其中xh-flowable就是暴露出去的npm包名 2.创建tpyes文件夹&#xff0c;并新增内容 3.创建package文件夹...

【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)

骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术&#xff0c;它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton)&#xff1a;由层级结构的骨头组成&#xff0c;类似于人体骨骼蒙皮 (Mesh Skinning)&#xff1a;将模型网格顶点绑定到骨骼上&#xff0c;使骨骼移动…...

tree 树组件大数据卡顿问题优化

问题背景 项目中有用到树组件用来做文件目录&#xff0c;但是由于这个树组件的节点越来越多&#xff0c;导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多&#xff0c;导致的浏览器卡顿&#xff0c;这里很明显就需要用到虚拟列表的技术&…...

Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)

目录 一、&#x1f44b;&#x1f3fb;前言 二、&#x1f608;sinx波动的基本原理 三、&#x1f608;波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、&#x1f30a;波动优化…...

并发编程 - go版

1.并发编程基础概念 进程和线程 A. 进程是程序在操作系统中的一次执行过程&#xff0c;系统进行资源分配和调度的一个独立单位。B. 线程是进程的一个执行实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。C.一个进程可以创建和撤销多个线程;同一个进程中…...

【LeetCode】3309. 连接二进制表示可形成的最大数值(递归|回溯|位运算)

LeetCode 3309. 连接二进制表示可形成的最大数值&#xff08;中等&#xff09; 题目描述解题思路Java代码 题目描述 题目链接&#xff1a;LeetCode 3309. 连接二进制表示可形成的最大数值&#xff08;中等&#xff09; 给你一个长度为 3 的整数数组 nums。 现以某种顺序 连接…...