博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++语言学习
阅读量:6853 次
发布时间:2019-06-26

本文共 4247 字,大约阅读时间需要 14 分钟。

 

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

2.复合类型的声明:

int* p1,p2;//p1是指向int的指针,p2是int/*#define和typedef的区别*/#define TT  int*typedef  int*   YY;TT P1,P2;//p1是指向int的指针,p2是intYY 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 defaultPublic:    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++<

 

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

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

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

       

1 #include 
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 Time2 {3     Time(int h,int m=0);//构造函数4    ......5 }6 Time coding(2,40);//创建一个类对象,40覆盖0;

 

 

转载于:https://www.cnblogs.com/ctq1/p/7805323.html

你可能感兴趣的文章
centos7 init
查看>>
php通过各种函数判断0和空
查看>>
基于easyui的文档管理系统springmvc+mybaits实现
查看>>
Chrome将证书透明度要求推迟至2018年
查看>>
jdbc的五大常见应用场景
查看>>
字符串
查看>>
剖析非同质化代币ERC721-全面解析ERC721标准
查看>>
Python八荣八耻
查看>>
华硕网络硬盘服务出问题!遭到中间人攻击
查看>>
java电子商务系统源码 Spring MVC+mybatis+spring cloud+spring boot+spring security
查看>>
Java 实现 给Excel模板赋值(直接打开表格赋值或者用自定义了名称的单元格(一块区域)赋值)...
查看>>
DataLakeAnalytics: 解析IP地址对应的国家城市地址的能力
查看>>
20181120上课截图
查看>>
FastReport教程:如何从命令行使用报表设计器和查看器
查看>>
sed命令详解及运用
查看>>
一篇文章让你全部看懂!内存-java模型-jvm结构
查看>>
[转] Valgrind使用
查看>>
0023-HOSTS配置问题导致集群异常故障分析
查看>>
《软件开发工具》要点
查看>>
iOS开发 图形变换-做一个正方体
查看>>