杀不死的程序员

博客园 首页 新随笔 联系 订阅 管理

 

1.< >表示包含那些由系统提供的并放在指定子目录中的头文件,对于自己编写的头文件放在当前目录或其他目录下则用双引号” ”;

2.复合类型的声明:

int* p1,p2;//p1是指向int的指针,p2是int
/*#define和typedef的区别*/
#define TT  int*
typedef  int*   YY;
TT P1,P2;//p1是指向int的指针,p2是int
YY P1,P2;//p1,P2都是指向int的指针

 

3.decltype类型指示符:如果decltype使用的表达式是一个变量,则decltype返回该变量的类型(包括顶层const和引用在内);decltype(s.size()) p=0;//p的类型和s.size的返回类型一样即string::size_type(  从逻辑上来讲,size() 成员函数似乎应该返回整形数值,或是无符号整数。但事实上,size 操作返回的是 string::size_type 类型的值。

   string 类类型和许多其他库类型都定义了一些配套类型(companion type)。通过这些配套类型,库类型的使用就能与机器无关(machine-independent)。size_type 就是这些配套类型中的一种。它定义为与 unsigned 型(unsigned int 或 unsigned long)具有相同的含义,而且可以保证足够大能够存储任意 string 对象的长度。为了使用由 string 类型定义的 size_type 类型是由 string 类定义。任何存储string的size操作结果的变量必须为string::size_type 类型。特别重要的是,不要把size的返回值赋给一个 int 变量。
   虽然我们不知道 string::size_type 的确切类型,但可以知道它是 unsigned 型。对于任意一种给定的数据类型,它的 unsigned 型所能表示的最大正数值比对应的 signed 型要大一倍。这个事实表明 size_type 存储的 string 长度是 int 所能存储的两倍。 
   使用 int 变量的另一个问题是,有些机器上 int 变量的表示范围太小,甚至无法存储实际并不长的 string 对象。如在有 16 位 int 型的机器上,int 类型变量最大只能表示 32767 个字符的 string 对象。而能容纳一个文件内容的 string 对象轻易就会超过这个数字。因此,为了避免溢出,保存一个 stirng 对象 size 的最安全的方法就是使用标准库类型 string::size_type。)

4.const:定义变量时给初始值,不能修改,只读形式;默认状态下,const对象仅在文件内有效,//对于const变量不管是声明还是定义都添加extern关键字,这样只需定义一次就可以了://extern const int bufSize=8;//该常量能被其他文件访问。

l  auto:编译器通过初始值自动推断变量的类型

n  例如:auto val = val1 + val2;

如果val1+val2是int类型,则val是int类型;

如果val1+val2是double类型,则val是double类型。

5.类和对象:

 

 1 /* class类名称 
 3 {
 5 public:
 7        公有成员(外部接口) 
 9 private: 
11 私有成员
13 protected:
15           保护型成员
17 };
19 从类外访问成员使用“对象名.成员名”方式访问public成员*/

 

6.重载函数的主要好处:{功能类似的多个函数用同一个名字;

要求:参数的类型不同/参数的个数不同/参数的类型和个数都不同}

7.构造函数:”=default”;默认构造函数

8.class和struct关键字都可以定义类,区别在于默认访问权限不一样。如果使用struct关键字,则定义在第一个访问说明符之前的成员是public的;相反使用class关键字,则这些成员是private的。//例:

 

class Word
{
     float mass;//private by default
     char name[20];//private by default
Public:
    void tee(void);
};

9.update()成员函数的函数头如下:

     void Stock ::update(double price)

这种表示法意味着我们定义的update( )函数是Stock类的成员。这不仅将update( )标识为成员函数,还意味着我们可以将另一个类的成员函数也命名为update()。

10.:面向行的输入cin.getline(name,20);//使用getline将姓名读入到一个包含20个元素的name数组中,换行符结束,不包含换行符。

Cin.get();//包含换行符。

将两个类成员函数拼接起来:下面的语句将把输入中的连续两行分别读入到数组name1,name2中,其效果与两次调用cin.getline()相同:

cin.getline(name1,20).getline(name2,20);//cin.getline()返回一个cin对象

11.vector<string> v8{10,”hi”};//v8有10个值为hi的元素

(因为要想列表初始化vector对象,花括号里的值必须与元素类型相同,显然不能用int初始化string对象,所以v7和v8提供的值不能作为元素的初始值。确认无法执行列表初始化后,编译器会尝试用默认值初始化vector对象)

12.要想理解数组声明的含义,最好的办法是从数组的名字开始从右向左,有括号先读括号里的。

13.size_t类型:是一种机器无关的无符号类型,它被设计的足够大以便能表示内存中任意对象的大小。在cstddef头文件中定义了size_t类型,这个文件是c标准库stddef.h头文件的c++版本。在使用数组下标的时候,通常将其定义为size_t类型。

14.在一条语句中混合解引用和递增运算符:

 

1 auto pbeg=v.begin();
2 
3 while(pbeg!=v.end()&& *beg>=0)
4 
5    cout<<*pbeg++<<endl;//输出当前值并将pbeg向前移动一个元素,比cout<<*iter<<endl;\ ++iter;更简洁

 

15.确定一个流对象的状态的最简单的方法是将它当作一个条件来使用: 

while(cin>>word) //while循环检查>>表达式返回的流的状态。如果输入操作成功,流保持有效状态,则条件为真。                  

16.关于枚举:enum spectrum{red,orange,yellow,green,blue};//spectrum成为新类型的名称:spectrum被称为枚举,就像struct变量被称为结构一样。

       

 1 #include <iostream>
 2 enum spectrum{red,orange,yellow,green,blue};
 3 spectrum band;
 4 band=blue;//正确
 5 band=20;//错误,spectrum变量受到限制只能有5个可能值
 6 /*对于枚举,只定义了赋值运算符,没有定义算数运算符*/
 7 band=green;//正确
 8 ++band;//错误
 9 band=orange+green;//错误
10 /*枚举量是证型,可被提升为int类型,但是int类型不能自动转换为枚举类型*/
11 int colour=blue;//正确
12 band=3;//错误
13 colour=2+green;//正确
14 band=orange+red;//错误,算数表达式中枚举将被转换为整数,因此表达式orange+red将被转换为1+0.这是个合法的表达式,但其类型为int,不能将其赋给类型为spectrum的变量band

 17.用const保护数组:

1 /*接受数组名的函数将使用原始数据,可以对其进行修改*/
2 void show_arry(double ar[],int n){}
3 /*为防止函数修改数组的内容,可在声明形参时使用关键字const*/
4 void show_arry(const double ar[],int n){}

 18.

 1  /*如果数据类型本身并不是指针,则可以将const数据或非const数据的地址赋给指向const的指针,但只能将非const数据的地址赋给非const指针*/
 2  int age=30;
 3  const int *pt=&age;/*可以直接通过age变量来修改age的值,但不能用pt指针来修改它;能防止修改pt指向的值,但是不能防止修改pt的值,也就是说可以将一个新地址赋给pt:
 4 int sage=89;
 5 pt=&sage;正确,但仍不能使用pt来修改它指向的值(现在为89)*/
 6  const int ouu=9;
 7  int *pm=&ouu;//错误
 8 void dd(int*){}
 9 dd(ouu);//错误
10 /*尽可能使用const(除非要修改数据)
11 理由:1.这样可以避免由于无意间修改数据而导致的编程错误
12          2.使用const使得函数能够处理const和非const实参,否则将只能接受非const数据。*/
13 /*还有一种使用const的方式使得无法修改指针的值*/
14 int sll=3;
15 int *const pp=&sll;//pp只能指向sll,但允许使用pp来修改sll的值,同样,如果是const int sll=3;则不能赋值给pp

 19.构造函数可以对其参数列表中的元素直接赋值,但是在创建对象时可以通过重新传实参来覆盖它原来的值:

1 class Time
2 {
3     Time(int h,int m=0);//构造函数
4    ......
5 }
6 Time coding(2,40);//创建一个类对象,40覆盖0;

 

 

posted on 2017-11-08 17:48  杀不死的程序员  阅读(272)  评论(0编辑  收藏  举报