C++学习 之 变量和常量的使用(笔记)

一、变量

1.对变量含义的理解:

  变量就像是经过工厂加工后有一定容量的容器。在变量定义时,系统充当了工厂的角色,按照类型为变量分配相应的空间。定义完成的变量可以存放相应类型的值,存放的值大于变量所能接受的范围时变量会发生溢出。顾名思义,变量里的值一般是可以修改的,体现在该变量存储区的值可以复写。

2.C++中变量的声明:

  C++定义变量的语法:

      variable_type(变量类型) variable_name(变量名称);

      或

      variable_type(变量类型) variable_name(变量名称) = initial_value(初始值);

如:

int v1;
char v2='a';

  声明多个类型相同的变量:

      variable_type(变量类型) variable_name(变量名称),variable_name(变量名称),...,variable_name(变量名称);

      variable_type(变量类型) variable_name(变量名称) = initial_value(初始值),...,variable_name(变量名称) = initial_value(初始值); 

      variable_type(变量类型) variable_name(变量名称),...,variable_name(变量名称) = initial_value(初始值);

如:

int a,b,c,d;
int e=0,f=0,g=0;
int h,i=0;

3.理解变量作用域:

  每个变量都有作用域,变量的作用域决定了变量定义的生效范围,就如同法律条文一样,一般不同国家的法律条文仅作用于本国,变量仅生效于其作用域。函数内定义的变量的作用域为该函数内,全局变量的作用域为全局。不同函数内定义的变量被视为独立实体,当该函数执行完毕便释放变量所占用的内存空间,即便不同函数内定义的变量名称相同也不会相互影响。

  全局变量定义示例:

#include<iostream>
using std::cout;
using std::endl;
int a=20;
void Print()
{
    cout<<a<<endl;    
}
int main()
{
   Print(); cout
<<a<<endl; }

  局部变量定义示例:

#include<iostream>
using std::cout;
using std::endl;
int a=20;
void Print()
{
    int b=30;
    cout<<b<<endl;  
    cout<<a<<endl;    
}
int main()
{
    Print();
    cout<<a;
    //cout<<b;
}

  注意:main函数中的注释行"//cout<<b;"如果去掉注释符号会有类似于'b' was not declared in this scope的报错信息。因为变量 "b"只在Print函数中定义了,在main函数中没有定义。

4.C++中常见变量类型和取值范围:

  4.1 bool变量

  C++中专门为存储布尔值true和false而创建的变量类型,bool变量的取值为true或false。

  布尔变量定义示例:

bool running=false;

  4.2 char变量

  char变量用于存储单个字符。char的取值为256个字符值,在ASCII码中用7位二进制表示字符,可表示128个不同的字符值;在扩展ASCII码用一个字节中的高一位做扩展位,其余7位表示128个不同的字符

  加上高位的一位共8位可表示256个字符值。

  

char input_char='Y';//定义名为input_char的变量,并设置初始值为Y。

  4.3 unsigned int 和 int变量

  unsigned int 中有 unsigned short int 和 unsigned long int ,unsigned short int为二进制16位表示范围为0~65535,unsigned long int 为二进制32位表示范围为0~4294967295。在大多C++编译器中int被认

  为拥有4个字节共32位,即直接使用unsigned int时 其取值范围大多时候为0~4294967295,部分编译器会把它。unsigned long long int 的范围为unsigned long int的两倍。int 中有short int 和 long int 以及

  long long int,它们的二进制表示最高位为符号位,所以 short int 的取值范围 -32768~32767,long int 的取值范围为-2147483648~2147483648,long long int 的取值范围是 long 的基础上扩展两倍。

  4.4 浮点类型 float 和 double

  浮点数就是实数,可以是正,也可以是负,还可以包含小数值。如果要存储小数就可以声明浮点类型的变量,如:float Pi=3.1416;声明双精度浮点数(double)变量如:double Pi=3.14159265,注意想存

  储两个整数相除得到的小数结果时,不能直接相除,而应在把整数换成类似"22.0"这样的小数。

5. typedef替换变量类型

  C++允许我们将变量类型替换为我们认为方便或更具描述性的名称,为此可使用关键字 typedef。例如:typedef unsigned int Integral_type;给 unsigned int 一个别名 Integral_type。

二、常量

1. 常量的定义:

  不被人为改变的量叫做常量,换句话说常量的值不能被修改。如果我们想定义了一个具有和变量一样带有名称的常量,我们可以使用const来定义,也可以使用enum声明枚举常量。在C++11版本中新增了

  常量表达式,声明时使用constexpr。不推荐使用#define定义变量,因为其定义的是宏常量,只是字符替换,编译器不关心常量的类型,没法进行语法的检查。const比#define更安全并且更加简洁高效;    #define兼容性更好。

2.枚举常量的定义:

  使用enum为一种变量设置特定一组取值。

    例如枚举常量包含彩虹的颜色:

enum RainbowColors
{
    Violot = 0,
    Indigo,
    Blue,
    Green,
    Yellow,
    Orange,
    Red
};

  声明的枚举常量,编译器会把它转化为整数,其默认起始值为0,我们也可以给定初始值如上例中显式给出初始值为0,我们还可以给每个枚举常量赋指定值(使用默认值时每个值都比前一个大1,当然除

  了第一个)。

  注意:变量命名要符合规范,要站在别人的角度考虑,要使得变量名或常量名具有描述性。

原文地址:https://www.cnblogs.com/dulm/p/11218781.html