数据类型、运算符、表达式

作者: 十年L_c2c6 | 来源:发表于2017-03-18 13:12 被阅读12次

C语言的数据类型:基本数据类型、构造数据类型、指针类型、空类型。

  • 构造数据类型:是根据已定义的一个或多个数据类型用构造方法来定义的。一个构造类型的值可以分解成若干个“成员”或“元素”
  • 指针类型: 指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个变量在内存储器中的地址。

常量与变量

常量:程序执行过程中其值不发生改变的量。

  • 直接常量:
    a.整型常量:1,100,29,-10
    b.实型常量:5.2,6.4,-0.5
    c.字符常量:‘a’,'b'
  • 符号常量:用宏来代表一个常量。在C语言中,可以使用一个标识符来表示一个常量,称之为符号常量。
    符号常量在使用之前需要先定义,其一般形式为:
  • () #define 标识符 常量
    其中#define是一条预处理命令,称为红定义命令,其功能是把该标识符定义为其后的常量值。
    习惯上符号常量的标识符使用大写字母,变量标识符使用小写字母,以示区别
  • 例如:#define PI 3.1415926

变量:其值可以改变的量成为变量

一个变量应该有一个名字,在内存中占有一定的存储单元,变量在使用之前必须先定义。
int a=3; int是a的数据类型,a是变量名,3是变量值。

整型数据

1.整型常量

整型常量就是整常数,C语言中的常整数有八进制,十六进制,十进制三种。
(1)十进制整常数:十进制常整数没有前缀,其数码为0~9

  • 合法的十进制整常数,123,2,4356,-100.
  • 不合法的十进制整常数:078,78A(含有非十进制数码)
  • 在程序中各个前缀用来区分各种进制数。
    (2)八进制常整数:八进制整数必须以0开头,即以0作为八进制数的前缀。数码为0~7。八进制通常是无符号数。
  • 合法的八进制整常数:015(13),0101(64),0177777(65535)
  • 不合法的八进制整常数:256,03A2,-0127
    (3)十六进制整常数:十六进制整常数的前缀为0X或0x,其数码为09,af或A~F,
  • 合法的十六进制整常数:0X2A(42),0XA0(160),0XFFFF(65535)
  • 非法的十六进制整常数:5A,0X3H

实型数据

  • 十进制数形式:由0~9和小数点组成
  • 合法实数:0.0,0.12,4.567,-256.123 (必须有小数点)
  • 指数形式:由十进制数加阶码标志“e”或“E”以及阶码组成。
  • 其一般形式为: a E n (a 为十进制数,n为十进制整数)
  • 其值为 a10^n.
    如:2.1e5(2.1
    10^5) 3.7e-2(3.710^-2) 0.5e7(0.510^7)

实型变量

(1)实型变量实型数据在内存中的存放形式

  • 实型数据一般占4个字节。按指数形式存储。
    |符号位 |小数部分 |指数部分 |
    小数部分占的位越多,数的有效数字越多,精度越高
    指数部分占的位数越多,数能表示的范围越大。

    (2)实型变量的分类
  • 单精度(float),双精度(double型),长双精度(long double型)三类

字符变量

字符数据在内存中的存储形式及使用方法。
每个字符变量被分配一个字节的空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在内存单元中的。

#include <stdio.h>
int main()
{
    char a,b;
    a = 120;
    b = 121;
    printf("%c,%c\n",a,b);
    printf("%d,%d\n",a,b);
    return 0;
}

a=x b=y
a=120 b=121

字符串常量和字符常量是不同的量.他们有以下区别

  • 字符常量是由单引号括起来的,字符串常量是由双引号括起来的
  • 字符常量只能是单个字符,字符串常量则含有一个火多个字符.
  • 可以吧一个字符常量付给一个字符变量,但不能把一个字符串常量付给一个字符变量.在C语言中没有相应的字符串变量。我们用一个字符数组在存放一个字符变量。
  • 字符占一个字节的内存空间.字符串常量占的内存字节数等于字符串中的字节数加一.增加的一个字节用于存放字符'\0',这是字符串的结束标志。

各类数据类型的混合运算

(1) 若参与运算量的类型不同,则先转换成同一类型然后进行运算.
(2)转换按数据长度增加的方向进行,以保证精度不降低,如int与long运算时,先把int转换为long,然后进行运算。
(3)所有的浮点型运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换为double型,然后进行运算。
(4)char型和short运算时,必须先转换为int
(5)在赋值运算时,赋值号两边量的数据类型不同时,赋值号右边的量的类型转换为左边量的类型.如果右边量的数据类型长度大于左边的,则会丢失一部分数据,这样会降低精度,丢失的部分四舍五入.

![Upload Paste_Image.png failed. Please try again.]

强制类型转换

  • 强制类型转换是通过类型转换运算来实现的。
  • 其一般形式为:
    (类型说明符)(表达式)
    其功能是吧表达式的运算结果强制转换成类型说明符所表示的类型
    int a;
    (float) a; //把a转换为实型
    (int) (x+y) //把x+y的结果转换为整型
    注意:
    (1)类型说明符和表达式都必须加括号(单个变量可以不加),
    (2)无论是强制类型转换还是自动转换,都只是为了本次运算的需要对变爱玲的数据长度进行临时替换,而不是改变变量的类型。

相关文章

网友评论

    本文标题:数据类型、运算符、表达式

    本文链接:https://www.haomeiwen.com/subject/osuunttx.html