C++ Primer 学习笔记(2)

第二章(变量和基本类型)的学习笔记,采用关键词的形式进行一一阐述。

1.变量

变量,或者说对象,其实就是内存中具有类型的区域,且具有名字供程序操作。

例如:int i =0,int为类型,i 为变量名。

在这里就引申出两个概念:变量名和类型。

变量名,就是标识符,由字母、数字和下划线构成;特别的是C++区分大小写,不过变量命名一般使用小写;当然不支持C++保留的关键字。

类型,如int(整型),告诉我们一个存储在被命名为“i”的区域的数据是整数,而不是浮点数;其中隐含的信息还有,该区域占内存的大小,该区域的数据所能进行的操作。

类型,有基本内置类型和自定义类型(包括标准库类型),int就是一个内置类型。

2.定义和声明

例如int i =0,这是一个变量定义的形式。

定义,用于为变量分配存储空间,或者说有目的地划出内存中的某个区域,并给予名字和类型。

注意的是在一个程序中,定义有且只有一个。

声明,用于向程序表明该变量的类型和名字。使用关键字extern进行说明,例如extern int i;

一个程序,会包含多个文件,为了在多个文件中使用同一个变量,需要向程序表明该变量的类型和名字,于是就用上了声明。

声明不是定义,不分配存储空间,只是定义在其他地方的使用说明。

区别:

声明可以多次,定义只有一次;

定义就是声明,声明不是定义,但使用了初始化的声明可看做是定义(如extern int i=0;).

3.初始化

int i=0;这程序语句的完整意思是:定义了一个变量名i的存储空间用来存放数据,并将它初始化为0,即预先存放数据0。个人理解为占位,在图书馆的座位上,贴上自己的名字,并放上自己的书包。

初始化就是那个书包。注意,任何没有放书包的占位都是不可靠的,同样,任何没有初始化的定义都是不可靠的。

当然,有时系统会自动帮我们初始化,即默认初始化。对于内置类型变量,这取决于变量定义的位置,即后面提到的作用域;对于类类型变量,大多数都提供默认构造函数。(类类型变量通过构造函数进行初始化)

4.作用域

一个定义的变量,在程序不同的地方会发挥不同的意义,这就是作用域,用于区分变量在哪些地方发挥不同意义。

作用域分为全局作用域、局部作用域和语句作用域。其中,作用域可以嵌套,嵌套过程中,语句作用域屏蔽局部,局部屏蔽全局,由里到外。

5.const、引用和const 引用

const,定义常量的限定符。定义常量代表一个常数,在程序上具有很好的作用。

定义方法如const int i=0;常量定义后具有不可修改性,所以必须初始化;另外,const变量(即常量)可以通过声明(extern)跨文件访问,并且是显示               表示,非const变量则默认为extern。

引用,实质只是它绑定的对象的别名,对象的另一个名字;对引用的操作都实际作用在绑定的对象上。引用通过变量名前添加“&”来定义,并且必须初始化.

引用定义如 “int j=0;int &i=j;"。

const引用,指向const对象的引用,如”const int j=0;const int &i=j; “。

const引用可以绑定到非const对象上,但非const引用绑定到const对象是不合法的,个中原因还得从引用的实质中寻找”引用,实质只是它绑定的对象的                别名,对引用的操作都实际作用在绑定的对象上“。

6.typedef

typedef,定义类型的同义词。暂时不知有何好作用,以观后效。

7.枚举

枚举,为某些属性定义一组可选择的值;定义如:enum open_modes {intput,output,append};enum为关键字,open_modes为枚举类型名,{intput,output,append}用{}括起来的枚举成员。

枚举成员,第一个默认初始化为0,其后递增+1;成员可以初始化为某个常量;枚举成员为常量表达式,一旦初始化后不能改变。

至于后面几节关于类类型的,之后和第三章一起学习更为妥当!

C++ Primer 学习笔记(2)

时间: 2024-07-29 03:58:49

C++ Primer 学习笔记(2)的相关文章

C++ Primer 学习笔记_98_特殊工具与技术 --优化内存分配

特殊工具与技术 --优化内存分配 引言: C++的内存分配是一种类型化操作:new为特定类型分配内存,并在新分配的内存中构造该类型的一个对象.new表达式自动运行合适的构造函数来初始化每个动态分配的类类型对象. new基于每个对象分配内存的事实可能会对某些类强加不可接受的运行时开销,这样的类可能需要使用用户级的类类型对象分配能够更快一些.这样的类使用的通用策略是,预先分配用于创建新对象的内存,需要时在预先分配的内存中构造每个新对象. 另外一些类希望按最小尺寸为自己的数据成员分配需要的内存.例如,

C++ Primer 学习笔记_73_面向对象编程 --再谈文本查询示例

面向对象编程 --再谈文本查询示例 引言: 扩展第10.6节的文本查询应用程序,使我们的系统可以支持更复杂的查询. 为了说明问题,将用下面的简单小说来运行查询: Alice Emma has long flowing red hair. Her Daddy says when the wind blows through her hair, it looks almost alive, like a fiery bird in flight. A beautiful fiery bird, he

C++ Primer 学习笔记_74_面向对象编程 --再谈文本查询示例[续/习题]

面向对象编程 --再谈文本查询示例[续/习题] //P522 习题15.41 //1 in TextQuery.h #ifndef TEXTQUERY_H_INCLUDED #define TEXTQUERY_H_INCLUDED #include <iostream> #include <fstream> #include <sstream> #include <vector> #include <set> #include <map&g

C++ Primer 学习笔记_19_类与数据抽象(5)_初始化列表(const和引用成员)、拷贝构造函数

C++ Primer 学习笔记_19_类与数据抽象(5)_初始化列表(const和引用成员).拷贝构造函数  从概念上将,可以认为构造函数分为两个阶段执行: 1)初始化阶段: 2)普通的计算阶段.计算阶段由构造函数函数体中的所有语句组成. 一.构造函数初始化列表 推荐在构造函数初始化列表中进行初始化 1.对象成员及其初始化 <span style="font-size:14px;">#include <iostream> using namespace std;

C++ Primer 学习笔记_14_标准模板库_bitset位集合容器

C++ Primer 学习笔记_14_标准模板库_bitset位集合容器 bitset容器是一个bit位元素的序列容器,每个元素只占一个bit位,取值为0或1,因而很节省内存空间.下图是一个bitset的存储示意图,它的10个元素只使用了两个字节的空间. 使用bitset需要声明头文件"#include <bitset>" 1.创建bitset对象 创建bitset对象时,必须要指定容器的大小.bitset对象的大小一经定义,就不能修改了.下面这条语句就定义了bitset对

C++ Primer 学习笔记_23_标准模板库_stack.

C++ Primer 学习笔记_11_标准模板库_stack.queue队列容器与priority_queue优先队列容器 1.stack堆栈 stack堆栈是一个后进先出(Last In First Out,LIFO)的线性表,插入和删除元素都只能在表的一端进行.插入元素的一端称为栈顶,而另一端称为栈底.插入元素叫入栈(Push),删除元素叫出栈(Pop).下图是堆栈示意图 堆栈只提供入栈,出栈,栈顶元素访问和判断是否为空等几种方法.采用push()方法将元素入栈:采用pop()方法出栈:采用

C++primer学习笔记(二)——Chapter 4

4.1  Fundamentals 1.Basic Concepts (1)操作符分为一元,二元或者三元操作符: (2)复杂的表达式中含有很多操作符时: 规则一:分为不同的级别,级别高的先运行: 规则二:相同级别的操作符有执行顺序的确定: (3)操作符可以改变操作数的类型 一般将级别低的转化成级别高的 (4)重载运算符 相同的运算符在对不同类型的对象进行操作的时候,会有不同的功能: (5)Lvalue和Rvalue 显而易见:Lvalue指的是Left value,Rvalue指的是Right

C++ Primer 学习笔记_104_特殊工具与技术 --嵌套类

特殊工具与技术 --嵌套类 可以在另一个类内部(与后面所讲述的局部类不同,嵌套类是在类内部)定义一个类,这样的类是嵌套类,也称为嵌套类型.嵌套类最常用于定义执行类. 嵌套类是独立的类,基本上与它们的外围类不相关,因此,外围类和嵌套类的对象是互相独立的.嵌套类型的对象不具备外围类所定义的成员,同样,外围类的成员也不具备嵌套类所定义的成员. 嵌套类的名字在其外围类的作用域中可见,但在其他类作用域或定义外围类的作用域中不可见.嵌套类的名字将不会与另一作用域中声明的名字冲突 嵌套类可以具有与非嵌套类相同

C++ Primer 学习笔记_102_特殊工具与技术 --运行时类型识别[续]

特殊工具与技术 --运行时类型识别[续] 三.RTTI的使用 当比较两个派生类对象的时候,我们希望比较可能特定于派生类的数据成员.如果形参是基类引用,就只能比较基类中出现的成员,我们不能访问在派生类中但不在基类中出现的成员. 因此我们可以使用RTTI,在试图比较不同类型的对象时返回假(false). 我们将定义单个相等操作符.每个类定义一个虚函数 equal,该函数首先将操作数强制转换为正确的类型.如果转换成功,就进行真正的比较:如果转换失败,equal 操作就返回 false. 1.类层次 c

C++ Primer 学习笔记_77_模板与泛型编程 --实例化

模板与泛型编程 --实例化 引言: 模板是一个蓝图,它本身不是类或函数.编译器使用模板产生指定的类或函数的特定版本号.产生模板的特定类型实例的过程称为实例化. 模板在使用时将进行实例化,类模板在引用实际模板类型时实例化,函数模板在调用它或用它对函数指针进行初始化或赋值时实例化. 1.类的实例化 当编写Queue<int>qi时,编译器自己主动创建名为Queue<int>的类.实际上,编译器通过又一次编写Queue模板,用类型int取代模板形參的每次出现而创建Queue<int