C++数组初始化的误解
来源:互联网 发布:mac删除系统自带软件 编辑:程序博客网 时间:2024/06/05 11:15
一直以为 int a[256]={0};是把a的所有元素初始化为0,int a[256]={1};是把a所有的元素初始化为1. 调试的时查看内存发现不是那么一回事,翻了一下《The C++ Programming Language》总算有定论。PDF的竟然不然复制,就把它这章翻译了,
如下5.2.1
数组初始化
数组可以用一个列值来初始化,例如
int v1[] ={1,2,3,4};
char v2[]={'a','b','c',0};
当数组定义时没有指定大小,当初始化采用列表初始化了,那么数组的大小由初始化时列表元素个数决定。
所以v1和v2分别为 int[4] 和char[4]类型。如果明确指定了数组大小,当在初始化时指定的元素个数超过这个大小就会产生错误。例如: char v3[2] ={'a','b',0}; //错误:太多的初始化值了
char v3[3] ={'a','b',0}; //正确
如果初始化时指定的的元素个数比数组大小少,剩下的元素都回被初始化为 0。例如
int v5[8]={1,2,3,4}; 等价于
int v5[8]={1,2,3,4,0,0,0,0};
注意没有如下形式的数组赋值:
void f()
{
v4={'c','d',0}; //错误:不是数组赋值
}
如果你想这样的复制的话,请使用 vector(16章第三节) 或者 valarray(22章第四节)。
字符数组可以方便地采用字符串直接初始化(参考第五章 2.2小节)
译注: 就是 这样啦 char alpha []="abcdefghijklmn";
- C++数组初始化的误解
- 关于数组的误解
- C语言的数组初始化
- c/c++数组的初始化
- C语言的数组初始化
- c语言 数组的初始化
- C语言的数组初始化
- C语言的数组初始化
- C语言的数组初始化
- C语言的数组初始化
- C语言的数组初始化
- C语言的数组初始化
- C/C++ 数组的初始化
- c 字符数组的初始化
- C语言的数组初始化
- C语言的数组初始化
- 【C++】二维数组的初始化
- C语言静态数组的初始化
- 用Oracle PL/SQL 编程实现小数转分数的方法
- 多线程
- 复习要点
- test
- net 使用 Global.asax 文件
- C++数组初始化的误解
- [翻译].NET牛人应该知道些什么
- 创建“维护计划”时遇到的问题
- db2 索引 设计准则
- UltraEdit-32 v14.10 简体中文版
- Visual Studio 2008中的Code Performance Analysis
- Ruby中的二维数组初始化的一个小问题
- Call Unmanaged Code. Part 1 - Simple DLLImport
- Call Unmanaged Code Part 2 - Marshal Class