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

【C语言】17. 数据在内存中的存储

文章目录

  • 一、整数在内存中的存储
  • 二、⼤⼩端字节序和字节序判断
    • 1、什么是⼤⼩端?
    • 2、为什么有⼤⼩端?
    • 3、练习
      • 1)练习1
      • 2)练习2
      • 3)练习3
      • 4)练习4
      • 5) 练习5
      • 6)练习6
  • 三、浮点数在内存中的存储
    • 1、浮点数的存储
      • 1)浮点数存的过程
      • 2)浮点数取的过程
    • 2、题⽬解析

一、整数在内存中的存储

在讲解操作符的时候,我们就讲过了下⾯的内容:
整数的2进制表⽰⽅法有三种,即原码、反码和补码
有符号的整数,三种表⽰⽅法均有符号位和数值位两部分,符号位都是⽤0表⽰“正”,⽤1表
⽰“负”,最⾼位的⼀位是被当做符号位,剩余的都是数值位。

正整数的原、反、补码都相同。

负整数的三种表⽰⽅法各不相同:
原码:直接翻译成⼆进制
反码:原码符号位不变,其他取反
补码:反码+1

对于整形来说:数据存放内存中其实存放的是补码。
为什么呢?在计算机系统中,数值⼀律⽤补码来表⽰和存储。

原因在于:
使⽤补码,可以将符号位和数值域统⼀处理。
同时,加法和减法也可以统⼀处理(CPU只有加法器)此外,补码与原码相互转换,其运算过程是
相同的,不需要额外的硬件电路。

二、⼤⼩端字节序和字节序判断

当我们了解了整数在内存中存储后,我们调试看⼀个细节:

#include <stdio.h>int main()
{int a = 0x11223344;//0x是十六进制,11 22 33 44是四个字节,共同组成了一个内存单元,也就是一个整型举例:1return 0;
}

调试的时候,我们可以看到在a中的 0x11223344 这个数字是按照字节为单位,倒着存储的。这是为
什么呢?
在这里插入图片描述
在这里有些额外知识需要注意:

1.整数在内存中存储的是二进制的补码
2.在调试窗口中观察内存的时候,为了方便展示,显示的是16进制的值
3.存储的顺序是倒过来的!

1、什么是⼤⼩端?

其实超过⼀个字节的数据在内存中存储的时候,就有存储顺序的问题,按照不同的存储顺序,我们分为⼤端字节序存储和⼩端字节序存储,下⾯是具体的概念:

首先在整数123中,3就被叫做个位也就是低位
同理在内存中:
0x11223344   右边的字节就是低位11 22 33 44
低地址  高地址   大端字节序存储
大端字节序存储:把一个数据的低位字节的内容存储到高地址处,把高位字节的内容存储到低地址处(按顺序)44 33 22 11
低地址  高地址   小端字节序存储
小端字节序存储:把一个数据的低位字节的内容存储到低地址处,把高位字节的内容存储到高地址处(倒反天罡)

我们可以设计一个小程序来判断当前机器的字节序:

0x 00 00 00 01 这是整数1的十六进制
我们可以观察其内存来验证:
01 00 00 00 (反) 小端字节序
00 00 00 01 大端字节序

int main()
{int n = 1;if (*(char*) &n == 1)printf("小端\n");elseprintf("大端\n");return 0;
}

在这里插入图片描述
运行结果是小端 说明计算机中储存1的内存是01 00 00 00

2、为什么有⼤⼩端?

为什么会有⼤⼩端模式之分呢?

这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着⼀个字节,⼀个字节为8bit位,但是在C语⾔中除了8 bit的 char之外,还有16 bit的 short型,32 bit的 long 型(要看具体的编译器),另外,对于位数⼤于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度⼤于⼀个字节,那么必然存在着⼀个如何将多个字节安排的问题。因此就导致了⼤端存储模式和⼩端存储模式。

例如:⼀个 16 bit 的 short 型 x ,在内存中的地址为 0x0010 , x 的值为 0x1122 ,那么0x11 为⾼字节, 0x22 为低字节。对于⼤端模式,就将 0x11 放在低地址中,即 0x0010 中,0x22 放在⾼地址中,即 0x0011 中。⼩端模式,刚好相反。我们常⽤的 X86 结构是⼩端模式

3、练习

1)练习1

请简述⼤端字节序和⼩端字节序的概念,设计⼀个⼩程序来判断当前机器的字节序。(10分)-百度笔
试题

//代码1 #include <stdio.h>int check_sys()
{int n = 1;/*if (*(char*)&n == 1)return 1;elsereturn 0;*/return *(char*)&n;
}
int main()
{int ret = check_sys();if (ret == 1)printf("小端\n");elseprintf("大端\n");return 0;
}

在练习下面知识前,我们需要补充一点知识:

 signed  char a;  有符号的                      
unsigned char b;  无符号的
char - 1个字节 - 8bit位
如果是signed char类型,那么内存中的最高位就被当作符号位00000000 000000001 1
正数   00000010 2     这些存的字节都是补码,正数原反补相同00000011 3                  00000100 400000101 5...01111111 127100000000 11111111 10000000 -12810000001 11111110 11111111 -127         负数的补码取反+1变成原码负数     ...11111110 10000001 10000010 -211111111 10000000 10000001 -1补      取反      原signed  char类型的取值范围是:-128~127unsigned char的内存:不看符号位,当成数计算,都是正的,正数的原反补都是相同的
00000000 0
00000001 1
00000010 2
00000011 3
00000100 4
...
01111111 127
10000000 128
10000001 129
...
11111110 254
11111111 255
unsigned char的取值范围是0~255char 到底是有符号的char 还是无符号的char是取决于编译器的!
在vs上char==signed char

2)练习2

#include <stdio.h>int main()
{char a = -1;signed char b = -1;unsigned char c = -1;printf("a=%d,b=%d,c=%d", a, b, c);return 0;
}

运行结果:
在这里插入图片描述

解析:

    int main()
{char a = -1;//这是将-1的值赋值给char类型的a//100000000000000000000000000000000001 -1的原码//111111111111111111111111111111111110//111111111111111111111111111111111111 -1的补码//11111111-a  char类型只要补码中的8个bit位//111111111111111111111111111111111111 signed类型整型提升补1,这是补码//100000000000000000000000000000000001  取反+1得到原码(-1)signed char b = -1;//同理也是-1unsigned char c = -1;//11111111-c也是同样的8个bit位//000000000000000000000000000011111111 unsigned类型整型提升补0//无符号就是正数,原反补相同,也就是255printf("a=%d,b=%d,c=%d", a, b, c);//%d意味着要整型提升return 0;
}

3)练习3

#include <stdio.h>int main()
{char a = -128;printf("%u\n",a);return 0;
}
#include <stdio.h>int main()
{char a = 128;printf("%u\n", a);return 0;
}

在这里插入图片描述

解析:

int main()
{char a = 128;//128的原码 000000000000000000000000000010000000//正数原反补相同//char类型取8bit位 10000000//整型提升:111111111111111111111111111110000000-补//无符号原反补相同,和上面一样,原码值也一样很大printf("%u\n", a);//%u当成无符号return 0;
}

如果%u改成%d就是有符号的,计算结果就会不一样了

int main()
{char c = -128;printf("%d\n", c);//-128,%d是看成有符号的return 0;
}

在这里插入图片描述

4)练习4

#include <stdio.h>int main()
{char a[1000]://0~999,signed char类型存放数据的范围是-128~127int i = 0;for (i = 0; i < 1000; i++){a[i] = -1 - i;//-1-i依次赋值给a[i]}//-1 -2 -3 -4...-127 -128 127 126 ... 4 3 2 1 0 -1 -2...printf("%zd", strlen(a));//求的是字符串的长度,统计的是\0(ASCII码值是0)之前的字符个数//255return 0;
}

5) 练习5

#include <stdio.h>unsigned char i = 0;
//unsigned char 的取值范围是0~255,可以看成一个圈,不会出现这个范围外的数字,unsigned是无符号的
int main()
{for (i = 0; i <= 255; i++)//这里的判断条件是<=255是恒成立,就会无限循环打印{printf("hello world\n");}return 0;
}
#include <stdio.h>
#include<windows.h>int main()
{unsigned int i;//无符号说明恒>=0for (i = 9; i >= 0; i--)//判断条件恒满足,死循环{printf("%u\n", i);Sleep(1000);//逐步执行代码}return 0;
}

6)练习6

#include <stdio.h>//X86环境 小端字节序 
int main()
{int a[4] = { 1,2,3,4 };int* ptr1 = (int*)(&a + 1);//&a的类型是int(*)[4],int*强制类型转换说明&a+1之后变为了整型指针ptr1,只能变换一个整型int* ptr2 = (int*)((int)a + 1);//int强制类型转换a为整型,+1就只能变换一个字节,int*强制类型转换为指针ptr2,也只能变换一个整型printf("%x,%x", ptr1[-1], *ptr2);return 0;
}

解析:

                ptr1&a           &a+1+            +1   2   3    4
ptr1[-1]=*(ptr1-1)//ptr1向前移动一个字节 就是4(int)a说明a只能变换一个字节了,+1是向后跳一个字节a:01 00 00 00   02 00 00 00   03 00 00 00   04 00 00 00+           +
跳过一个字节后的整型就是00 00 00 02
按照小端字节序,那么内存中应该是 02 00 00 00

三、浮点数在内存中的存储

常⻅的浮点数:3.14159、1E10等,浮点数家族包括: float、double、long double 类型。
浮点数表⽰的范围: float.h 中定义
整数的取值范围:limits.h

练习:

#include <stdio.h>int main()
{int n = 9;float* pFloat = (float*)&n;//将n的地址赋值给指针变量pFLoatprintf("n的值为:%d\n", n);//9printf("*pFloat的值为:%f\n", *pFloat);//0.000000*pFloat = 9.0;printf("num的值为:%d\n", n);//1091567616printf("*pFloat的值为:%f\n", *pFloat);//9.000000return 0;
}

运行结果:
在这里插入图片描述
说明:整数和浮点数在内存中的存储方式是有不一样的,就像不同国家对同一个东西的理解不同

1、浮点数的存储

上⾯的代码中, num 和 *pFloat 在内存中明明是同⼀个数,为什么浮点数和整数的解读结果会差别这么⼤?
要理解这个结果,⼀定要搞懂浮点数在计算机内部的表⽰⽅法。
根据国际标准IEEE(电⽓和电⼦⼯程协会)754,任意⼀个⼆进制浮点数V可以表⽰成下⾯的形式:
V = (−1)S * M * 2E

•(−1)S表⽰符号位,当S=0,V为正数;当S=1,V为负数

• M表⽰有效数字,M大于等于1,小于2

• 2E表⽰指数位

举例来说:
⼗进制的5.0,写成⼆进制是 101.0 ,相当于 1.01×22

那么,按照上⾯V的格式,可以得出S=0,M=1.01,E=2。
⼗进制的-5.0,写成⼆进制是 -101.0 ,相当于 -1.01×22 。那么,S=1,M=1.01,E=2。

IEEE 754规定:
对于32位的浮点数,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M
对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M
在这里插入图片描述
在这里插入图片描述

1)浮点数存的过程

IEEE 754对有效数字M和指数E,还有⼀些特别规定。
前⾯说过, 1≤M<2 ,也就是说,M可以写成 1.xxxxxx 的形式,其中xxxxxx 表⽰⼩数部分。
IEEE 754规定,在计算机内部保存M时,默认这个数的第⼀位总是1,因此可以被舍去,只保存后⾯的xxxxxx部分。⽐如保存1.01的时候,只保存01,等到读取的时候,再把第⼀位的1加上去。这样做的⽬的,是节省1位有效数字。以32位浮点数为例,留给M只有23位,将第⼀位的1舍去以后,等于可以保存24位有效数字。

⾄于指数E,情况就⽐较复杂
⾸先,E为⼀个⽆符号整数(unsigned int)

这意味着,如果E为8位,它的取值范围为0 ~ 255;如果E为11位,它的取值范围为0~2047。但是,我们知道,科学计数法中的E是可以出现负数的,所以IEEE 754规定,存⼊内存时E的真实值必须再加上⼀个中间数,对于8位的E,这个中间数是127;对于11位的E,这个中间数是1023。⽐如,210的E是10,所以保存成32位浮点数时,必须保存成10+127=137,即10001001。

2)浮点数取的过程

指数E从内存中取出还可以再分成三种情况:
E不全为0或不全为1

这时,浮点数就采⽤下⾯的规则表⽰,即指数E的计算值减去127(或1023),得到真实值,再将有效
数字M前加上第⼀位的1。
⽐如:0.5的⼆进制形式为0.1,由于规定正数部分必须为1,即将⼩数点右移1位,则为1.0*2(-1),其
阶码为-1+127(中间值)=126,表⽰为01111110,⽽尾数1.0去掉整数部分为0,补⻬0到23位
00000000000000000000000,则其⼆进制表⽰形式为:

0 01111110 00000000000000000000000

E全为0:
说明E+127==0 所以E=-127,则原值是一个非常小的数字,这时E等于1-127=-126或者 1-1023=-1022,表示±0

0 00000000 00100000000000000000000

E全为1:
则E+127=255,说明E=128,表示±无穷大;

0 11111111 00010000000000000000000

2、题⽬解析

下⾯,让我们回到⼀开始的练习
先看第1环节,为什么 9 还原成浮点数,就成了0.000000 ?
9以整型的形式存储在内存中,得到如下⼆进制序列:

0000 0000 0000 0000 0000 0000 0000 1001

⾸先,将 9 的⼆进制序列按照浮点数的形式拆分,得到第⼀位符号位s=0,后⾯8位的指数E=00000000 ,
最后23位的有效数字M=00000000000000000001001。
由于指数E全为0,所以符合E为全0的情况。因此,浮点数V就写成:
V=(-1)0 × 0.00000000000000000001001×2(-126)=1.001×2(-146)

显然,V是⼀个很⼩的接近于0的正数,所以⽤⼗进制⼩数表⽰就是0.000000。

再看第2环节,浮点数9.0,为什么整数打印是 1091567616
⾸先,浮点数9.0等于⼆进制的1001.0,即换算成科学计数法是:1.001×23
所以:9.0 = (−1)0 *(1.001)*23

那么,第⼀位的符号位S=0,有效数字M等于001后⾯再加20个0,凑满23位,指数E等于3+127=130,
即10000010
所以,写成⼆进制形式,应该是S+E+M,即

0 10000010 001 0000 0000 0000 0000 0000

这个32位的⼆进制数,被当做整数来解析的时候,就是整数在内存中的补码,原码正是1091567616 。

解析:
在这里插入图片描述

相关文章:

【C语言】17. 数据在内存中的存储

文章目录 一、整数在内存中的存储二、⼤⼩端字节序和字节序判断1、什么是⼤⼩端&#xff1f;2、为什么有⼤⼩端?3、练习1&#xff09;练习12&#xff09;练习23&#xff09;练习34&#xff09;练习45&#xff09; 练习56&#xff09;练习6 三、浮点数在内存中的存储1、浮点数的…...

二叉树概述

目录 一、二叉树的基本结构 二、二叉树的遍历 1.前序 2.中序 3.后序 4.层序遍历 三.计算二叉树的相关参数 1.计算节点总个数 2.计算叶子节点的个数 3.计算树的高度 4.计算第k层的子树个数 5.查找树中val为x的节点 四.刷题 1.单值二叉树 2.检查两棵树是否相同 3.一…...

【开源免费】基于SpringBoot+Vue.JS图书进销存管理系统(JAVA毕业设计)

博主说明&#xff1a;本文项目编号 T 082 &#xff0c;文末自助获取源码 \color{red}{T082&#xff0c;文末自助获取源码} T082&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…...

惠普M126a连接共享打印机故障0x000006ba,系统不支持请求的命令,print spooler重复停止

故障说明&#xff1a;直连惠普M126a打印机正常打印&#xff0c;通过共享连接的报故障。 目前已知有三种故障&#xff1a; 1、0x000006ba报错2、系统不支持请求的命令3、print spooler重复停止&#xff08;或者&#xff0c;print spooler没有停止依然报故障&#xff09; 解决方…...

Chainlit集成LlamaIndex实现一个通过用户聊天对话的酒店预定系统

Agent 简介 “Agent”是一个自动推理和决策引擎。它接受用户输入/查询,并为执行该查询做出内部决策,以便返回正确的结果。关键的代理组件可以包括但不限于: 把复杂的问题分解成小问题选择要使用的外部工具+调用工具的参数计划一系列的任务将以前完成的任务存储在内存模块中…...

计算机网络之网络层超详细讲解

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 计算机网络之网络层超详细讲解 收录于专栏【计算机网络】 本专栏旨在分享学习计算机网络的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; …...

代码随想录算法训练营day51|动态规划part13

回文子串 回文子串这里的递推式不太一样&#xff0c;dp[i] 和 dp[i-1] &#xff0c;dp[i 1] 看上去都没啥关系。所以要回归到回文的定义 而我们发现&#xff0c;判断一个子字符串&#xff08;字符串下标范围[i,j]&#xff09;是否回文&#xff0c;依赖于&#xff0c;子字符串…...

ESP8266自制桌宠机器狗

看到别人的桌宠机器狗有没有想要拥有一台的冲动,其实我们可以使用少量的资金自制一台机器狗 1 硬件 esp8266芯片 舵机 超声波传感器 2 接线 ESP8266配件...

【力扣】409.最长回文串

问题描述 思路解析 因为同时包含大小写字母&#xff0c;直接创建个ASCII表大小的桶来标记又因为是要回文子串&#xff0c;所以偶数个数的一定可以那么同时&#xff0c;对于出现奇数次数的&#xff0c;我没需要他们的次数-1&#xff0c;变为偶数&#xff0c;并且可以标记出现过…...

git 拉取代码时报错 gitignore Please move or remove them before you merge.

git 拉取代码时报错&#xff0c; The following untracked working tree files would be overwritten by merge: .gitignore Please move or remove them before you merge. 当你在使用 Git 进行代码拉取&#xff08;通常是执行 git pull 或 git merge 命令&#xff09;时遇到这…...

19,[极客大挑战 2019]PHP1

这个好玩 看到备份网站字眼&#xff0c;用dirsearch扫描 在kali里打开 爆破出一个www.zip文件 访问一下 解压后是这个页面 class.php <?php include flag.php; error_reporting(0); class Name{ private $username nonono; private $password yesyes; publi…...

MQTT消息服务器mosquitto介绍及说明

Mosquitto是一个开源的消息代理软件&#xff0c;支持MQTT协议&#xff08;消息队列遥测传输协议&#xff09;。MQTT是一种轻量级的发布/订阅消息传输协议&#xff0c;专为低带宽、不可靠网络环境下的物联网设备通信而设计。以下是关于Mosquitto服务器的一些介绍和说明&#xff…...

uniapp结合movable-area与movable-view实现拖拽功能

前言 因为公司业务开发需要拖拽功能。 ps&#xff1a;该功能只能针对高度一致的&#xff0c;如果高度不一致需要另外二开 演示 开始 <template><view style"height: 100%;"><movable-area :style"{width: 100%, height: allHeight px}"…...

十九(GIT2)、token、黑马就业数据平台(页面访问控制(token)、首页统计数据、登录状态失效)、axios请求及响应拦截器、Git远程仓库

1. JWT介绍 JSON Web Token 是目前最为流行的跨域认证解决方案&#xff0c;本质就是一个包含信息的字符串。 如何获取&#xff1a;在使用 JWT 身份验证中&#xff0c;当用户使用其凭据成功登录时&#xff0c;将返回 JSON Web Token&#xff08;令牌&#xff09;。 作用&#xf…...

文生图模型开源之光!ComfyUI - AuraFlow本地部署教程

一、模型介绍 AuraFlow 是唯一一个真正开源的文生图模型&#xff0c;由Fal团队开源&#xff0c;其代码和权重都放在了 FOSS 许可证下。基于 6.8B 参数优化模型架构&#xff0c;采用最大更新参数化技术&#xff0c;还重新标注数据集提升指令遵循质量。在物体空间和色彩上有优势…...

spring boot之@Import注解的应用

我们知道spring boot会通过ComponentScan定义包扫描路径进行业务定义的bean的加载&#xff0c;但是对于很多不在此包路径下定义的bean怎么办呢&#xff1f;比如其他jar包中定义的。这时候import就发挥作用了&#xff0c;通过它也可以实现bean的定义。具体是怎么做的呢&#xff…...

【记录】用JUnit 4的@Test注解时报错java.lang.NullPointerException的原因与解决方法

项目场景&#xff1a; 在练习黑马点评的逻辑过期解决缓存击穿时&#xff0c;编写了一个预热缓存数据的单元测试 SpringBootTest public class HmDianPingApplicationTests {Resourceprivate ShopServiceImpl shopService;Testpublic void testSaveShop() throws InterruptedE…...

Spring Boot 自动化脚本-多线程批量压缩图片

Spring Boot 自动化脚本-多线程批量压缩图片 支持多线程支持多路径配置支持断点续压支持压缩后文件层级路径不变脚本一键启动&#xff0c;支持本地 main 调用或远程 POST 接口调用 背景&#xff1a;在进行数据迁移时&#xff0c;发现附件文件夹过于庞大&#xff0c;且大都为图…...

依托 Spring Boot框架,精铸高扩展性招聘信息管控系统

1 绪 论 1.1 课题背景与意义 在Internet高速发展的今天&#xff0c;计算机的应用几乎完全覆盖我们生活的各个领域&#xff0c;互联网在经济&#xff0c;生活等方面有着举足轻重的地位&#xff0c;成为人们资源共享&#xff0c;信息快速传递的重要渠道。在中国&#xff0c;网上管…...

【前端】理解 JavaScript 对象属性访问的复杂性

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: 前端 文章目录 &#x1f4af;前言&#x1f4af;理论基础&#xff1a;JavaScript 对象属性的访问模式1. 点符号访问&#xff08;Dot Notation&#xff09;2. 方括号访问&#xff08;Bracket Notation&#xff09;点符号…...

调用支付宝接口响应40004 SYSTEM_ERROR问题排查

在对接支付宝API的时候&#xff0c;遇到了一些问题&#xff0c;记录一下排查过程。 Body:{"datadigital_fincloud_generalsaas_face_certify_initialize_response":{"msg":"Business Failed","code":"40004","sub_msg…...

CentOS下的分布式内存计算Spark环境部署

一、Spark 核心架构与应用场景 1.1 分布式计算引擎的核心优势 Spark 是基于内存的分布式计算框架&#xff0c;相比 MapReduce 具有以下核心优势&#xff1a; 内存计算&#xff1a;数据可常驻内存&#xff0c;迭代计算性能提升 10-100 倍&#xff08;文档段落&#xff1a;3-79…...

Java多线程实现之Callable接口深度解析

Java多线程实现之Callable接口深度解析 一、Callable接口概述1.1 接口定义1.2 与Runnable接口的对比1.3 Future接口与FutureTask类 二、Callable接口的基本使用方法2.1 传统方式实现Callable接口2.2 使用Lambda表达式简化Callable实现2.3 使用FutureTask类执行Callable任务 三、…...

leetcodeSQL解题:3564. 季节性销售分析

leetcodeSQL解题&#xff1a;3564. 季节性销售分析 题目&#xff1a; 表&#xff1a;sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...

搭建DNS域名解析服务器(正向解析资源文件)

正向解析资源文件 1&#xff09;准备工作 服务端及客户端都关闭安全软件 [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0 2&#xff09;服务端安装软件&#xff1a;bind 1.配置yum源 [rootlocalhost ~]# cat /etc/yum.repos.d/base.repo [Base…...

Qemu arm操作系统开发环境

使用qemu虚拟arm硬件比较合适。 步骤如下&#xff1a; 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载&#xff0c;下载地址&#xff1a;https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...

苹果AI眼镜:从“工具”到“社交姿态”的范式革命——重新定义AI交互入口的未来机会

在2025年的AI硬件浪潮中,苹果AI眼镜(Apple Glasses)正在引发一场关于“人机交互形态”的深度思考。它并非简单地替代AirPods或Apple Watch,而是开辟了一个全新的、日常可接受的AI入口。其核心价值不在于功能的堆叠,而在于如何通过形态设计打破社交壁垒,成为用户“全天佩戴…...

Spring Security 认证流程——补充

一、认证流程概述 Spring Security 的认证流程基于 过滤器链&#xff08;Filter Chain&#xff09;&#xff0c;核心组件包括 UsernamePasswordAuthenticationFilter、AuthenticationManager、UserDetailsService 等。整个流程可分为以下步骤&#xff1a; 用户提交登录请求拦…...

基于单片机的宠物屋智能系统设计与实现(论文+源码)

本设计基于单片机的宠物屋智能系统核心是实现对宠物生活环境及状态的智能管理。系统以单片机为中枢&#xff0c;连接红外测温传感器&#xff0c;可实时精准捕捉宠物体温变化&#xff0c;以便及时发现健康异常&#xff1b;水位检测传感器时刻监测饮用水余量&#xff0c;防止宠物…...

起重机起升机构的安全装置有哪些?

起重机起升机构的安全装置是保障吊装作业安全的关键部件&#xff0c;主要用于防止超载、失控、断绳等危险情况。以下是常见的安全装置及其功能和原理&#xff1a; 一、超载保护装置&#xff08;核心安全装置&#xff09; 1. 起重量限制器 功能&#xff1a;实时监测起升载荷&a…...