数组和指针
1.数组的维数,需要注意的地方
2.特殊的字符数组,用一个字符串字面值初始化字符数组时,字符串字面值包含一个额外的空字符(null)
3.数组和vector的区别(3点)
4.取地址(&)操作符只能用于左值,因为只有当变量用作左值时,才能取其地址
5.把对指针进行初始化货赋值操作只能使用以下四种类型的值:
(1)0值常量表达式,例如,在编译时可获得0值得整型const对象或字面值常量0
(2)类型匹配的对象的地址
(3)另一对象之后的下一地址
(4)同类型的另一个有效地址
把int型变量赋给指针是非法的,尽管此int型变量的值可能为0.但允许把数值0或在编译时可获得0值得const量赋给指针。
6.指针和引用的区别(4.15)
7.size_type、different_type、size_t、ptrdiff_t
8.指针和const限定符
不能使用指向const对象的指针修改基础对象,然而如果该指针指向的是一个非const对象,可以其他方法修改其所指的对象。
/**
* Copyright (C) 2014, CSU
* All rights reservedl
* File Name:test.cpp
* Author: lmm
* Date of completion: 2014/10/7
* Version: v1.0
*
* 问题描述:不能使用指向const对象的指针修改基础对象,然而如果该指针指向的是一个非const对象,
* 可以其他方法修改其所指的对象。
* 输入描述: 基本数据
* 程序输出: 通过其他方法改变指向const对象的指针所指对象的值
*/
#include <iostream>
using namespace std;
int main()
{
const double *cptr;
double dval = 3.14159;
cptr = &dval;
//*cptr = 3.14159; error: cptr is a pointer to const
double *ptr = &dval; // ptr points at non-const double
*ptr = 2.72;
cout << *cptr << endl;
}
程序结果:
在实际程序中,指向const的指针常用作函数的形参。将形参定义为指向const的指针,以此确保传递给函数的实际对象在函数中不因为形参而被修改。
9.const指针
理解:typedef string *pstring;
const pstring cstr;
等价于:string *const cstr; // cstr定义为指向string类型对象的const指针
10.永远不要忘记字符串结束符null
在使用处理C风格字符串的标准库函数时,牢记字符串必须以结束符null结束
C++中所有的字符串字面值都由编译器自动在末尾添加一个空字符。
11. 创建动态数组
/**
* Copyright (C) 2014, CSU
* All rights reservedl
* File Name:test.cpp
* Author: lmm
* Date of completion: 2014/10/7
* Version: v1.0
*
* 问题描述:编写程序读入一组string类型的数据,并将它们存储在vector中,接着,把该vector对象复制给一个字符指针数组
* 为vector中的每个元素创建一个新的字符数组,并把该vector元素的数据复制到相应的字符数组中,
* 最后把指向该数组的指针插入字符指针数组中
* 输入描述: string类型的数据
* 程序输出: 输出数组的内容
*/
#include <iostream>
#include <string>
#include <vector>
#include <cstring>
using namespace std;
int main()
{
vector<string> svec;
string str;
cout << "Enter strings: " << endl;
while(cin >> str)
svec.push_back(str);
char **parr = new char*[svec.size()];
size_t ix = 0;
for(vector<string>::iterator iter = svec.begin(); iter != svec.end(); ++ iter, ++ix)
{
char *p = new char[(*iter).size()+1];
strcpy(p,(*iter).c_str());
parr[ix] = p;
}
cout << "Content of character arrays: " << endl;
for(ix = 0; ix != svec.size(); ++ix)
cout << parr[ix] << endl;
for(ix = 0; ix != svec.size(); ++ix)
delete []parr[ix];
delete []parr;
return 0;
}
程序结果: