C语言数据类型

第1章 C语言概括

 

第1章
C语言概括
1.
C源程序的结构特点
2.
书写程序时应总遵循的规则
3.
C语言的字符集
4.
C语言词汇
第2章
数据类型,运算符,表达式
1.
C语言的数据类型
2.
整型量
3.
实型量
4.
字符型量
字符常量包括字符常量和字符变量
5.
变量的初始值和类型转换
6.
基本运算符和表达式[1]
小结

 

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

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

C语言数据类型

1. C源程序的结构特点

  1. 一个C语言源程序可以由一个或多个源文件组成
  2. 每个源文件可由一个或多个函数组成
  3. 一个源程序不论由多少个文件组成,都只有一个且只有一个main函数,即主函数
  4. 源程序中可以有预处理命令(include
    命令仅为其中一种),预处理命令通常应放在源文件或源程序的最前面
  5. 每一个说明,每一个语句都必须以分号结尾。但预处理命令,函数头和花括号“{}”之后不能加分号
  6. 标识符,关键字之间必须至少加一个空格以示间隔。若已有明显的间隔符,也可不再加空格来间隔

常量与变量

原文:

2. 书写程序时应总遵循的规则

  1. 一个说明或一个语句占一行
  2. 用 {} 括起来的部分,通常表示了程序的某层次结构。{}
    一般与结构语句的第一个字母对齐,并单独占一行
  3. 低一层次的语句或说明可比高一层次的语句或说明缩进若干格后书写。

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

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

 

3. C语言的字符集

  • 字符是组成语言的最基本的元素,C语言字符集由字母,数字,空格,标点和特殊字符组成,在字符常量中,字符串常量和注释中还可以使用汉字或其它可表示的图形符号
  1. 字母:小写字母 a~z ,大写字母 A~Z

  2. 数字:0~9 共10个

  3. 空白符(空格符,制表符,换行符)只在字符常量和字符串常量中起作用。其它地方,只起间隔作用
  4. 标点和特殊字符

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

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

C语言各种数据类型及其在系统中占的字节和取值范围2009-08-21 09:53C语言包含5个基本数据类型: void, int, float, double, 和 char.   (另:C++ 定义了另外两个基本数据类型: bool 和 wchar_t.   一些基本数据类型能够被 signed, unsigned, short, 和 long 修饰  所以short,long等等都不算基本数据类型。  这是书上说的,所以C++是7种基本数据类型。    空值型是一种,但枚举型不算。原因就是枚举型可分的,所以不够基本。    不过不同的书也有不同的规定,比如C++Primer上就说是bool,char,wchar_t,short,int,long,float,double,long double和void,这个暂时没有定论。)    ============================================================    基本类型包括字节型(char)、整型(int)和浮点型(float/double)。    定义基本类型变量时,可以使用符号属性signed、unsigned(对于char、int),和长度属性short、long(对    于int、double)对变量的取值区间和精度进行说明。    下面列举了Dev-C++下基本类型所占位数和取值范围:    符号属性 长度属性 基本型 所占位数 取值范围 输入符举例 输出符举例        -- -- char                            8 -2^7 ~ 2^7-1 %c %c、%d、%u            signed -- char                    8 -2^7 ~ 2^7-1 %c %c、%d、%u            unsigned -- char                8 0 ~ 2^8-1 %c %c、%d、%u            [signed] short [int]            16 -2^15 ~ 2^15-1 %hd            unsigned short [int]           16 0 ~ 2^16-1 %hu、%ho、%hx            [signed] -- int                    32 -2^31 ~ 2^31-1 %d            unsigned -- [int]                 32 0 ~ 2^32-1 %u、%o、%x            [signed] long [int]              32 -2^31 ~ 2^31-1 %ld            unsigned long [int]             32 0 ~ 2^32-1 %lu、%lo、%lx            [signed] long long [int]       64 -2^63 ~ 2^63-1 %I64d            unsigned long long [int]      64 0 ~ 2^64-1 %I64u、%I64o、%I64x            -- -- float                            32 +/- 3.40282e+038 %f、%e、%g            -- -- double                        64 +/- 1.79769e+308 %lf、%le、%lg %f、%e、%g            -- long double                    96 +/- 1.79769e+308 %Lf、%Le、%Lg    几点说明:    1. 注意! 表中的每一行,代表一种基本类型。“[]”代表可省略。        例如:char、signed char、unsigned char是三种互不相同的类型;            int、short、long也是三种互不相同的类型。            可以使用C++的函数重载特性进行验证,如:            void Func(char ch) {}            void Func(signed char ch) {}            void Func(unsigned char ch) {}            是三个不同的函数。    2. char/signed char/unsigned char型数据长度为1字节;        char为有符号型,但与signed char是不同的类型。            注意! 并不是所有编译器都这样处理,char型数据长度不一定为1字节,char也不一定为有符号型。    3. 将char/signed char转换为int时,会对最高符号位1进行扩展,从而造成运算问题。        所以,如果要处理的数据中存在字节值大于127的情况,使用unsigned char较为妥当。            程序中若涉及位运算,也应该使用unsigned型变量。    4. char/signed char/unsigned char输出时,使用格式符%c(按字符方式);        或使用%d、%u、%x/%X、%o,按整数方式输出;            输入时,应使用%c,若使用整数方式,Dev-C++会给出警告,不建议这样使用。    5. int的长度,是16位还是32位,与编译器字长有关。        16位编译器(如TC使用的编译器)下,int为16位;32位编译器(如VC使用的编译器cl.exe)下,int为32            位。    6. 整型数据可以使用%d(有符号10进制)、%o(无符号8进制)或%x/%X(无符号16进制)方式输入输出。        而格式符%u,表示unsigned,即无符号10进制方式。    7. 整型前缀h表示short,l表示long。        输入输出short/unsigned short时,不建议直接使用int的格式符%d/%u等,要加前缀h。            这个习惯性错误,来源于TC。TC下,int的长度和默认符号属性,都与short一致,            于是就把这两种类型当成是相同的,都用int方式进行输入输出。    8. 关于long long类型的输入输出:        "%lld"和"%llu"是Linux下gcc/g++用于long long int类型(64 bits)输入输出的格式符。            而"%I64d"和"%I64u"则是Microsoft VC++库里用于输入输出__int64类型的格式说明。            Dev-C++使用的编译器是Mingw32,Mingw32是x86-win32 gcc子项目之一,编译器核心还是linux下的gcc。            进行函数参数类型检查的是在编译阶段,gcc编译器对格式字符串进行检查,显然它不认得"%I64d",            所以将给出警告“unknown conversion type character `I' in format”。对于"%lld"和"%llu",gcc理            所当然地接受了。            Mingw32在编译期间使用gcc的规则检查语法,在连接和运行时使用的却是Microsoft库。            这个库里的printf和scanf函数当然不认识linux gcc下"%lld"和"%llu",但对"%I64d"和"%I64u",它则是            乐意接受,并能正常工作的。    9. 浮点型数据输入时可使用%f、%e/%E或%g/%G,scanf会根据输入数据形式,自动处理。        输出时可使用%f(普通方式)、%e/%E(指数方式)或%g/%G(自动选择)。    10. 浮点参数压栈的规则:float(4 字节)类型扩展成double(8 字节)入栈。        所以在输入时,需要区分float(%f)与double(%lf),而在输出时,用%f即可。            printf函数将按照double型的规则对压入堆栈的float(已扩展成double)和double型数据进行输出。            如果在输出时指定%lf格式符,gcc/mingw32编译器将给出一个警告。    11. Dev-C++(gcc/mingw32)可以选择float的长度,是否与double一致。    12. 前缀L表示long(double)。        虽然long double比double长4个字节,但是表示的数值范围却是一样的。            long double类型的长度、精度及表示范围与所使用的编译器、操作系统等有关。        ====================================================================  (一)32位平台:   分为有符号型与无符号型。   有符号型:   short 在内存中占两个字节,范围为-2^15~(2^15-1)   int 在内存中占四个字节,范围为-2^31~(2^31-1)   long在内存中占四个字节,范围为-2^31~2^31-1   无符号型:最高位不表示符号位   unsigned short 在内存中占两个字节,范围为0~2^16-1   unsigned int 在内存中占四个字节,范围为0~2^32-1   unsigned long在内存中占四个字节,范围为0~2^32-1   实型变量:   分单精度 float 和双精度 double 两种形式:   float:占四个字节,提供7~8位有效数字。   double: 占八个字节,提供15~16位有效数字。     (二)16位平台:   1)整型(基本型):类型说明符为int,在内存中占2个字节。   2)短整型:类型说明符为short int或short。所占字节和取值范围均与整型(基本型)相同。   3)长整型:类型说明符为long int或long,在内存中占4个字节。   无符号型:类型说明符为unsigned。   无符号型又可与上述三种类型匹配而构成:   各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。   实型变量:   分为单精度(float型)、双精度(double型)和长双精度(long double型)三类。  单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。   双精度型占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。   长双精度型16 个字节(128位)内存空间,可提供18-19位有效数字。  ============================================================================  C语言中5种基本数据类型的存储空间长度的排列顺序:  char = signed char = unsigned char < short int = unsigned short int <= int = unsigned int <= long int = unsigned long int  <= long long int = unsigned long long int  float <= double <= long double  用short修饰int时,short int表示短整型,占2字节的数据位.用long修饰int时,long int表示长整型,占4字节的数据位,在vc++6.0中int的数据类型也是占用了4字节的数据位,  那么应用int型与long型有什么区别呢? 下面就让我们来解答这个问题.我们知道现在的C++开发工具非常的多,int型在不同的系统中有可能占用的字节数会不一样, 而short与long修饰的int型的字节数是固定的,任何支持标准C++编译系统中都是如此.所以如果需要编写可移植性好的程序,应该将整型数据声明为short与long修饰的int型。





----------------------------------------------------------------------------------------
在C语言中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。

4. C语言词汇

  • 六类:标识符,关键字,运算符,分隔符,常量,注释符
  1. 标识符:在程序中使用的变量,函数名,标号等统称为标识符。除库函数的函数名由系统定义外,其余都由用户定义。C
    规定,标识符只能是字母(A~Z,a~z)、数字(0~9)、下划线()组成的字符串,并且第一个字符必须是字母或者下划线(总之不能是数字)

  2. 关键字:是由C语言规定的具有特定意义的字符串,通常也称为保留字。用户定义的标识符不应与关键字同名
    1) 类型说明符:用于定义、说明变量、函数或其它数据结构的类型;如 int
    double等
    2) 语句定义符:用于表示一个语句的功能;if else 条件语句
    3) 预处理命令字:用于表示一个预处理命令; include等

  3. 运算符:C语言中含有相当丰富的运算符。运算符与变量,函数一起组成表达式,表示各种运算功能。运算符由一个或多个字符组成
  4. 分隔符:有逗号和空格两种。逗号主要用在类型说明和函数参数表中,分隔各个变量。空格多用于语句各单词之间,做间隔符
  5. 常量:C语言中使用的常量可分为数字常量,字符常量,字符串常量,符号常量,转义字符等多种
  6. 注释符:“/* */” 多行注释 # 单行注释

整型数据

1.基本数据类型

第2章 数据类型,运算符,表达式

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

  基本数据类型最主要的特点是,其值不可以再分解为其它类型。也就是说,基本数据类型是自我说明的。

1. C语言的数据类型

  • 可分为:基本数据类型,构造数据类型,指针类型,空类型
  1. 基本数据类型:其值不可以再分解其他类型,
  2. 构造数据类型:是根据已定义一个或多个数据类型用构造的方法来定义的。一个构造类型的值可以分解成多个“成员”或“元素”。每个成员都是一个基本数据类型或又是一个构造类型。构造类型:数组类型,结构类型,联合类型
  3. 指针类型:其值用来表示某个量在内存存储器中的地址
  4. 空类型:在调用函数值时,通常应向调用者返回一个函数值,类型说明符为:void

对于基本数据类型量,按其取值是否可以改变分为变量和常量;在程序执行中,其值不发生改变的量称为常量,反之;可分为:整型常量,整型变量,浮点常量,浮点变量,字符常量,字符变量,枚举常量,枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用

实型数据

  • 十进制数形式:由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)

2.构造数据类型构造数据类型

2. 整型量

  • 整型量包含整型常量、整型变量。整型常量就是整常数:八进制,十六进制,十进制
    二进制到八进制转换
    1 100 011 100 110
    1 4 3 4 6
    二进制到十六进制转换:
    1 1000 1110 0110
    1 8 E 6
  1. 整型常量
    1)
    八进制整常数八进制整常数必须为0开头,即以0作为八进制数的前缀。数码取值为0~7,八进制通常是无符号数
    015(十进制为13) 0101(65)
    2) 十六进制整常数的前缀为0X或0x。数码取值 0~9,A~F 或 a~f
    0X2A(十进制13) 0XA0(160)
    3) 十进制整常数没有前缀。数码取值 0~9

十进制无符号整常数的范围为 0~65535 有符号数为 -32768~32767 ;
八进制无符号数的表示范围为 0~0177777 ; 十六进制无符号数的表示范围为
0X0~0XFFFF 或 0x0~0xFFFF
如果使用的数据超过了上述范围,就必须用长整型数来表示。长整型数是用后缀
“L” 或 “l”
十进制长整常数 158L (十进制为158) 358000L(十进制为 -358000)
八进制长整常数 012L (十进制为 10) 077L (十进制为 63)
十六进制进制长整常数 0X15L (十进制为 21) 0X10000L (十进制为 65536)
整型常数的无符号数的后缀为 “U” 或 “u”

  1. 整型变量
    1) 基本型:int 在内存中占 2 个字节,其取值为基本整常数
    -32768~32768
    2) 短整量:short int 同基本型 -32768~32768
    3) 长整型:long int 或 long 在内存中占4个字节,其取值为长整常数
    -32768~32768
    4) 无符号型:unsigned
  • 变量说明的一般形式:类型说明符 变量名称标识符 …:

<wiz_code_mirror>

 

 

 

 

 

 1 int a, b, c // (a,b,c 为整型变量) 2 long x, y // (x,y 为长整型变量) 

 

 

  • 注意:
    1.允许在一个类型说明符后,说明多个相同类型的变量。各变量之间用逗号
    间隔,类型说明符与变量名之间至少用一个空格间隔
    2.最后一个变量名之后必须以“;”号结尾
    3.变量说明必须在变量使用之前,一般放在函数体的开头部分

实型变量

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

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

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

  是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。在C语言中,构造类型有以下几种:
·数组类型 ·结构类型 ·联合类型

3. 实型量

  1. 实型常量:实型也称为 浮点型;实型常量也称为实数或者
    浮点数;十进制数形式和指数形式
    1) 十进制数形式:由数码 0~9 和小数点组成
    2)
    指数形式:由十进制数,加阶码标志“e”或“E”以及阶码组成(其一般形式为a E
    n (a为十进制数,n为十进制整数)其值为 a10,n 如: 2.1E5
    (等于2.1
    10,5))
  2. 实型变量:单精度型和双精度型
    1) 单精度说明符:float
    在C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字;
    2) 双精度说明符:double
    双精度型占8个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字
    3) 实型变量说明的格式和书写规格与整型相同

字符变量

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

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

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

3.指针类型

4. 字符型量

  • ##### 字符常量包括字符常量和字符变量
  1. 字符常量:是用单引号括起来的一个字符。’a’ ‘b’ ‘+’ ‘?’
    都是合法的字符常量
    1) 字符常量只能用单引号括起来,不能用双引号或其他括号
    2) 字符常量只能是个单个字符,不能是字符串
    3) 字符可以是字符集任意字符,但数字被定义为字符后就不能参入数值运算
  2. 转义字符:转义字符以反斜线””开头,后跟一个或几个字符
转义字符 转义字符的意义
n 回车换行
t 横向跳到下一制表位置
v 竖向跳格
b 退格
r 回车
f 走纸换页
反斜线符""
单引号符
a 鸣铃
ddd 1~3位八进制数所代表的字符
xhh 1~2位十六进制数所代表的字符
  1. 字符变量:的取值是字符常量,即单个字符。字符变量的类型说明符是
    char。
    1)
    如x的十进制ASCII码是120,y的十进制ASCII码是121。对字符变量a,b赋予’x’和’y’值:
    a=’x’;b=’y’;实际上是在a,b两个单元内存放120和121的二进制代码: a 0 1
    1 1 1 0 0 0
         b 0 1 1 1 1 0 0 1
  2. 字符串常量:是由一对双引号括起的字符序列,”charn”
    “REBT”;字符串常量和字符常量是不同的量:
    1) 字符常量由单引号 括起来,字符串常量由双引号 括起来
    2)
    字符常量只能是单个字符,字符串常量则可以含一个或多个字符
    3)
    可以把一个字符常量赋值一个字符变量,但不能把一个字符串常量赋予一个字符变量;但是可以用一个字符数组来存放一个字符串常量
    4) 字符常量占一个字节
    的内存空间,字符串常量占的内存字节数等于字符串字节数加1,增加的一个字节存放字符””,这是字符串结束的标志
  3. 符号常量:可以用一个标识符来表示一个常量,在使用前必须先定义,其形式:
    #define 标识符 常量(宏定义命令)

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

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

 
 指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同
的量,因此不能混为一谈。4.空类型在调用函数值时,通常应向调用者返回一个函数值。这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中
给以说明,例如在例题中给出的max函数定义中,函数头为: int max(int a,int
b);其中“int
”类型说明符即表示该函数的返回值为整型量。又如在例题中,使用了库函数
sin,由于系统规定其函数返回值为双精度浮点型,因此在赋值语句s=sin
(x);中,s
也必须是双精度浮点型,以便与sin函数的返回值一致。所以在说明部分,把s说明为双精度浮点型。但是,也有一类函数,调用后并不需要向调用者返回函数
值,
这种函数可以定义为“空类型”。其类型说明符为void。在第五章函数中还要详细介绍。在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。其余
类型在以后各章中陆续介绍。

5. 变量的初始值和类型转换

  1. 变量赋初值:常常需要对变量赋初值,以便使用变量;
    类型说明符 变量1 = 值1, 变量2 = 值2···;

<wiz_code_mirror>

 

 

 

 

 

1 int a = 4, b = 2;
2 char = ch1 = 's', ch2 = 'a';
3 int a = b = c = 4;        // error 不允许连续赋值

 

 

 

  1. 变量类型的转换:变量的数据类型是可以转换的,自动转换 和
    强制转换
    1)
    自动转换:发生在不同数据类型的量在混合运算时,由编译系统自动完成,规则:
    · 若参与运算量的类型不同,则先转换成统一类型,然后进行运算
    · 转换按数据长度增加的方向进行,以保证精度不降低。如
    int型和long型运算时,先把int量转成long型后在进行运算
    ·
    所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要转成double型,再做运算
    · char型和short型参与运算时,必须先转换成int型
    ·
    在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型,如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入
    2) 强制转换:是通过类型转换来实现的,一般形式:(类型说明符)
    (表达式)
    其功能是把表达式的运算结果强制转换成类型说明符所表示的类型;
    例如:(float) a 把a转换为实型; (int) (x+y)
    把x+y的结果运算结果强制转换为整型
    · 类型说明符和表达式都必须加括号(单个变量可以不加括号),
    ·
    无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型

各类数据类型的混合运算

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

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

  对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过
程中,其值不发生改变的量称为常量,取值可变的量称为变量。它们可与数据类型结合起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常
量、字符变量、枚举常量、枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先说明后使用。

6. 基本运算符和表达式[1]

  1. 优先级和结合性:运算符的运算优先级分为15级,优先级较高的先于优先级低的进行运算,而在一个运算量两则的运算符优先级相同时,则按运算符的结合性:即左结合性(自左向右)
    右结合性(自右向左)
  2. 算术运算符和算术表达式基本的算术运算符
    1) 加法运算符”+”
    :双目运算符,即应有两个量参与加法运算,具有右结合性
    2) 减法运算符”-“
    :双目运算符,但’-‘也可作为负值运算符,此时为单目运算符,具有左结合性
    3) 乘法运算符” * “ :双目运算符,具有左结合性
    4) 除法运算符”/”
    :双目运算符,参与运算量均为整型时,结果也为整型,舍去小数;如果运算量中有一个是实型,则结果位双精度实型,具有左结合性
    5) 求余运算符”%”
    :双目运算符,要求参与运算的量均为整型,求余运算的结果等于两数相除后的余数,具有左结合性
  3. 自增自减运算符:自增1运算符记为”++”,其功能是使变量的值自增1,自减1运算符记为”–“,其功能是使变量值自减1;自增1,自减1运算符均为单目运算符,具有右结合性
    · ++i i自增1后再参与其它运算
    · –i i自减1后再参与其它运算
    · i++ i参与运算后,i的值再自增1
    · i– i参与运算后,i的值再自减1
  4. 算术表达式:由算术运算符和括号连接起来的式子,例如:
    (a2)/c (x+r)8-(a+b)/7  ++i sin(x)+sin(y)  (++i)-(j++)+(k–)

  5. 赋值运算符和赋值表达式:简单的赋值运算符记为”=”。由
    “=”连接的式子称为赋值表达式,形式:变量 =
    表达式;赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右结合性。因此
    a=b=c=5 可理解为 a=(b=(c=5))

  6. 复合赋值符及表达式:在赋值符”=”之前加上其它双目运算符可构成复合赋值符;构成复合赋值表达式的形式:变量
    双目运算符 = 表达式
    它等效于 变量 = 变量 运算符 表达式

  7. 逗号运算符:”,”
    其功能是把两个表达式连接起来组成一个表达式,一般形式:表达式1,表达式2···

强制类型转换

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

整型量

小结

  • C的数据类型:
    基本类型 构造类型 指针类型 空类型
  • 基本类型的分类及特点:
类型说明符 字节 数值范围
字符型 char 1 C字符集
基本整型 int 2 -32768~32767
短整型 short int 2 -32768~32767
长整型 long int 4 -214783648~214783647
无符号型 unsigned 2 0~65535
无符号长整型 unsigned long 4 0~4294967295
单精度实型 float 4 3/4E-38~3/4E+38
双精度实型 double 8 1/7E-308~1/7E+308
  • 常量后缀:
    L或l 长整型
    U或u 无符号数
    F或f 浮点数
  • 常量类型:
    整数 长整数 无符号数 浮点数 字符 字符串 符号常数 转义字符
  • 数据类型转换:
    ·
    自动转换:在不同类型数据的混合运算中,由系统自动实现转换,由少字节类型向多字节类型转换。不同类型的量相互赋值时也由系统自动进行转换,把赋值号右边的类型转换为左边的类型
    · 强制转换:由强制转换运算符完成转换
  • 运算符优先级和结合性:
    一般而言,单目运算符优先级较高,赋值运算符优先级低;算术运算符优先级较高,关系和逻辑运算符优先级较低;多数运算符具有左结合性,单目运算符,三目运算符、赋值
  • 表达式:
    是由运算符连接常量、变量、函数所组成的式子。每个表达式都有一个指和类型。表达式求值按运算符的优先级和结合性所规定的顺序进行~~~~

整型量包括整型常量、整型变量。整型常量就是整常数。在C语言中,使用的整常数有八进制、十六进制和十进制三种。

整型常量

1.八进制整常数八进制整常数必须以0开头,即以0作为八进制数的前缀。数码取值为0~7。八进制数通常是无符号数。
以下各数是合法的八进制数:
015(十进制为13) 0101(十进制为65) 0177777(十进制为65535)
以下各数不是合法的八进制数: 256(无前缀0)
03A2(包含了非八进制数码) -0127(出现了负号)

2.十六进制整常数
十六进制整常数的前缀为0X或0x。其数码取值为0~9,A~F或a~f。
以下各数是合法的十六进制整常数: 0X2A(十进制为42)  0XA0
(十进制为160)  0XFFFF (十进制为65535)
以下各数不是合法的十六进制整常数: 5A (无前缀0X)  0X3H
(含有非十六进制数码)

3.十进制整常数 十进制整常数没有前缀。其数码为0~9。
以下各数是合法的十进制整常数: 237 -568 65535 1627
以下各数不是合法的十进制整常数: 023 (不能有前导0) 23D
(含有非十进制数码)

在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。

4.整型常数的后缀在16位字长的机器上,基本整型的长度也为
16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0~65535,有符号数为-32768~+32767。八进制无符号数的表示范围
为0~0177777。十六进制无符号数的表示范围为0X0~0XFFFF或0x0~0xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表
示。长整型数是用后缀“L”或“l”来表示的。例如: 十进制长整常数 158L
(十进制为158) 358000L (十进制为-358000) 八进制长整常数 012L (十进制为10)
077L (十进制为63) 0200000L (十进制为65536) 十六进制长整常数 0X15L
(十进制为21) 0XA5L (十进制为165) 0X10000L (十进制为65536)
长整数158L和基本整常数158
在数值上并无区别。但对158L,因为是长整型量,C编译系统将为它分配4个字节存储空间。而对158,因为是基本整型,只分配2
个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。例如:
358u,0x38Au,235Lu
均为无符号数。前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。

整型变量

整型变量可分为以下几类: 1.基本型
类型说明符为int,在内存中占2个字节,其取值为基本整常数。 2.短整量
类型说明符为short int或short’C110F1。所占字节和取值范围均与基本型相同。
3.长整型 类型说明符为long int或long
,在内存中占4个字节,其取值为长整常数。 4.无符号型
类型说明符为unsigned。 无符号型又可与上述三种类型匹配而构成:
(1)无符号基本型 类型说明符为unsigned int或unsigned。 (2)无符号短整型
类型说明符为unsigned short (3)无符号长整型 类型说明符为unsigned long
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。
下表列出了Turbo C中各类整型量所分配的内存字节数及数的表示范围。
类型说明符    数的范围     分配字节数 int
      -32768~32767     ■■ short int    -32768~32767
    ■■ signed int    -32768~32767     ■■ unsigned int  
0~65535        ■■ long int  -2147483648~2147483647  ■■■■
unsigned long  0~4294967295     ■■■■ 整型变量的说明
变量说明的一般形式为: 类型说明符 变量名标识符,变量名标识符,…;
例如: int a,b,c; (a,b,c为整型变量) long x,y; (x,y为长整型变量) unsigned
p,q; (p,q为无符号整型变量)

在书写变量说明时,应注意以下几点:
1.允许在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。
2.最后一个变量名之后必须以“;”号结尾。
3.变量说明必须放在变量使用之前。一般放在函数体的开头部分。     x,
y是长整型变量,a,
b是基本整型变量。它们之间允许进行运算,运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不同类型的量可以参与运算并
相互赋值。其中的类型转换是由编译系统自动完成的。有关类型转换的规则将在以后介绍。

实型量

实型常量

实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。它有二种形式:
十进制数形式指数形式 1.十进制数形式 由数码0~
9和小数点组成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的实数。
2.指数形式
由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。其一般形式为a
E n (a为十进制数,n为十进制整数)其值为 a*10,n 如: 2.1E5
(等于2.1*10,5), 3.7E-2 (等于3.7*10,)-2*) 0.5E7 (等于0.5*10,7),
-2.8E-2 (等于-2.8*10,)-2*)以下不是合法的实数 345 (无小数点) E7
(阶码标志E之前无数字)  -5 (无阶码标志) 53.-E3 (负号位置不对) 2.7E
(无阶码)
标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如356f和356.是等价的。例2.2说明了这种情况:
void main() { printf(“%fn%fn”,356.,356f); } void
指明main不返回任何值 利用printf显示结果 结束

实型变量

实型变量分为两类:单精度型和双精度型, 其类型说明符为float
单精度说明符,double 双精度说明符。在Turbo
C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。双精度型占8
个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。
实型变量说明的格式和书写规则与整型相同。 例如: float x,y;
(x,y为单精度实型量) double a,b,c; (a,b,c为双精度实型量)
实型常数不分单、双精度,都按双精度double型处理。 void main(){ float a;
double b; a=33333.33333; b=33333.33333333333333;
printf(“%fn%fn”,a,b); } 此程序说明float、double的不同 a ■■■■ b
■■■■■■■■ a<—33333.33333 b<—33333.33333333333;; 显示程序结果
此程序说明float、double的不同 float a; double b; a=33333.33333;
b=33333.33333333333333; 从本例可以看出,由于a
是单精度浮点型,有效位数只有七位。而整数已占五位,故小数二位后之后均为无效数字。b
是双精度型,有效位为十六位。但Turbo C
规定小数后最多保留六位,其余部分四舍五入。

字符型量

字符型量包括字符常量和字符变量。

字符常量
字符常量是用单引号括起来的一个字符。例如’a’,’b’,’=’,’+’,’?’都是合法字符常量。在C语言中,字符常量有以下特点:
1.字符常量只能用单引号括起来,不能用双引号或其它括号。
2.字符常量只能是单个字符,不能是字符串。
3.字符可以是字符集中任意字符。但数字被定义为字符型之后就
不能参与数值运算。如’5’和5 是不同的。’5’是字符常量,不能参与运算。

转义字符
转义字符是一种特殊的字符常量。转义字符以反斜?quot;”开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符原有的意义,故称“转义”
字符。例如,在前面各例题printf函数的格式串中用到的“n”就是一个转义字符,其意义是“回车换行”。转义字符主要用来表示那些用一般字符不便于
表示的控制代码。 常用的转义字符及其含义 转义字符  转义字符的意义 n
     回车换行 t      横向跳到下一制表位置 v
     竖向跳格 b      退格 r      回车 f    
 走纸换页 \      反斜线符”” ‘      单引号符 a
     鸣铃 ddd     1~3位八进制数所代表的字符 xhh
    1~2位十六进制数所代表的字符
广义地讲,C语言字符集中的任何一个字符均可用转义字符来表示。表2.2中的ddd和xhh正是为此而提出的。ddd和hh分别为八进制和十六进制的
ASCII代码。如101表示字?quot;A”
,102表示字母”B”,134表示反斜线,XOA表示换行等。转义字符的使用
void main() { int a,b,c; a=5; b=6; c=7; printf(“%dnt%d %dn %d
%dtb%dn”,a,b,c,a,b,c); } 此程序练习转义字符的使用
a、b、c为整数 5->a,6->b,7->c 调用printf显示程序运行结果
printf(“%dnt%d %dn %d %dtb%dn”,a,b,c,a,b,c);
程序在第一列输出a值5之后就是“n”,故回车换行;接着又是“t”,于是跳到下一制表位置(设制表位置间隔为8),再输出b值6;空二格再输出c
值7后又是”n”,因此再回车换行;再空二格之后又输出a值5;再空三格又输出b的值6;再次后”t”跳到下一制表位置(与上一行的6
对齐),但下一转义字符“b”又使退回一格,故紧挨着6再输出c值7。

字符变量
字符变量的取值是字符常量,即单个字符。字符变量的类型说明符是char。字符变量类型说明的格式和书写规则都与整型变量相同。
例如: char a,b;
每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在变量的内存单元之中的。如x的
十进制ASCII码是120,y的十进制ASCII码是121。对字符变量a,b赋予’x’和’y’值:
a=’x’;b=’y’;实际上是在a,b两个单元内存放120和121的二进制代码: a 0 1 1 1
1 0 0 0 b 0 1 1 1 1 0 0 1 所以也可以把它们看成是整型量。
C语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时,
允许把字符变量按整型量输出,也允许把整型量按字符量输出。
整型量为二字节量,字符量为单字节量,当整型量按字符型量处理时,
只有低八位字节参与处理。 main(){ char a,b; a=120; b=121;
printf(“%c,%cn%d,%dn”,a,b,a,b); } a ■ b ■ a <– 120 b <— 121
显示程序结果 char a,b; a=120; b=121;
本程序中说明a,b为字符型,但在赋值语句中赋以整型值。从结果看,a,b值的输出形式取决于printf函数格式串中的格式符,当格式符为”c”时,对应输出的变量值为字符,当格式符为”d”时,对应输出的变量值为整数。
void main(){ char a,b; a=’x’; b=’y’; a=a-32; b=b-32;
printf(“%c,%cn%d,%dn”,a,b,a,b); } a,b被说明为字符变量并赋予字符值
把小写字母换成大写字母 以整型和字符型输出
本例中,a,b被说明为字符变量并赋予字符值,C语言允许字符变量参与数值运算,即用字符的ASCII
码参与运算。由于大小写字母的ASCII
码相差32,因此运算后把小写字母换成大写字母。然后分别以整型和字符型输出。

字符串常量 字符串常量是由一对双引号括起的字符序列。例如: “CHINA” ,”C
program: , “$12.5”
等都是合法的字符串常量。字符串常量和字符常量是不同的量。它们之间主要有以下区别:
1.字符常量由单引号括起来,字符串常量由双引号括起来。
2.字符常量只能是单个字符,字符串常量则可以含一个或多个字符。
3.可以把一个字符常量赋予一个字符变量,但不能把一个字符串常量赋予一个字符变量。在C语言中没有相应的字符串变量。
这是与BASIC
语言不同的。但是可以用一个字符数组来存放一个字符串常量。在数组一章内予以介绍。
4.字符常量占一个字节的内存空间。字符串常量占的内存字节数等于字符串中字节数加1。增加的一个字节中存放字符””(ASCII码为0)。这是字符
串结束的标志。例如,字符串 “C program”在内存中所占的字节为:C
program。字符常量’a’和字符串常量”a”虽然都只有一个字符,但在内存中的情况是不同的。
‘a’在内存中占一个字节,可表示为:a
“a”在内存中占二个字节,可表示为:a符号常量

符号常量
在C语言中,可以用一个标识符来表示一个常量,称之为符号常量。符号常量在使用之前必须先定义,其一般形式为:
#define 标识符 常量
其中#define也是一条预处理命令(预处理命令都?quot;#”开头),称为宏定义命令(在第九章预处理程序中将进一步介绍),其功能是把该标识符
定义为其后的常量值。一经定义,以后在程序中所有出现该标识符的地方均代之以该常量值。习惯上符号常量的标识符用大写字母,变量标识符用小写字母,以示区
别。 #define PI 3.14159 void main(){ float s,r; r=5; s=PI*r*r;
printf(“s=%fn”,s); } 由宏定义命令定义PI 为3.14159
s,r定义为实数 5->r PI*r*r->s 显示程序结果 float
s,r; r=5; s=PI*r*r; 本程序在主函数之前由宏定义命令定义PI
为3.14159,在程序中即以该值代替PI
。s=PI*r*r等效于s=3.14159*r*r。应该注意的是,符号常量不是变量,它所代表的值在整个作用域内不能再改变。也就是说,在程序中,不
能再用赋值语句对它重新赋值。

变量的初值和类型转换

变量赋初值
在程序中常常需要对变量赋初值,以便使用变量。语言程序中可有多种方法,在定义时赋以初值的方法,这种方法称为初始化。在变量说明中赋初值的一般形式为:
类型说明符 变量1= 值1,变量2= 值2,……; 例如: int a=b=c=5; float
x=3.2,y=3f,z=0.75; char ch1=’K’,ch2=’P’;
应注意,在说明中不允许连续赋值,如a=b=c=5是不合法的。 void main(){ int
a=3,b,c=5; b=a+c; printf(“a=%d,b=%d,c=%dn”,a,b,c); }
a<—3,b<–0,c<—5 b<–a+c 显示程序运行结果

变量类型的转换 变量的数据类型是可以转换的。转换的方法有两种,
一种是自动转换,一种是强制转换。

自动转换
自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3.所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必须先转换成int型。
5.在赋值运算中,赋值号两边量的数据类型不同时,
赋值号右边量的类型将转换为左边量的类型。
如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,
丢失的部分按四舍五入向前舍入。图2 1表示了类型自动转换的规则。 void
main(){ float PI=3.14159; int s,r=5; s=r*r*PI; printf(“s=%dn”,s); }
PI<–3.14159 s<–0,r<–5 s<–r*r*PI 显示程序运行结果 float
PI=3.14159; int s,r=5; s=r*r*PI;
本例程序中,PI为实型;s,r为整型。在执行s=r*r*PI语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分。

强制类型转换 强制类型转换是通过类型转换运算来实现的。其一般形式为:
(类型说明符) (表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。例如:
(float) a 把a转换为实型(int)(x+y)
把x+y的结果转换为整型在使用强制转换时应注意以下问题:
1.类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2.无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。
main(){ float f=5.75; printf(“(int)f=%d,f=%fn”,(int)f,f); }
f<–5.75 将float f强制转换成int f float
f=5.75;printf(“(int)f=%d,f=%fn”,(int)f,f);
本例表明,f虽强制转为int型,但只在运算中起作用,
是临时的,而f本身的类型并不改变。因此,(int)f的值为
5(删去了小数)而f的值仍为5.75

  程序中使用的各种变量都应预先加以定义,即先定义,后使用。对变量的定义可以包括三个方面:数据类型、存储类型、作用域。

用户存储空间可以分为三个部分:

  1. 程序区;
  2. 静态存储区;
  3. 动态存储区;

从变量的作用域(即从空间)角度来分,可以分为全局变量和局部变量。

从变量值存在的作时间(即生存期)角度来分,可以分为静态存储方式和动态存储方式。
    静态存储方式:是指在程序运行期间分配固定的存储空间的方式。
   
动态存储方式:是在程序运行期间根据需要进行动态的分配存储空间的方式。

 
全局变量全部存放在静态存储区,在程序开始执行时给全局变量分配存储区,程序行完毕就释放。在程序执行过程中它们占据固定的存储单元,而不动态地进行分配和释放;

  动态存储区存放以下数据:

  1. 函数形式参数;
  2. 自动变量(未加static声明的局部变量);
  3. 函数调用实的现场保护和返回地址;

对以上这些数据,在函数开始调用时分配动态存储空间,函数结束时释放这些空间。在c语言中,每个变量和函数有两个属性:数据类型和数据的存储类别。

为了提高效率,C语言允许将局部变量得值放在CPU中的寄存器中,这种变量叫“寄存器变量”,用关键字register作声明。

PS:

  1. 只有局部自动变量和形式参数可以作为寄存器变量;
  2. 一个计算机系统中的寄存器数目有限,不能定义任意多个寄存器变量;
  3. 局部静态变量不能定义为寄存器变量。

     
    外部变量(即全局变量)是在函数的外部定义的,它的作用域为从变量定义处开始,到本程序文件的末尾。如果外部变量不在文件的开头定义,其有效的作用范围只限于定义处到文件终了。如果在定义点之前的函数想引用该外部变量,则应该在引用之前用关键字extern对该变量作“外部变量声明”。表示该变量是一个已经定义的外部变量。有了此声明,就可以从“声明”处起,合法地使用该外部变量。

  数据类型

按被定义变量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。

图片 1

You can leave a response, or trackback from your own site.

Leave a Reply

网站地图xml地图