- 重组文档目录结构: 每个模块的概述页移动到模块子目录 - 重命名 index.md 为 main.md - 修正所有模块文档中的错误: - math: FromEuler→FromEulerAngles, TransformDirection 包含缩放, Box 是 OBB, Color::ToRGBA 格式 - containers: 新增 operator==/!= 文档, 补充 std::hash DJB 算法细节 - core: 修复 types 链接错误 - debug: LogLevelToString 返回大写, timestamp 是秒, Profiler 空实现标注, Windows API vs ANSI - memory: 修复头文件路径, malloc vs operator new, 新增方法文档 - resources: 修复 Shader/Texture 链接错误 - threading: TaskSystem::Wait 空实现标注, ReadWriteLock 重入描述, LambdaTask 链接 - 验证: fix_links.py 确认 0 个断裂引用
48 lines
961 B
Markdown
48 lines
961 B
Markdown
# Array::Size() / Capacity() / Empty()
|
||
|
||
```cpp
|
||
size_t Size() const;
|
||
size_t Capacity() const;
|
||
bool Empty() const;
|
||
```
|
||
|
||
获取数组的尺寸信息。
|
||
|
||
**Size():** 返回数组中的实际元素数量。
|
||
|
||
**Capacity():** 返回底层内存缓冲区能容纳的元素数量,不一定等于 `Size()`。
|
||
|
||
**Empty():** 返回数组是否为空(`Size() == 0`)。等价于 `Size() == 0`,但更语义化。
|
||
|
||
**返回:**
|
||
- `Size()` - 元素数量
|
||
- `Capacity()` - 底层缓冲区容量
|
||
- `Empty()` - 是否为空
|
||
|
||
**复杂度:** O(1)
|
||
|
||
**示例:**
|
||
|
||
```cpp
|
||
Containers::Array<int> arr;
|
||
|
||
arr.Size(); // 0
|
||
arr.Capacity(); // 0
|
||
arr.Empty(); // true
|
||
|
||
arr.PushBack(1);
|
||
arr.PushBack(2);
|
||
|
||
arr.Size(); // 2
|
||
arr.Capacity(); // 4(自动扩容)
|
||
arr.Empty(); // false
|
||
|
||
arr.Reserve(100);
|
||
arr.Size(); // 2(元素数量不变)
|
||
arr.Capacity(); // 100(容量增加)
|
||
```
|
||
|
||
## 相关文档
|
||
|
||
- [Array 总览](array.md) - 返回类总览
|