C语言———初识C语言

1、常量与变量

1 常量

  • 在程序运行过程中,其值不能被改变的量
  • 常量一般出现在表达式或赋值语句中
整型常量100,200,-100,0
实型常量3.14 , 0.125,-3.123
字符型常量‘a’,‘b’,‘1’,‘\n’
字符串常量“a”,“ab”,“12356”

字符串:

C语言中,用双引号引着的一串字符,称之为字符串。一定有一个结束标记'\0'

  • char ch = ‘A’; 一个字节
  • "abc" --> 'a''b''c''\0'
  • ‘a’ 不等价 “a”(“a”等价于'a''\0')

2 变量

1) 变量

变量:在程序运行过程中,其值可以改变; 变量在使用前必须先定义,定义变量前必须有相应的数据类型

标识符命名规则

  • 标识符不能是关键字
  • 标识符只能由字母、数字、下划线组成
  • 第一个字符必须为字母或下划线
  • 标识符中字母区分大小写

变量特点:

  • 变量在编译时为其分配相应的内存空间
  • 可以通过其名字和地址访问相应内存

2) 声明和定义区别

  • 声明变量不需要建立存储空间,如:extern int a;
  • 定义变量需要建立存储空间,如:int b;

2、整型:int

1 整型变量的定义和输出

打印格式含义
%d输出一个有符号的10进制int类型
%o(字母o)输出8进制的int类型
%x输出16进制的int类型,字母以小写输出
%X输出16进制的int类型,字母以大写输出
%u输出一个10进制的无符号数

2 short、int、long、long long占用空间

数据类型占用空间
short(短整型)2字节
int(整型)4字节
long(长整形)Windows为4字节,Linux为4字节(32位),8字节(64位)
long long(长长整形)8字节

注意:

  • 需要注意的是,整型数据在内存中占的字节数与所选择的操作系统有关。虽然 C 语言标准中没有明确规定整型数据的长度,但 long 类型整数的长度不能短于 int 类型, short 类型整数的长度不能长于 int 类型。
  • 当一个小的数据类型赋值给一个大的数据类型,不会出错,因为编译器会自动转化。但当一个大的类型赋值给一个小的数据类型,那么就可能丢失高位。
打印格式含义
%hd输出short类型
%d输出int类型
%ld输出long类型
%lld输出long long类型
%hu输出unsigned short类型
%u输出unsigned int类型
%lu输出unsigned long类型
%llu输出unsigned long long类型

3 有符号数和无符号数区别

有符号数:有符号数是最高位为符号位,0代表正数,1代表负数

无符号数:无符号数最高位不是符号位,而就是数的一部分,无符号数不可能是负数。

有符号和无符号整型取值范围

数据类型占用空间取值范围
short2字节-32768 到 32767 (-215 ~ 215-1)
int4字节-2147483648 到 2147483647 (-231 ~ 231-1)
long4字节-2147483648 到 2147483647 (-231 ~ 231-1)
unsigned short2字节0 到 65535 (0 ~ 216-1)
unsigned int4字节0 到 4294967295 (0 ~ 232-1)
unsigned long4字节0 到 4294967295 (0 ~ 232-1)

注意:当我们写程序要处理一个不可能出现负值的时候,一般用无符号数,这样可以增大数的表达最大值

3、字符型:char

1 字符变量的定义和输出

字符型变量用于存储一个单一字符,在 C 语言中用 char 表示,其中每个字符变量都会占用 1 个字节。在给字符型变量赋值时,需要用一对英文半角格式的单引号(' ')把字符括起来。

字符变量实际上并不是把该字符本身放到变量的内存单元中去,而是将该字符对应的 ASCII 编码放到变量的存储单元中。char的本质就是一个1字节大小的整型

#include <stdio.h>
 
int main()
{
        char ch = 'a';
        printf("sizeof(ch) = %u\n", sizeof(ch));
 
        printf("ch[%%c] = %c\n", ch); //打印字符
        printf("ch[%%d] = %d\n", ch); //打印‘a’ ASCII的值
 
        char A = 'A';
        char a = 'a';
        printf("a = %d\n", a);                //97
        printf("A = %d\n", A);        //65
 
        printf("A = %c\n", 'a' - 32); //小写a转大写A
        printf("a = %c\n", 'A' + 32); //大写A转小写a
 
        ch = ' ';
        printf("空字符:%d\n", ch); //空字符ASCII的值为32
        printf("A = %c\n", 'a' - ' '); //小写a转大写A
        printf("a = %c\n", 'A' + ' '); //大写A转小写a
 
        return 0;
}

2 ASCII对照表

ASCII值控制字符ASCII值字符ASCII值字符ASCII值字符
0NUT32(space)64@96
1SOH33!65A97a
2STX34"66B98b
3ETX35#67C99c
4EOT36$68D100d
5ENQ37%69E101e
6ACK38&70F102f
7BEL39,71G103g
8BS40(72H104h
9HT41)73I105i
10LF42*74J106j
11VT43+75K107k
12FF44,76L108l
13CR45-77M109m
14SO46.78N110n
15SI47/79O111o
16DLE48080P112p
17DCI49181Q113q
18DC250282R114r
19DC351383S115s
20DC452484T116t
21NAK53585U117u
22SYN54686V118v
23TB55787W119w
24CAN56888X120x
25EM57989Y121y
26SUB58:90Z122z
27ESC59;91[123{
28FS60<92/124|
29GS61=93]125}
30RS62>94^126`
31US63?95_127DEL

ASCII 码大致由以下两部分组成:

  • ASCII 非打印控制字符: ASCII 表上的数字 0-31 分配给了控制字符,用于控制像打印机等一些外围设备。
  • ASCII 打印字符:数字 32-126 分配给了能在键盘上找到的字符,当查看或打印文档时就会出现。数字 127 代表 Del 命令。

3 转义字符

转义字符含义ASCII码值(十进制)
\a警报007
\b退格(BS) ,将当前位置移到前一列008
\f换页(FF),将当前位置移到下页开头012
\n换行(LF) ,将当前位置移到下一行开头010
\r回车(CR) ,将当前位置移到本行开头013
\t水平制表(HT) (跳到下一个TAB位置)009
\v垂直制表(VT)011
\\代表一个反斜线字符"\"092
\'代表一个单引号(撇号)字符039
\"代表一个双引号字符034
\?代表一个问号063
\0数字0000
\ddd8进制转义字符,d范围0~73位8进制
\xhh16进制转义字符,h范围0~9,a~f,A~F3位16进制
#include <stdio.h>
 
int main()
{
        printf("abc");
        printf("\refg\n"); //\r切换到句首, \n为换行键
 
        printf("abc");
        printf("\befg\n");//\b为退格键, \n为换行键
 
        printf("%d\n", '\123');// '\123'为8进制转义字符,0123对应10进制数为83
        printf("%d\n", '\x23');// '\x23'为16进制转义字符,0x23对应10进制数为35
 
        return 0;
}

4、实型(浮点型):float、double

实型变量也可以称为浮点型变量,浮点型变量是用来存储小数数值。在C语言中, 浮点型变量分为两种: 单精度浮点数(float)、 双精度浮点数(double), 但是double型变量所表示的浮点数比 float 型变量更精确。

由于浮点型变量是由有限的存储单元组成的,因此只能提供有限的有效数字。在有效位以外的数字将被舍去,这样可能会产生一些误差。不以f结尾的常量是double类型,以f结尾的常量(如3.14f)是float类型。

#include <stdio.h>
 
int main()
{
        //传统方式赋值
        float a = 3.14f; //或3.14F
        double b = 3.14;
 
        printf("a = %f\n", a);
        printf("b = %lf\n", b);
 
        //科学法赋值
        a = 3.2e3f; //3.2*1000 = 3200,e可以写E
        printf("a1 = %f\n", a);
 
        a = 100e-3f; //100*0.001 = 0.1
        printf("a2 = %f\n", a);
 
        a = 3.1415926f;
        printf("a3 = %f\n", a); //结果为3.141593
 
        return 0;
}

5、进制

进制也就是进位制,是人们规定的一种进位方法。 对于任何一种进制—X进制,就表示某一位置上的数运算时是逢X进一位。 十进制是逢十进一,二进制就是逢二进一,以此类推,x进制就是逢x进位。

十进制二进制八进制十六进制
0000
1111
21022
31133
410044
510155
611066
711177
81000108
91001119
10101012A
11101113B
12110014C
13110115D
14111016E
15111117F
16100002010

1 二进制

二进制是计算技术中广泛采用的一种数制。二进制数据是用0和1两个数码来表示的数。它的基数为2,进位规则是“逢二进一”,借位规则是“借一当二”。

当前的计算机系统使用的基本上是二进制系统,数据在计算机中主要是以补码的形式存储的。

术语含义
bit(比特)一个二进制代表一位,一个位只能表示0或1两种状态。数据传输是习惯以“位”(bit)为单位。
Byte(字节)一个字节为8个二进制,称为8位,计算机中存储的最小单位是字节。数据存储是习惯以“字节”(Byte)为单位。
WORD(双字节)2个字节,16位
DWORD两个WORD,4个字节,32位
1b1bit,1位
1B1Byte,1字节,8位
1k,1K1024
1M(1兆)1024k, 1024*1024
1G1024M
1T1024G
1Kb(千位)1024bit,1024位
1KB(千字节)1024Byte,1024字节
1Mb(兆位)1024Kb = 1024 * 1024bit
1MB(兆字节)1024KB = 1024 * 1024Byte
  • 十进制转化二进制的方法:用十进制数除以2,分别取余数和商数,商数为0的时候,将余数倒着数就是转化后的结果。
  • 十进制的小数转换成二进制:小数部分和2相乘,取整数,不足1取0,每次相乘都是小数部分,顺序看取整后的数就是转化后的结果。

2 八进制

八进制,Octal,缩写OCT或O,一种以8为基数的计数法,采用0,1,2,3,4,5,6,7八个数字,逢八进1。一些编程语言中常常以数字0开始表明该数字是八进制。

3 十六进制

十六进制(英文名称:Hexadecimal),同我们日常生活中的表示法不一样,它由0-9,A-F组成,字母不区分大小写。与10进制的对应关系是:0-9对应0-9,A-F对应10-15。

4 C语言如何表示相应进制数

十进制以正常数字1-9开头,如123
八进制以数字0开头,如0123
十六进制以0x开头,如0x123
二进制C语言不能直接书写二进制数
#include <stdio.h>
 
int main()
{
        int a = 123;                //十进制方式赋值
        int b = 0123;                //八进制方式赋值, 以数字0开头
        int c = 0xABC;        //十六进制方式赋值
 
        //如果在printf中输出一个十进制数那么用%d,八进制用%o,十六进制是%x
        printf("十进制:%d\n",a );
        printf("八进制:%o\n", b);        //%o,为字母o,不是数字
        printf("十六进制:%x\n", c);
 
        return 0;
}

6、sizeof关键字

  • sizeof不是函数,所以不需要包含任何头文件,它的功能是计算一个数据类型的大小,单位为字节
  • sizeof的返回值为size_t。size_t类型在32位操作系统下是unsigned int,是一个无符号的整数
  • 使用方法:
      • 方法1: sizeof(类型名) -- sizeof(int)
      • 方法2: sizeof(变量名) --- int a = 20; sizeof(a)

7、计算机内存数值存储方式

1 原码

一个数的原码(原始的二进制码)有如下特点:

  • 最高位做为符号位,0表示正,为1表示负
  • 其它数值部分就是数值本身绝对值的二进制数
  • 负数的原码是在其绝对值的基础上,最高位变为1

下面数值以1字节的大小描述:

十进制数原码
+150000 1111
-151000 1111
+00000 0000
-01000 0000

原码表示法简单易懂,与带符号数本身转换方便,只要符号还原即可,但当两个正数相减或不同符号数相加时,必须比较两个数哪个绝对值大,才能决定谁减谁,才能确定结果是正还是负,所以原码不便于加减运算。

2 反码

  • 对于正数,反码与原码相同
  • 对于负数,符号位不变,其它部分取反(1变0,0变1)
十进制数反码
+150000 1111
-151111 0000
+00000 0000
-01111 1111

反码运算也不方便,通常用来作为求补码的中间过渡

3 补码

在计算机系统中,数值一律用补码来存储。

补码特点

  • 对于正数,原码、反码、补码相同
  • 对于负数,其补码为它的反码加1
  • 补码符号位不动,其他位求反,最后整个数加1,得到原码
十进制数补码
+150000 1111
-151111 0001
+00000 0000
-00000 0000

4 补码的意义

在计算机系统中,数值一律用补码来存储,主要原因是:

  • 统一了零的编码
  • 将符号位和其它位统一处理
  • 将减法运算转变为加法运算
  • 两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃

示例1:用8位二进制数分别表示+0和-0

十进制数原码
+00000 0000
-01000 0000

不管以原码方式存储,还是以反码方式存储,0也有两种表示形式。为什么同样一个0有两种不同的表示方法呢? --但是如果以补码方式存储,补码统一了零的编码:

十进制数补码
+00000 0000
-010000 0000由于只用8位描述,最高位1丢弃,变为0000 0000

示例2:计算9-6的结果

以原码方式相加:

十进制数原码
90000 1001
-61000 0110

结果为-15,不正确。

以补码方式相加:

十进制数补码
90000 1001
-61111 1010

最高位的1溢出,剩余8位二进制表示的是3,正确。

5 数值溢出

当超过一个数据类型能够存放最大的范围时,数值会溢出。

有符号位最高位溢出的区别:符号位溢出会导致数的正负发生改变,但最高位的溢出会导致最高位丢失。

8、字符串格式化输出和输入

1 字符串常量

  • 字符串是内存中一段连续的char空间,以'\0'(数字0)结尾。
  • 字符串常量是由双引号括起来的字符序列,如“china”、“C program”,“$12.5”等都是合法的字符串常量。

字符串常量与字符常量的不同:每个字符串的结尾,编译器会自动的添加一个结束标志位'\0',即 "a" 包含两个字符'a'和’\0’。

2 printf函数

printf是输出一个字符串,putchar输出一个char。printf格式字符:

打印格式对应数据类型含义
%dint接受整数值并将它表示为有符号的十进制整数
%hdshort int短整数
%huunsigned short无符号短整数
%ounsigned int无符号8进制整数
%uunsigned int无符号10进制整数
%x,%Xunsigned int无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF
%ffloat单精度浮点数
%lfdouble双精度浮点数
%e,%Edouble科学计数法表示的数,此处"e"的大小写代表在输出时用的"e"的大小写
%cchar字符型。可以把输入的数字按照ASCII码相应转换为对应的字符
%schar *字符串。输出字符串中的字符直至字符串中的空字符(字符串以'\0‘结尾,这个'\0'即空字符)
%pvoid *以16进制形式输出指针
%%%输出一个百分号

printf附加格式:

字符含义
l(字母l)附加在d,u,x,o前面,表示长整数
-左对齐
m(代表一个整数)数据最小宽度
0(数字0)将输出的前面补上0直到占满指定列宽为止不可以搭配使用-
m.n(代表一个整数)m指域宽,即对应的输出项在输出设备上所占的字符数。n指精度,用于说明输出的实型数的小数位数。对数值型的来说,未指定n时,隐含的精度为n=6位。

举例

#include <stdio.h>
int main()
{
        int a = 100;
        printf("a = %d\n", a);//格式化输出一个字符串
        printf("%p\n", &a);//输出变量a在内存中的地址编号
        printf("%%d\n");
 
        char c = 'a';
        putchar(c);//putchar只有一个参数,就是要输出的char
        long a2 = 100;
        printf("%ld, %lx, %lo\n", a2, a2, a2);
 
        long long a3 = 1000;
        printf("%lld, %llx, %llo\n", a3, a3, a3);
 
        int abc = 10;
        printf("abc = '%6d'\n", abc);
        printf("abc = '%-6d'\n", abc);
        printf("abc = '%06d'\n", abc);
        printf("abc = '%-06d'\n", abc);
 
        double d = 12.3;
        printf("d = \' %-10.3lf \'\n", d);
 
        return 0;
}

结果:

3 putchar函数

  • 输出一个 字符 到屏幕。
  • 直接使用 ASCII 码。
  • 不能输出字符串。‘abc’既不是一个有效字符,也不是一个有效字符串。
  • 常用putchar('\n');来打印换行。printf("\n");
  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值