C++ 变量和类型



C++ 变量

变量为我们提供了程序可以操作的命名存储。C++ 中的每个变量都具有特定的类型,该类型决定变量内存的大小和布局;可以存储在该内存中的值的范围;以及可以应用于变量的操作集。

C++ 变量命名

变量的名称可以由字母、数字和下划线字符组成。它必须以字母或下划线开头。大写字母和小写字母是不同的,因为 C++ 区分大小写。

C++ 中变量命名约定的一些其他规则 -

  • 关键字不能用作变量名。
  • 变量名不能包含空格。
  • 变量名中不能使用连字符 (-)。
  • 变量名不能以特殊字符和数字开头。它应该是一个大写或小写字符或下划线 (_) 。

有效变量名称示例

一些有效的变量名称如下 -

int age;
int _age;
int student_age;
int studentAge;

无效变量名称示例

一些无效的变量名称如下 -

int 2ndvariable;
int student-age;
int float;
int student age;
int #age;

C++ 变量类型

如下所示,C++ 中有以下基本变量类型,在上章中已解释 -

序号 类型和描述
1

bool

存储真或假值。

2

char

通常是一个八位字节(一个字节)。这是一种整数类型。

3

int

机器最自然的整数大小。

4

float

单精度浮点值。

5

double

双精度浮点值。

6

void

表示类型的缺失。

7

wchar_t

宽字符类型。

C++ 还允许定义各种其他类型的变量,我们将在后续章节中介绍,例如枚举、指针、数组、引用、数据结构

下一节将介绍如何定义、声明和使用各种类型的变量。

C++ 中的变量定义

变量定义告诉编译器在哪里以及为变量创建多少存储空间。变量定义指定数据类型,并包含如下所示的一个或多个该类型变量的列表 -

语法

type variable_list;

这里,type必须是有效的C++ 数据类型,包括 char、w_char、int、float、double、bool 或任何用户定义的对象等,而variable_list可以包含一个或多个用逗号分隔的标识符名称。这里显示了一些有效的声明 -

int    i, j, k;
char   c, ch;
float  f, salary;
double d;

int i, j, k; 这行代码同时声明和定义了变量 i、j 和 k;它指示编译器创建名为 i、j 和 k 的 int 类型变量。

C++ 中的变量初始化

变量可以在其声明中进行初始化(分配初始值)。初始化程序由等号后跟一个常量表达式组成,如下所示 -

语法

type variable_name = value;

示例

一些示例如下 -

extern int d = 3, f = 5;    // declaration of d and f. 
int d = 3, f = 5;           // definition and initializing d and f. 
byte z = 22;                // definition and initializes z. 
char x = 'x';               // the variable x has the value 'x'.

对于没有初始化程序的定义:具有静态存储持续时间的变量隐式初始化为 NULL(所有字节的值都为 0);所有其他变量的初始值未定义。

C++ 中的变量声明

变量声明向编译器保证存在一个具有给定类型和名称的变量,以便编译器在不需要有关变量的完整详细信息的情况下继续进行进一步的编译。变量声明仅在编译时具有意义,编译器在程序链接时需要实际的变量定义。

当您使用多个文件并将变量定义在一个文件中时,变量声明很有用,该文件将在程序链接时可用。您将使用extern关键字在任何地方声明变量。尽管您可以在 C++ 程序中多次声明变量,但它只能在一个文件中、一个函数中或一段代码中定义一次。

示例

尝试以下示例,其中变量已在顶部声明,但已在 main 函数内部定义 -

#include <iostream>
using namespace std;

// Variable declaration:
extern int a, b;
extern int c;
extern float f;
  
int main () {
   // Variable definition:
   int a, b;
   int c;
   float f;
 
   // actual initialization
   a = 10;
   b = 20;
   c = a + b;
 
   cout << c << endl ;

   f = 70.0/3.0;
   cout << f << endl ;
 
   return 0;
}

当以上代码编译并执行时,会产生以下结果 -

30
23.3333

相同的概念也适用于函数声明,您在函数声明时提供函数名称,其实际定义可以在任何其他地方给出。例如 -

// function declaration
int func();
int main() {
   // function call
   int i = func();
}

// function definition
int func() {
   return 0;
}

左值和右值

C++ 中有两种表达式 -

  • 左值 - 指向内存位置的表达式称为“左值”表达式。左值可以出现在赋值的左侧或右侧。

  • 右值 - 右值一词是指存储在内存某个地址中的数据值。右值是一个表达式,不能将其值赋予它,这意味着右值可以出现在赋值的右侧,但不能出现在左侧。

变量是左值,因此可以出现在赋值的左侧。数字文字是右值,因此不能被赋值,也不能出现在左侧。以下是一个有效的语句 -

int g = 20;

但以下语句无效,会生成编译时错误 -

10 = 20;
广告