指针(5)
1.sizeof 和 strlen 的对比
1.1sizeof
sizeof 是操作符,sizeof 计算变量所占内存空间的大小,单位是字节,如果操作数是类型的话,计算的是使用类型创建的变量所占空间的大小。
sizeof 只关注占用内存的空间的大小,不在乎内存中存放的是什么数据。
int main()
{int a = 10;printf("%d\n", sizeof(a));printf("%d\n", sizeof a);printf("%d\n", sizeof(int));return 0;
}
//运行出的结果是一样的说明sizeof是操作符而不是函数,也进一步说明了sizeof不在意内存中存放的是什么内容
//只关注内存中所占用的空间的大小
1.2.strlen
strlen 是库函数,功能是求字符串 \0 之前的字符串长度。函数规则如下:
size_t strlen ( const char * str );
strlen 函数会一直往后找 \0 ,所以可能出现越界的情况。
1.3 sizeof 和 strlen 的对比
sizeof:
1.sizeof 是操作符
2.sizeof计算操作数所占用内存的空间的大小,单位是字节
3.不关注内存中存放的是什么数据
strlen:
1.strlen 是库函数,头文件是 string.h
2.strlen 是求字符串的长度的,统计 \0 之前的字符个数
3.关注内存中是否有 \0,若没有,则会一直往后找,可能出现越界的情况
2.数组和指针题的解析
2.1一维数组
int main()
{int a[] = { 1,2,3,4 };//a 数组有4个元素,每个元素是 int 类型的数据printf("%d\n", sizeof(a));//16 sizeof(数组名)的情况是表示的是这个数组的大小,单位字节printf("%d\n", sizeof(a + 0));// 4/8 a代表首元素地址,a+0 还是首元素地址,printf("%d\n", sizeof(*a));// 4 a代表首元素地址,*a就是首元素,大小是4个字节printf("%d\n", sizeof(a + 1));// 4/8 a表示首元素地址,a+1代表的是第二个元素的地址,计算的就是第二个元素地址,大小是4/8printf("%d\n", sizeof(a[1]));//4 a[1]代表的是下表为1的第二个元素,元素的类型是int,大小是4字节printf("%d\n", sizeof(&a));// 4/8 &a表示的是取得是整个数组的地址,但根本上还是地址,所以大小为4/8printf("%d\n", sizeof(*&a));//16 //1.* 和 &的作用相互抵消 sizeof(a)取得就是 a 整个元素的大小//2.&a 的类型是数组指针 int (*)[4],*&a就是对数组指针进行解引用操作访问一个数组的大小printf("%d\n", sizeof(&a + 1));//4/8 &a+1跳过了整个数组后的一个地址,是地址大小就是4/8printf("%d\n", sizeof(&a[0]));//4/8 &a[0] 取得是下标为0的元素的地址,地址——4/8printf("%d\n", sizeof(&a[0] + 1));// 4/8 &a[0]+1 代表的是第二个元素的地址,大小 4/8return 0;
}
2.2字符数组
代码1:
int main()
{char arr[] = { 'a','b','c','d','e','f' };//arr数组中有6个元素printf("%d\n", sizeof(arr));//6 计算的是整个元素的大小printf("%d\n", sizeof(arr + 0));//4/8 arr是首元素的地址 arr+0表达也是首元素的地址printf("%d\n", sizeof(*arr)); // 1 arr首元素的地址,*arr 就是第一个元素 大小是1个字节printf("%d\n", sizeof(arr[1]));//1 arr[1] 表示的是第二个元素,大小是1printf("%d\n", sizeof(&arr));// 4/8 取得是整个的元素的地址,大小是4/8printf("%d\n", sizeof(&arr + 1));// 4/8 &arr+1 跳过了整个数组,取得的还是地址 4/8printf("%d\n", sizeof(&arr[0] + 1));//4/8 &arr[0]+1 取得的是第二个元素的地址 大小是4/8return 0;}
代码2:
int main()
{char arr[] = { 'a','b','c','d','e','f' };printf("%d\n", strlen(arr));//随机值 printf("%d\n", strlen(arr + 0));//随机值//printf("%d\n", strlen(*arr));//err arr 首元素地址 *arr首元素 是a—97//printf("%d\n", strlen(arr[1]));//err//上述两个例子存放的是两个ASCII码值,应该存放的是字符串,因为strlen要查找\0printf("%d\n", strlen(&arr));//随机值printf("%d\n", strlen(&arr + 1));//随机值printf("%d\n", strlen(&arr[0] + 1));//随机值return 0;
}
代码3:
int main()
{char arr[] = "abcdef";printf("%zd\n", sizeof(arr));//6 整个数组的大小printf("%zd\n", sizeof(arr + 0));// arr 首元素地址 arr+0表示的也是首元素地址 是地址就是4/8个字节printf("%zd\n", sizeof(*arr));//arr 首元素地址,*arr首元素的大小 1printf("%zd\n", sizeof(arr[1]));//arr[1] - 'b' 大小为1printf("%zd\n", sizeof(&arr));//取得是整个数组的地址,是地址,大小就是4/8个字节printf("%zd\n", sizeof(&arr + 1));//跳过整个数组,指向了数组后边的地址 大小4/8字节printf("%zd\n", sizeof(&arr[0] + 1));//得到的是第二个元素的地址,是地址就是4/8字节return 0;
}
代码4:
int main()
{char arr[] = "abcdef"; //arr数组内容:a b c d e f \0printf("%zd\n", strlen(arr));//arr首元素地址 往后找\0 统计个数为 6printf("%zd\n", strlen(arr + 0));//arr首元素地址 arr+0 也是首元素地址 6//printf("%zd\n", strlen(*arr));//arr首元素地址 *arr代表的是首元素 'a'-97 //在strlen中传的是 const char * str 而这里传的是97 是错误的 err//printf("%zd\n", strlen(arr[1]));//同样的,arr[1]-'b'-98 也是错误的 errprintf("%zd\n", strlen(&arr));//&arr 取得是整个数组的地址 指向的是数组的起始位置,往后找\0 6printf("%zd\n", strlen(&arr + 1));//&arr+1 跳过的是整个数组 在往后找\0 不确定 随机值 printf("%zd\n", strlen(&arr[0] + 1));//&arr[0] + 1 指向的是第二个元素地址,往后找\0 元素有5个 大小为 5return 0;
}
代码5:
int main()
{char* p = "abcdef"; //内存中的内容:a b c d e f \0printf("%zd\n", sizeof(p));//p表示的是其实位置的地址,是地址大小就是4/8,不管你里面存放的是什么内容,只管大小,单位字节printf("%zd\n", sizeof(p + 1));//p 第一个元素的地址 p+1 第二个元素的地址 是地址大小就是 4/8printf("%zd\n", sizeof(*p));//*p - a 大小为 1printf("%zd\n", sizeof(p[0]));//p[0]-->*(p+0)-'a',大小为 1printf("%zd\n", sizeof(&p));//二级指针 取得是一级指针p(指针变量)的地址 是地址就是 4/8printf("%zd\n", sizeof(&p + 1));//&p + 1是指向的是p指针变量的后面的空间 但是仍然是地址,是地址就是 4 /8printf("%zd\n", sizeof(&p[0] + 1));//&p[0] + 1代表的是第二个元素地址,是地址大小就是 4/8return 0;
}
代码6:
int main()
{char* p = "abcdef"; //内存中的内容:a b c d e f \0printf("%zd\n", strlen(p));// 6 p表示的是起始位置的地址,往后找\0,统计 \0 之前的个数 就是 6printf("%zd\n", strlen(p + 1));// 5 p+1 就是起始位置的地址+1表示的是第二个元素的地址,往后找\0,有 5 个元素//printf("%zd\n", strlen(*p));//error p 表示的是起始位置的地址 *p -- 'a' 对应的ASCII码值是97,但是strlen函数参数里面接收的是地址 所以会出现错误//printf("%zd\n", strlen(p[0]));//error p[0] 表示的是 'a'--对应的ASCII码值是 97 ,会出现错误 printf("%zd\n", strlen(&p));//随机值printf("%zd\n", strlen(&p + 1));//随机值 &p + 1 跳过的是abcdef\0所有的内容,不知道后面什么时候会出现\0printf("%zd\n", strlen(&p[0] + 1));//5 &p[0] + 1 表示的是第二个元素的地址,往后找\0,会有5个元素return 0;
}
2.3二维数组
数组名的理解:
1.sizeof(数组名) 计算的是整个数组的大小
2.&数组名 取得是整个数组的地址,但是在屏幕上输出的结果同首元素的地址一样
其余情况数组名代表的都是首元素的地址
int main()
{int a[3][4] = {0};printf("%zd\n",sizeof(a));//计算的是整个数组的大小 12*4=48printf("%zd\n",sizeof(a[0][0]));//a[0][0]代表的是第0行的下标为0的元素 大小为 4printf("%zd\n",sizeof(a[0]));//a[0]是二维数组的元素下标为0的行的数组名,代表的是a[0]这一行的大小:4*4=16printf("%zd\n",sizeof(a[0]+1));//a[0]代表的是下标为0的行的地址,这里表示数组首元素a[0][0] a[0]+1代表的是a[0][1]的地址//也是地址,是地址大小就是4/8printf("%zd\n",sizeof(*(a[0]+1)));// a[0]+1代表的是a[0][1]的地址 *(a[0]+1)表示的是a[0][1] 大小是4 printf("%zd\n",sizeof(a+1));//a+1 首元素(第一行)的地址+1表示的是 a[1](第二行)的地址,是地址的大小就是 4/8printf("%zd\n",sizeof(*(a+1)));//*(a+1)=a[1] 就是第二行的数组名 sizeof(数组名) 计算的是第二行的数据的大小 4*4 =16printf("%zd\n",sizeof(&a[0]+1));//&a[0]+1 中的&a[0]代表的是二维数组中首元素(第一行)的名称, +1表示的是第二行的地址//是地址,大小就是 4/8printf("%zd\n",sizeof(*(&a[0]+1)));// &a[0]+1 表示的是a[1](第二行)的地址,*(&a[0]+1)) 后计算大小:4*4=16printf("%zd\n",sizeof(*a));//a表示的是首元素(第一行)地址 *a 表示的就是a[0](第一行),大小为 4*4=16printf("%zd\n",sizeof(a[3]));//a[3]表示的是下标为3的行,虽然本数组只有3行,下标为2,但是sizeof是根据类型来判断大小的,//sizeof(表达式)不存在越界,内部的表达式是不会真实计算的,只要知道类型就可以计算出大小,在一个二维整型数组中不存在的行数,//也是会计算出结果的,按照已经存在的行数来计算,在strlen中是不会出现这种情况的,因为在strlen中传的是字符串而不是整型数组//大小为 4*4=16return 0;
}
3.指针运算题的解析
3.1 题目1
int main()
{int a[5] = { 1, 2, 3, 4, 5 };int* ptr = (int*)(&a + 1);printf("%d,%d", *(a + 1), *(ptr - 1)); // 2 5return 0;
}
//程序的结果是什么???
3.2 题目2
//在X86环境下
//假设结构体的⼤⼩是20个字节
//程序输出的结果是啥?
struct Test
{int Num;char* pcName;short sDate;char cha[2];short sBa[4];
}*p = (struct Test*)0x100000;int main()
{printf("%p\n", p + 0x1); //+0x1 = +1 指针+1 跳过了20字节 所以这里的+1是加了20,结果为: 0x100014printf("%p\n", (unsigned long)p + 0x1);//unsigned long 转换为整型 +1 是真正的 +1,结果为: 0x100001printf("%p\n", (unsigned int*)p + 0x1);//(unsigned int*) 转换为整型指针数据类型 +1 实际上是+4,结果为:0x100004return 0;
}
3.3 题目3
int main()
{//逗号表达式: 1 3 5 所以数组的真正内容是:1 3 5int a[3][2] = { (0, 1), (2, 3), (4, 5) }; // 0 0 0//初始化数组用 { } // 0 0 0int* p;p = a[0];// 第一行的数组名,表示首元素的地址printf("%d", p[0]); //1return 0;
}
3.4 题目4
//假设环境是x86环境,程序输出的结果是啥?
int main()
{int a[5][5];int(*p)[4];p = a;printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]); //-4 原码:10000000000000000000000000000100//%p 打印出来的是补码 -4 的补码:FFFFFFFC // 反码:11111111111111111111111111111011 //%d 打印出来的是原码 -4 中的 - (负号) 是因为低地址-高地址 // 补码:1111 1111 1111 1111 1111 1111 1111 1100//指针 - 指针 的绝对值表示的是 两个地址之间的元素个数 // F F F F F F F C //输出结果://FFFFFFFC //-4return 0;
}
3.5 题目5
int main()
{int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };int* ptr1 = (int*)(&aa + 1);int* ptr2 = (int*)(*(aa + 1));printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));// 10 5return 0;
}
3.6 题目6
int main()
{char* a[] = { "work","at","alibaba" };char** pa = a;pa++;printf("%s\n", *pa);//输出结果:atreturn 0;
}
3.7 题目7
int main()
{char* c[] = { "ENTER","NEW","POINT","FIRST" };char** cp[] = { c + 3,c + 2,c + 1,c };char*** cpp = cp;printf("%s\n", **++cpp);//POINTprintf("%s\n", *-- * ++cpp + 3);//ERprintf("%s\n", *cpp[-2] + 3);//STprintf("%s\n", cpp[-1][-1] + 1);//EWreturn 0;
}
相关文章:
指针(5)
1.sizeof 和 strlen 的对比 1.1sizeof sizeof 是操作符,sizeof 计算变量所占内存空间的大小,单位是字节,如果操作数是类型的话,计算的是使用类型创建的变量所占空间的大小。 sizeof 只关注占用内存的空间的大小,不在…...
机器学习day4-Knn+交叉验证api练习(预测facebook签到位置)
数据集:FackebookV : 预测 row id:签⼊事件的id x y:坐标 accuracy: 准确度,定位精度 time: 时间戳 place_id: 签到的位置,需要预测的内容 具体步骤: # 1.获取数据集 # 2.基本数据处理 # 2.1 缩⼩数据…...
AI工具 Trae 创建java项目和配置运行环境完整示例
以下是使用字节跳动 Trae IDE 创建 Java 项目并配置运行环境的完整示例,结合其核心功能和搜索结果的实践案例整理: 一、环境准备与安装 下载与安装 访问 Trae 官网 下载 Windows 或 macOS 版本客户端,安装完成后选择中文界面和主题(推荐 Dark/DeepBlue 主题)。首次启动时支…...
【论文_序列转换模型架构_20230802v7】Attention Is All You Need 【Transformer】
https://arxiv.org/abs/1706.03762 20170612 v1 代码实现_notebook ∗Equal contribution. Listing order is random. Jakob proposed replacing RNNs with self-attention and started the effort to evaluate this idea. 提出用 self-attention 替代 RNNs,并开始…...
清晰易懂的跨域请求知识——拿捏
1. 什么是跨域请求? 简单来说:当你的 前端网页(例如 http://frontend.com)通过 JavaScript 调用 后端接口(例如 http://backend.com/api)时,如果两者的 域名、端口、协议 中任意一项不同&#…...
前端漏洞不扫描理由
漏洞类型豁免理由基于DOM的XSS1.已实施安全加固: 使用encodeURIComponent对URL参数进行编码 对特殊字符(<>“”&)进行HTML实体转义 使用template literal替代字符串拼接 移除了直接操作DOM的不安全写法,二次扫描仍然扫描出来,且修改建议模糊 2…...
论文阅读的三个步骤
论文阅读的三个步骤 方法说明链接:https://www.academia.edu/4907403/How_to_Read_a_Paper 方法框架如下...
Javascript 中的继承?如何实现继承?
一、继承的本质 继承:子对象可以自动拥有父对象的属性和方法,就像孩子继承父母的基因。JavaScript 的继承:通过原型链实现(原型和原型链是底层核心)。 二、4 种常见继承方式 1. 原型链继承(传家宝模式&am…...
深入理解 Linux 权限管理:从基础到进阶
在 Linux 系统中,权限管理是保障系统安全与资源合理分配的核心机制。无论是服务器管理员,还是日常使用 Linux 的开发者,深入掌握权限管理,不仅能避免因权限设置不当导致的数据泄露或系统故障,还能灵活高效地管理各类资…...
第1阶段-前5天-考试题及答案
文章目录 1.1 用户 root 的家目录是哪里?1.2 如何查询 linux 系统 ip 地址?1.3 检查是否可以访问 baidu.com 的命令?1.4 [rootoldboy-c7 /etc/sysconfig/ ]# 说说每一部分含义?1.5 说说 Linux 常见快捷键?(至少 3 个)1.6 Windows 分为 C 盘,D 盘,但是 Linux 一切从 根或/ …...
农村供水智能化远程监控解决方案
农村供水智能化远程监控解决方案 ——基于巨控GRM242Q-4D4I4Q(HE)模块的快速部署方案 一、项目需求与痛点 某西南山区农村供水项目需管理12个分散站点,每个站点包含: 4-20mA模拟量:压力传感器、流量计485通信设备:智能水表&…...
4月29日星期二今日早报简报微语报早读
4月29日星期二,农历四月初二,早报#微语早读。 1、特朗普声称中方领导人打了电话,外交部:近期中美元首没有通话; 2、跳水世界杯总决赛名单出炉,“梦之队”全主力出战; 3、深圳:对年…...
C++日更八股--first
### 内存static和dynamic的区别 static(静态) 和 dynamic(动态)<br> static:内存分配在编译的时候确定,大小和生命周期固定,无需运行时分配开销<br> dynamic:内存分配在运行时动态申请…...
Git操作指令
1.基础操作指令: (1).查看修改的状态(git status): 查看修改的状态(暂存区、工作区) (2).添加工作区到暂存区(git add 单个文件名 | 通配符): 添加工作区一个或多个文件的修改到暂存区 (3).提交暂存区到本地仓库(git commit -m "注释内容"): 提交暂存区内容到本…...
Linux——安装NVM
1. 安装命令 官方地址:https://github.com/nvm-sh/nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.3/install.sh | bash2. 安装完成后执行命令 source ~/.bashrc3. 验证 nvm -v...
C++之AVL树
前言 一、AVL的概念 二、AVL树的实现 2.1 AVL的结点结构 2.2 AVL树结点的插入 平衡因子的更新 更新原则: 更新停止的条件: 插入结点以及更新平衡因子的代码实现 旋转 右单旋 左单旋 左右双旋 右左双旋 2.3 AVL树的查找 2.4 AVL树的平衡性检测 总结 前言 …...
解决STM32H743单片机USB_HOST+FATF操作usb文件
前缀 花了两天的时间整理了一下在使用STM32H743单片机开发usb相关功能时遇到的问题及解决方案,具体为以下2种情况: 1.USB插上单片机后,单片机卡死,导致长时间没有喂狗程序重启; 2.USB正常插拔后,使用FAT…...
数据结构|并查集
Hello !朋友们,这是我在学习过程中梳理的笔记,以作以后复习回顾,有时略有潦草,一些话是我用自己的话描述的,可能不够准确,还是感谢大家的阅读! 目录 一、并查集Quickfind 二、两种算…...
从拒绝采样到强化学习,大语言模型推理极简新路径!
大语言模型(LLMs)的推理能力是当下研究热点,强化学习在其复杂推理任务微调中广泛应用。这篇论文深入剖析了相关算法,发现简单的拒绝采样基线方法表现惊人,还提出了新算法。快来一探究竟,看看这些发现如何颠…...
数据中心电能质量问题解决方案及经典案例
行业背景与挑战 数据中心作为互联网的核心枢纽,承载着海量数据存储、计算及通信任务,其内部精密设备(如恒温恒湿空调、高精度开关电源等)对电能质量极为敏感。微小的电压波动或频率偏差可能导致设备损坏,而瞬态过电压…...
【软考-高级】【信息系统项目管理师】【论文基础】沟通管理过程输入输出及工具技术的使用方法
沟通管理概念 沟通是人们分享信息、思想和情感的过程,沟通的主旨在于互动双方建立彼此相互了解的关系,相互回应,并期待能经由沟通的过程相互接纳并达成共识。 沟通失败是很多IT项目失败的重要原因。 与IT项目成功有关的最重要的四个因素是…...
优化PCB Via Stub系列(1):一次学会利用层叠设计降低Via Stub损耗
开路谐振对SI而言真不是个好东西,这种1/4波长谐振会带来讯号的驻波,进而降低整体通道带宽,导致SI不佳! 在高速PCB设计中,最常发生的1/4波长谐振就属过孔的Via stub,这个小小的金属残段可以酿成大大的SI问题…...
STP端口状态变迁及故障拓扑变化
STP端口状态变迁及故障拓扑变化 一、STP 端口状态变迁(以标准 STP 为例,共 5 种状态) 状态功能描述能否收发数据帧能否收发 BPDU持续时间进入条件Disabled端口物理关闭或被管理员手动关闭,不参与 STP 运算。否否-端口物理 down …...
9.idea中创建springboot项目_jdk1.8
9. idea中创建springboot项目_jdk1.8 步骤 1:打开 IntelliJ IDEA 并创建新项目 启动 IntelliJ IDEA。在欢迎界面,点击 New Project(或通过菜单栏 File > New > Project)。 步骤 2:选择 Maven 项目类型 在左侧…...
mysql 事务中如果有sql语句出错,会导致自动回滚吗?
CREATE TABLE name ( id int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT ID, name varchar(32) DEFAULT COMMENT 名称, PRIMARY KEY (id) ) ENGINEInnoDB DEFAULT CHARSETutf8mb4; 情况1.执行下列操作, 会发现新开窗口 去查询name表时,整个事务都…...
考OCM证书前需要有OCP证书
报考OCM认证必须持有有效OCP证书。 从知识体系的构建来看,OCP 和 OCM 认证构成了一个循序渐进的学习和考核体系。OCP 认证侧重于考察数据库管理员和开发人员对 Oracle 数据库的基础架构、日常管理、性能优化、备份恢复等核心技能的掌握。通过 OCP 考试,意…...
动态图表 -- eg1
问题: 前端vue,后端springboot,实现动态表格样式,(表格List<Student>,Student类有年级,班级,文理科分类,姓名,学号,等属性。先根据年级分类…...
echo 1 > /proc/sys/kernel/nmi_watchdog报错
报错内容 /proc/sys/kernel/nmi_watchdog报错,内容如下: [root@localhost log]# echo 1 > /proc/sys/kernel/nmi_watchdog -bash: echo: write error: Unknown error 524 [root@localhost log]#报错原因 内核未配置 NMI 支持 某些自定义内核可能未编译 NMI Watchdog 驱…...
upload-labs PASS 1-5通关
PASS-01 前端javascript检查 1,第一个提示javascript对上传的文件进行审查 2,javascript工作在前端页面,可以直接删除具有审查功能的代码 3,删除之后再上传一句话木马 上传成功,可以使用蚁剑进行连接,控制网…...
大数据测试集群环境部署
Hadoop大数据集群搭建(超详细)_hadoop_小飞飞519-GitCode 开源社区 hadoop集群一之虚拟机安装(mac)_hadoop_皮皮虾不皮呀-华为开发者空间 hadoop集群二之hadoop安装_hadoop_皮皮虾不皮呀-华为开发者空间 虚拟机如何查看gateway | PingCode智库...
BUUCTF——Online Tool
BUUCTF——Online Tool 进入靶场 <?phpif (isset($_SERVER[HTTP_X_FORWARDED_FOR])) {$_SERVER[REMOTE_ADDR] $_SERVER[HTTP_X_FORWARDED_FOR]; }if(!isset($_GET[host])) {highlight_file(__FILE__); } else {$host $_GET[host];$host escapeshellarg($host);$host e…...
人工智能数学基础(三):微积分初步
微积分作为数学的重要分支,为人工智能的发展提供了坚实的理论基础。从理解数据的变化趋势到优化模型参数,微积分的应用贯穿其中。本文将深入探讨微积分的核心概念,并结合 Python 编程实例,助力大家轻松掌握这些关键知识点。资源绑…...
【11408学习记录】考研英语语法核心:倒装句考点全解+真题演练
倒装句 英语语法总结——特殊句式倒装全部倒装介词短语形容词副词There be 部分倒装否定副词或词组位于句首only位于句首虚拟条件句省略if 每日一句词汇第一步:找谓语第二步:断句第三步:简化主句定语从句 英语 语法总结——特殊句式 倒装 …...
云数据中心整体规划方案PPT(113页)
1. 引言 概述:云数据中心整体规划方案旨在构建弹性、高效的云计算基础设施,通过软件定义数据中心(SDDC)实现资源虚拟化与管理自动化。 2. 技术趋势与背景 技术革新:随着云计算、虚拟化及自动化技术的发展,…...
java练习4
创建类对象,要求写一个人的类,内容包括: 值:年龄,姓名,家庭身份 函数:年龄,姓名修改,家庭身份修改,生孩子 package a01_第一次练习.a04_创建类对象;public cl…...
在VMware上创建Ubuntu虚拟机,与Xshell和Xftp的连接和使用
一、在VMware创建Ubuntu虚拟机 1、创建新的虚拟机 2、新建虚拟机安装导向 1)自定义安装 2)稍后安装操作系统 3)选择Linux和Ubuntu64 4)可自定义虚拟机名称和虚拟机位置 5)选择合适的处理器数量 6)虚拟机…...
Java常用注解通俗解释
注解就像是给Java代码贴的"便利贴",它们不会改变代码本身的逻辑,但能给编译器、开发工具或运行时环境提供额外信息。下面我用最通俗的方式解释Java中最常用的注解: 一、基础篇:人人必知的注解 1. Override - "我…...
前端性能优化2:结合HTTPS与最佳实践,全面优化你的网站性能
点亮极速体验:结合HTTPS与最佳实践,为你详解网站性能优化的道与术 在如今这个信息爆炸、用户耐心极其有限的数字时代,网站的性能早已不是一个可选项,而是关乎生存和发展的核心竞争力。一个迟缓的网站,无异于在数字世界…...
小刚说C语言刷题——1032分糖果
1.题目描述 某幼儿园里,有 5 个小朋友编号为 1,2,3,4,5,他们按自己的编号顺序围坐在一张圆桌旁。他们身上都有若干个糖果,现在他们做一个分糖果游戏。 从 1 号小朋友开始,将他的糖…...
socket套接字-UDP(下)
socket套接字-UDP(中)https://blog.csdn.net/Small_entreprene/article/details/147567115?fromshareblogdetail&sharetypeblogdetail&sharerId147567115&sharereferPC&sharesourceSmall_entreprene&sharefromfrom_link在我之前搭建…...
使用Docker操作MySQL
在Docker中操作MySQL可以简化数据库的部署和管理过程。以下是详细的步骤,包括如何拉取MySQL镜像、创建容器以及配置远程访问权限。 拉取MySQL镜像 首先,使用以下命令从Docker Hub拉取MySQL镜像: docker pull mysql你也可以指定版本&#x…...
OpenGL ES 3.0 第二章总结:你好,三角形(Hello Triangle)
—— 从“画出第一个三角形”理解现代图形渲染流程 🔰 写在前面 OpenGL 是一个状态机型的图形 API。第二章《你好,三角形》是整个图形开发的起点,它帮助我们掌握从「准备绘制数据」到「渲染出第一个像素」的完整流程。 这一章最核心的任务是…...
neo4j vs python
1.将库中已经存在的两个节点,创建关系。 查询库中只有2个独立的节点。 方式一,python,使用py2neo库 #coding:utf-8 from py2neo import Graph,Node,Relationship,NodeMatcher##连接neo4j数据库,输入地址、用户名、密码 graph G…...
MIT6.S081-lab7前置
MIT6.S081-lab7前置 这部分包含了设备中断和锁的内容 设备中断 之前系统调用的时候提过 usertrap ,而我们的设备中断,比如计时器中断也会在这里执行,我们可以看看具体的逻辑: void usertrap(void) {int which_dev 0;if((r_sst…...
通过漂移-扩散仿真研究钙钛矿-硅叠层太阳能电池中的电流匹配和滞后行为
引言 卤化物钙钛矿作为光活性半导体的出现,为光伏技术的发展开辟了令人振奋的新方向。[1] 除了在单结太阳能电池中的优异表现,目前研究的重点在于将钙钛矿吸收层整合到叠层器件中。在硅-钙钛矿叠层太阳能电池中,将高效的钙钛矿吸收层与成熟的…...
IIC小记
SCL 时钟同步线,由主机发出。 当SCL为高电平(逻辑1)时是工作状态,低电平(逻辑0)时是休息状态。SCL可以控制通信的速度。 SDA 数据收发线 应答位:前八个工作区间是一个字节,在SCL…...
使用 ECharts 在 Vue3 中柱状图的完整配置解析
一、初始化图表实例 const chart echarts.init(chartRef.value);二、Tooltip 提示配置 tooltip: {trigger: axis,axisPointer: {type: line // 支持 line 或 shadow 类型,指示器样式},backgroundColor: rgba(0,0,0,0.7),textStyle: { color: #fff },formatter: {…...
Ubuntu实现远程文件传输
目录 安装 FileZillaUbuntu 配套设置实现文件传输 在Ubuntu系统中,实现远程文件传输的方法有多种,常见的包括使用SSH(Secure Shell)的SCP(Secure Copy Protocol)命令、SFTP(SSH File Transfer P…...
AI驱动软件工程:SoftEngine 方法论与 Lynx 平台实践分析
引言 在过去数十年中,软件开发领域历经了从瀑布模型到敏捷开发,再到DevOps的深刻变革。然而,面对当今快速变化的市场需求和复杂的软件系统,这些方法仍然显露出明显的局限性。近年来,基于大语言模型(LLM&am…...
Vue基础(一) 基础用法
1.取消生产提示 Vue.config.productionTip false; Vue.config.devtools true; //运行开发调试 2.hello小案例 需要注意如下几点: 1.必须要有一个模板,其实就是一个html组件 2.新建一个Vue实例,并且通过el与容器建立绑定关系࿰…...