数据结构11

我勒个好多东西都没了😭。

*p先声明指针,然后后面无内型*p是通过地址修改。

也叫解引用符

C语言的结构体和java中的类很像。

sizeof(po) 是 C语言里的 sizeof 运算符,用来计算 po 这个结构体类型在内存中所占的字节数,简单来说就是"量一下这个结构体的'大小'"。

  1. 具体作用(结合之前的代码)

之前定义的 po 结构体是:

c

typedef struct {

int x; // int 类型占 4 字节(大部分系统)

int y; // int 类型占 4 字节

} po;

sizeof(po) 会计算这个结构体的总字节数: 4 + 4 = 8 字节。

把它传给 malloc ,就是告诉 malloc :"我需要一块和 po 结构体一样大的内存空间"------这样 malloc 就能准确分配 8 字节的空间,刚好能装下 po 结构体的两个 int 成员。

  1. 为什么要用到它?
  • 不用手动算大小:如果直接写 malloc(8) ,虽然结果一样,但如果后续修改了 po 结构体(比如加一个 char z; ), sizeof(po) 会自动变成 4+4+1=9 (实际会按内存对齐变成12字节,不过原理一样),而手动写的 8 就会出错;

  • 保证兼容性:不同系统里 int 的大小可能不同(比如某些嵌入式系统是 2 字节), sizeof 会自动适配当前系统的字节数,避免写死数值导致跨平台问题。

一句话总结

sizeof(po) 是"给 malloc 一个'尺子'",让它知道要分配多大的内存,确保能装下 po 结构体的所有内容。

p = (po*)malloc(sizeof(po));

还有Java的free垃圾回收。

// sizeof(po)计算po结构体的大小(int占4字节,两个int共8字节)

// (po*)是强制类型转换,把malloc返回的通用地址转成po结构体的指针

p = (po*)malloc(sizeof(po));

开辟完这个空间之后再挂个门牌号。

没错!在 p = (po*)malloc(sizeof(po)); 这个表达式中,执行顺序确实是从括号里的内容开始,按优先级逐步向外执行,具体步骤如下:

  1. 先执行最内层的 sizeof(po)

sizeof 是优先级很高的运算符,会先计算 po 结构体的大小(比如8字节),得到一个具体的数值,这是整个表达式的"基础数据"------相当于先确定要建的房子尺寸。

  1. 再执行 malloc(...)

malloc 是函数调用,它的参数就是第一步算出的结果(8字节),所以接下来会调用 malloc 申请8字节的内存,并返回这块内存的起始地址------相当于按确定的尺寸建好房子,拿到门牌号。

  1. 然后执行 (po*) 强制类型转换

将 malloc 返回的通用地址( void* )转换成 po* 类型------相当于给拿到的门牌号配上户型图,明确内存的解读方式。

  1. 最后执行赋值操作 =

把转换后的地址赋值给指针变量 p ------相当于把这个带户型图的门牌号交给 p 保管,后续通过 p 就能操作这块内存了。

简单说,执行顺序是: sizeof(po) → malloc(...) → (po*) → 赋值给 p ,完全遵循"从内层括号到外层、从高优先级到低优先级"的规则。

算法

算法的时间复杂度。

不过执行语句的快慢也和设备相关。

我们说的时间复杂度一般是上限,最慢的时候。

相关推荐
万粉变现经纪人8 小时前
如何解决 pip install mysqlclient 报错 ‘mysql_config’ not found 问题
数据库·python·mysql·pycharm·bug·pandas·pip
智航GIS10 小时前
11.3 Pandas 模块功能概览
python·信息可视化·pandas
White-Camellia1 天前
Pandas多个数据表合并(merge)
pandas
muddjsv1 天前
Pandas 绘图全能手册:12 类基础图一键绘制,覆盖所有原生绘图类型
pandas
程序猿零零漆1 天前
Spring之旅 - 记录学习 Spring 框架的过程和经验(十四)SpringMVC的请求处理
学习·spring·pandas
weixin_462446231 天前
Python 使用 PyQt5 + Pandas 实现 Excel(xlsx)批量合并工具(带图形界面)
python·qt·pandas
橙露2 天前
从零基础到实战:Python 数据分析三剑客(Pandas+NumPy+Matplotlib)核心应用指南
python·数据分析·pandas
清水白石0083 天前
手写超速 CSV 解析器:利用 multiprocessing 与 mmap 实现 10 倍 Pandas 加速
python·pandas
Hello.Reader5 天前
PyFlink 向量化 UDF(Vectorized UDF)Arrow 批传输原理、pandas 标量/聚合函数、配置与内存陷阱、五种写法一网打尽
python·flink·pandas
Hello.Reader5 天前
PyFlink Table API Data Types DataType 是什么、UDF 类型声明怎么写、Python / Pandas 类型映射一文搞懂
python·php·pandas