初识C语言:常量与变量中寻找数据类型

简介: 初识C语言:常量与变量中寻找数据类型

一、常量和变量

1.1 常量

1.1.1 常量的概念

常量是指在C语言中不变的值

常量分为整型常量,浮点型常量,字符常量,const 修饰的常变量,,#define 定义的标识符常量以及枚举常量。


例如:

#include<stdio.h>
int main()
{
    18;
    184.5;
    80;
    returm 0;
}


1.1.2 const修饰的常变量

虽然被const修饰后为常变量,但本质上是变量

#include<stdio.h>
int main()
{
    const int a = 10;
    int arr[a] = { 0 };
    return 0;
}


编译结果如下:

虽然可能没有报错,但也无法运行,因为表达式中必须含有常量值,因为在静态内存分配中要先分配内存,此时就要求表达式必须是一个常量,也间接证明了,const修饰后的常变量,本质上是一个具有常量性质的变量。


1.2.3 #define定义的标识符常量

代码示例如下:

#include<stdio.h>
#define MAX 1000;
int main()
{
  int a = MAX;
  printf("MAX = %d\n",a);
  return 0;
}


为了将标识符与变量名区别开来,习惯上标识符全部用大写字母表示。

枚举常量将在以后的枚举类型里面为大家介绍


1.2 变量

C语言中把变化的值,用变量概念来表示

1.2.1 变量的创建

(1)变量的定义

#include<stdio.h>
int main()
{
    int age=18;
    float height=184.5f;
    char ch='H';
    return 0;
}


(2)变量的命名

1).只能由字母(包括大写和小写)、数字和下划线( _ )组成。

2).不能以数字开头。

3).长度不能超过63个字符。

4).变量名中区分大小写的。

5).变量名不能使用关键字。


1.2.2 局部变量和全局变量

变量分为局部变量全局变量

(1)局部变量:

局部变量,也称内部变量,是指在一个函数内部或语句内部定义的变量。

也可以浅显的理解为{ }内定义的变量只能在{ }内的范围使用。

#include<stdio.h>
int mian()
{
  int a = 1;
  if (a == 1)
  {
    int j = 1;
  }
  printf("%d", j);
  return 0;
}

就会出现以下报错

如果将printf函数放入if语句{ }中就可以打印


代码如下(示例):

#include<stdio.h>
int main()
{
  int a = 1;
  if (a = 1)
  {
    int j = 1;
    printf("%d", j);
  }
  return 0;
}


1.2.3 作用域和生命周期

(1)作用域

1. 局部变量的作用域是变量所在的局部范围。

2. 全局变量的作用域是整个工程。


(2)生命周期

1.变量的生命周期指的是变量的创建到变量的销毁之间的一个时间段

2.局部变量的生命周期是:进入作用域生命周期开始,出作用域生命周期结束。

3. 全局变量的生命周期是:整个程序的生命周期。


二、数据类型

C语言的数据类型丰富多样,由以下组成

2.1 类型分类

2.1.1 基本类型

(1)整数类型

整数类型数据即整型数据,整型数据没有小数部分的数值。整型数据可分为:基本型、短整型、长整型和无符号型四种。

基本型:以int表示。

短整型:以short int表示。

长整型:以long int表示。

无符号型:存储单元中全部二进位用来存放数据本身,不包括符号。无符号型中又分为无符号整型、无符号短整型和无符号长整型,分别以unsigned int,unsigned short和unsigned long表示。


要注意的是,不同的计算机体系结构中这些类型所占比特数有可能是不同的,下面列出的是32位机中整型家族各数据类型所占的比特数。


整数常量分为多种进制


  1. 十进制整数的表示与数学上的表示相同,例如:256,-321,0
  2. 八进制整数的表示以数字0开头,例如:0234表示八进制整数,所对应的十进制数为2×82+3×81+4×80=156。
  3. 十六进制整数的表示以0x开头,例如:0×234表示十六进制整数。(应当注意的是十六进制数前导字符0x)。


(2)实数(浮点)类型

实型变量又可分为单精度(float)、双精度(double)和长双精度(long double)3种。列出的是常见的32位机中实型家族各数据类型所占的比特数。



要注意的是,这里的有效数字是指包括整数部分+小数部分的全部数字总数。

小数部分所占的位(bit)越多,数的精度就越高;指数部分所占的位数越多,则能表示的数值范围就越大。

实数(浮点)常量有以下两种表达形式。


  1. 十进制数形式。由正负号、数字和小数点组成。如5.734、一0.273、0.8、一224等都是十进制数形式。
  2. 指数形式。如546E+3或546E3都代表546×10 3。字母E(或e)之前必须有数字,E(或e)后面的指数必须为整数。


E8、4.6E+2.7、6e、e、9E7.5都是不合法的指数形式;

5.74E-7、-3E+6是合法的指数形式实型常量。


(3)字符类型

字符常量是指用单引号括起来的一个字符,如:‘a’,‘5’,‘?’ 等都是字符常量。以下是使用字符常量时容易出错的地方,请读者仔细阅读。


  1. 字符常量只能用单引号括起来,不能用双引号或其他括号。
  2. 字符常量只能是单个字符,不能是字符串。
  3. 字符可以是字符集中任意字符。但数字被定义为字符型之后就不能参与数值运算。如’5’和5是不同的。‘5’是字符常量,不能直接参与运算,而只能以其ASCⅡ码值(053)来参与运算。

枚举类型和指针类型以后泊舟会教你们的啦


2.1.2 结构类型

(1)结构体类型

在现实生活中,有很多的一组的数据,比如学生(姓名、年龄、身高、体重、成绩.),员工(姓名、年龄、性别、已婚、未婚、工龄),里面的属性不一定都是相同的类型。使用构造数据类型——结构体类型。


结构体内部的元素,也就是组成成分,我们一般称为"成员"。

struct  结构类型名

{

数据类型 成员1;

数据类型 成员2;

数据类型 成员3;

……

数据类型 成员n;

};


struct是关键字,是结构体类型的标志。

写结构体类型的方法示例如下:

struct stuInfo
{
char name[20];
int     num;
int     age;
char sex;
};
struct stuInfo stu1 = {“zhangsan”, 1, 20, ‘m’};
struct stuInfo stu2 = {“lisi”, 2, 22, ‘f’};


在程序中使用结构变量时,往往不把它作为一个整体来使用。一般对结构变量的使用,包括赋值、输入、输出、运算等都是通过结构变量的成员来实现的。


表示结构变量成员的一般形式是:‘.’ 结构体成员变量运算符,结构体变量.成员(stu1.name)


这是初阶的讲解,只要知道它的存在就好啦~


剩下几种以后在讲解啦~


2.2 signed和unsigned

整数在存储单元中都是以补码形式存储的,存储单元中的第 1 个二进制位代表符号。整型变量的值的范围包括负数到正数。


但是在实际应用中,有的数据的范围常常只有正值(如学号、年龄等),为了充分利用变量的值的范围,可以将变量定义为“无符号”类型。可以在类型符号前面加上修饰符 unsigned ,表示指定该变量是“无符号整数”类型。如果加上修饰符 signed,则是“有符号”类型。


在大多数时候我们常常省去signed,比如用int来表示signed int。

3e8af852462e9be3be51ff1e014e1c45_b75327cc7ffcf5618f7c58748dc03d7e.png


至于这些不同的类型是怎么存储的,会在之后的内容都给大家讲到的啦,不用着急。


总结:

今天讲到了c语言各种各样的数据类型,这将成为我们打开计算机的大门的第一步,我也会持续不断为大家带来更新的~

相关文章
|
28天前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
36 1
|
30天前
|
存储 C语言
C语言指针与指针变量的区别指针
指针是C语言中的重要概念,用于存储内存地址。指针变量是一种特殊的变量,用于存放其他变量的内存地址,通过指针可以间接访问和修改该变量的值。指针与指针变量的主要区别在于:指针是一个泛指的概念,而指针变量是具体的实现形式。
|
1月前
|
存储 C语言
C语言:设置地址为 0x67a9 的整型变量的值为 0xaa66
在C语言中,可以通过指针操作来实现对特定地址的访问和赋值。要将地址为 0x67a9 的整型变量值设为 0xaa66,可以先定义一个指向该地址的指针,并通过该指针对该内存位置进行赋值操作。需要注意的是,直接操作内存地址具有一定风险,必须确保地址合法且可写。代码示例应考虑字节序及内存对齐问题。
|
1月前
|
C语言 C++
实现两个变量值的互换[C语言和C++的区别]
实现两个变量值的互换[C语言和C++的区别]
19 0
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
34 3
|
C语言
《C语言编程初学者指南》一2.6 理解常量
本节书摘来自华章出版社《C语言编程初学者指南》一书中的第2章,第2.6节,作者【美】Keith Davenport(达文波特) , M1ichael Vine(维恩),更多章节内容可以访问云栖社区“异步社区”公众号查看 2.6 理解常量 常量(constant)数据类型通常也叫做只读变量,在程序执行中,它们不会丢失其数据值。
1544 0
|
7天前
|
C语言
c语言调用的函数的声明
被调用的函数的声明: 一个函数调用另一个函数需具备的条件: 首先被调用的函数必须是已经存在的函数,即头文件中存在或已经定义过; 如果使用库函数,一般应该在本文件开头用#include命令将调用有关库函数时在所需要用到的信息“包含”到本文件中。.h文件是头文件所用的后缀。 如果使用用户自己定义的函数,而且该函数与使用它的函数在同一个文件中,一般还应该在主调函数中对被调用的函数做声明。 如果被调用的函数定义出现在主调函数之前可以不必声明。 如果已在所有函数定义之前,在函数的外部已做了函数声明,则在各个主调函数中不必多所调用的函数在做声明
22 6
|
27天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
34 10
|
20天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
25天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
53 7