0

0

C++怎么使用数组 C++动态数组和静态数组定义【实战】

尼克

尼克

发布时间:2026-02-28 15:36:44

|

322人浏览过

|

来源于php中文网

原创

静态数组大小必须编译期确定,如int arr[5];动态数组需new[]/delete[]手动管理,易出错;推荐用std::array(静态)和std::vector(动态),必要时用std::unique_ptr接管堆数组。

c++怎么使用数组 c++动态数组和静态数组定义【实战】

静态数组定义:类型+大小必须在编译期确定

静态数组的大小写死在代码里,比如 int arr[5],编译器看到就分配 5 个 int 连续内存。它不调用构造函数(对 POD 类型),也不涉及堆操作,快且确定。

常见错误是把变量当大小:int n = 10; int arr[n]; —— 这在标准 C++ 中非法(GCC 允许是 GNU 扩展,但不是 portable)。C++11 起支持 std::array<int></int> 替代,大小仍是编译期常量。

  • 适用场景:已知固定尺寸、生命周期和栈空间足够(比如缓存小缓冲区、矩阵维度)
  • 注意 sizeof(arr) 返回总字节数,不是元素个数;要算长度得用 sizeof(arr) / sizeof(arr[0])
  • std::array 更安全:带 .size()、支持范围 for、能传值,推荐替代裸数组

动态数组用 new[]delete[]:手动管理,极易出错

想运行时决定大小?用 new int[n] 分配堆内存,返回指针。但它不记录长度,不自动析构对象(对类类型需显式调用构造/析构),且必须配对使用 delete[] —— 写成 delete 会未定义行为。

典型翻车现场:int* p = new int[10]; delete p; → 内存泄漏 + 可能崩溃;或忘记 delete[] 导致堆泄漏。

立即学习C++免费学习笔记(深入)”;

瑞志企业建站系统(ASP版)2.2
瑞志企业建站系统(ASP版)2.2

支持模板化设计,基于标签调用数据 支持N国语言,并能根据客户端自动识别当前语言 支持扩展现有的分类类型,并可修改当前主要分类的字段 支持静态化和伪静态 会员管理功能,询价、订单、收藏、短消息功能 基于组的管理员权限设置 支持在线新建、修改、删除模板 支持在线管理上传文件 使用最新的CKEditor作为后台可视化编辑器 支持无限级分类及分类的移动、合并、排序 专题管理、自定义模块管理 支持缩略图和图

下载
  • 参数差异:new int[n]n 是运行时值,但类型仍需明确(不能 new auto[n]
  • 性能影响:每次 new[] 触发堆分配,比栈慢;频繁分配释放易碎片化
  • 兼容性:C++98 起支持,但现代代码应避免直接使用

真正该用的:优先选 std::vector,不是“动态数组”的替代品,而是正确抽象

std::vector 不是语法糖,它封装了容量管理、异常安全拷贝、迭代器、RAII —— 这些你手写 new[] 根本没法轻松搞定。

比如扩容:vectorpush_back 超限时自动申请新内存、移动旧数据、释放旧内存;而自己用 new[] 得重复造轮子,还容易漏异常路径。

  • 初始化:std::vector<int> v(10);</int> 分配 10 个默认初始化 intstd::vector<int> v{1,2,3};</int> 初始化列表
  • 获取原始指针?用 v.data(),比取 &v[0] 安全(空 vector 时前者返回 nullptr,后者 UB)
  • 不要用 vector 存裸指针管理资源 —— 改用 std::unique_ptr 或直接存对象

什么时候真得碰裸数组?只有极少数底层场景

比如对接 C API(如 OpenGL 的 glVertexAttribPointer 要求连续内存)、嵌入式无 STL 环境、或高性能计算中极致控制内存布局。

这时若必须用,优先考虑 std::array(静态)或 std::unique_ptr<t></t>(动态)—— 后者自动 delete[],避免手动匹配问题。

  • std::unique_ptr<int> p(new int[100]);</int> → 析构时自动 delete[],比裸指针可靠得多
  • 千万别混用:用 new 分配单个对象,就用 delete;用 new[] 分配数组,必须用 delete[]
  • 所有裸数组操作(越界访问、长度误判、释放遗漏)都不会被编译器拦住,靠人盯,容易忽略

最麻烦的从来不是“怎么写”,而是“谁负责释放”和“长度信息存在哪”。C++ 数组语义简单,但边界和所有权一模糊,问题就藏进运行时里了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1560

2023.10.24

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

870

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

593

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

0

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.3万人学习

C 教程
C 教程

共75课时 | 5万人学习

C++教程
C++教程

共115课时 | 19.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号