C语言基础-第二课-数据类型与运算符

1   C语言中的数据类型

1.1   常量

常量就是在程序中不可变化的量,常量在定义的时候必须给一个初值。

1.1.1   #define

定义一个宏常量

1.1.2   const

定义一个const常量

1.2   字符串常量

“hello world”

对于#define类型的常量,c语言的习惯是常量名称为大写,但对于普通const常量以及变量,一般为小写结合大写的方式

1.3   二进制数、位、字节与字

我们习惯于十进制的数:10,12等

一个位只能表示0,或者1两种状态,简称bit,一个位是一个bit

一个字节为8个二进制,称为8位,简称BYTE,8个比特是一个字节

一个字为2个字节,简称WORD。

两个字为双字,简称DWORD

1.4   八进制

八进制为以8为基数的数制系统,C语言当中0表示八进制,0666;

1.5   十六进制

十六进制值16为基数 的数制系统,C语言中用0x表示十六进制


十进制


十六进制


二进制


0


0


0000


1


1


0001


2


2


0010


3


3


0011


4


4


0100

十进制转化8进制,用十进制数作为被除数,8作为除数,取商数和余数,直到商数为0的时候,将余数倒过来就是转化后的结果

十进制转化16进制,用十进制数作为被除数,16作为除数,取商数和余数,直到商数为0的时候,将余数倒过来就是转化后的结果

1.6   原码

将最高位做为符号位(0代表正,1代表负),其余各位代表数值本身的绝对值


+7的原码是00000111

-7的原码是10000111

+0的原码是00000000

-0的原码是10000000

1.7   反码

一个数如果值为正,那么反码和原码相同

一个数如果为负,那么符号位为1,其他各位与原码相反


+7的反码00000111

-7的反码11111000

-0的反码11111111

1.8   补码

原码和反码都不利于计算机的运算,如:原码表示的7和-7相加,还需要判断符号位。

正数:原码,反码补码都相同

负数:最高位为1,其余各位原码取反,最后对整个数 + 1


-7的补码:=

10000111(原码)

111111000(反码)

11111001(补码)

+0的补码为00000000

-0的补码也是00000000

补码符号位不动,其他位求反,最后整个数 + 1,得到原码


用补码进行运算,减法可以通过加法实现


7-6=1

7的补码和-6的补码相加:00000111 + 11111010 = 100000001

进位舍弃后,剩下的00000001就是1的补码


-7+6 = -1

-7的补码和6的补码相加:11111001 + 00000110 = 11111111

11111111是-1的补码

1.9   sizeof关键字

sizeofc语言关键字,功能是求指定数据类型在内存中的大小,单位:字节

sizeof与size_t类型 

1.10   int类型

1.10.1   int常量,变量

int就是32位的一个二进制整数,在内存当中占据4个字节的空间

1.10.2   printf输出int值

%d,输出一个有符号的10进制整数,%u,代表输出一个无符号的十进制整数

1.10.3   printf输出八进制和十六进制

%x,代表输出16进制数,%X,用大写字母方式输出16进制数

%o代表输出八进制数

1.10.4   short,long,long long,unsigned int

short意思为短整数,在32位系统下是2个字节,16个比特

long意思为长整数,在32位的系统下,long都是4个字节的,在64位系统下,windows还是4个字节,unix下成了8个字节。

Int不管是32位系统下,还是64位系统下,不论是windows还是unix都是4个字节的

Long long是64位,也就是8个字节大小的整数,对于32位操作系统,CPU寄存器是32位,所以计算longlong类型的数据,效率很低

9l,9L,9ll,9LL,9u,9ull,9ULL

1.10.5   整数溢出

计算一个整数的时候超过整数能够容纳的最大单位后,整数会溢出,溢出的结果是高位舍弃。

当一个小的整数赋值给大的整数,符号位不会丢失,会继承

1.10.6   大端对齐与小端对齐

对于arm,intel这种x86构架的复杂指令CPU,整数在内存中是倒着存放的,低地址放低位,高地址放高位,小端对齐。

但对于unix服务器的CPU,更多是采用大端对齐的方式存放整数

1.11   char类型

1.11.1   char常量,变量

char c;定义一个char变量

‘a’,char的常量

Char的本质就是一个整数,一个只有1个字节大小的整数

1.11.2   printf输出char

%c意思是输出一个字符,而不是一个整数

1.11.3   不可打印char转义符

\a,警报

\b退格

\n换行

\r回车

\t制表符

\\斜杠

\’单引号

\”双引号

\?问号

1.11.4   char和unsigned char

char取值范围为-128到127

unsigned char为0-255

1.12   浮点float,double,long double类型

1.12.1   浮点常量,变量

Float在32位系统下是4个字节,double在32位系统下是8个字节

小数的效率很低,避免使用,除非明确的要计算一个小数。

1.12.2   printf输出浮点数

%f,%Lf

%f是输出一个double

%lf输出一个long double

1.13   类型限定

1.13.1   const

const是代表一个不能改变值的常量

1.13.2   volatile

代表变量是一个可能被CPU指令之外的地方改变的,编译器就不会针对这个变量去优化目标代码。

1.13.3   register

变量在CPU寄存器里面,而不是在内存里面。但regist是建议型的指令,而不是命令型的指令

2   字符串格式化输入与输出

2.1   字符串在计算机内部的存储方式

字符串是内存中一段连续的char空间,以’\0’结尾

“”是C语言表达字符串的方式

2.2   printf函数,putchar函数

printf格式字符


字符


对应数据类型


含义


d


int


接受整数值并将它表示为有符号的十进制整数


hd


Short int


短整数


hu


Unsigned short int


无符号短整数


o


unsigned int


无符号8进制整数


u


unsigned int


无符号10进制整数


x / X


unsigned int


无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF


f


float或double


单精度浮点数双精度浮点数


e / E


double


科学计数法表示的数,此处"e"的大小写代表在输出时用的“e”的大小写


c


char


字符型。可以把输入的数字按照ASCII相应转换为对应的字符


s / S


char * / wchar_t *


字符串。输出字符串中的字符直至字符串中的空字符(字符串以‘\0‘结尾,这个‘\0‘即空字符)


p


void *


以16进制形式输出指针


%


%


输出一个百分号

printf附加格式


字符


含义


l


附加在d,u,x,o前面,表示长整数


-


左对齐


m(代表一个整数)


数据最小宽度


0


将输出的前面补上0直到占满指定列宽为止不可以搭配使用-


N(代表一个整数)


宽度至少为n位不够以空格填充

Putchar是显式一个字符的函数

2.3   scanf函数与getchar函数

scanf通过键盘读取用户输入,放入变量中,记得参数一定是变量的地址(&)


int a = 0;

int b = 0;

scanf("%d", &a);//一定要用&取变量的地址

scanf("%d", &b);//一定要用&取变量的地址

Getchar得到用户键盘输入的字符

3   运算符表达式和语句

3.1   基本运算符

3.1.1   =

数据对象:泛指数据在内存的存储区域

左值:表示可以被更改的数据对象

右值:能赋给左值的量

3.1.2   +

3.1.3   –

3.1.4   *

3.1.5   /

3.1.6   %

取余数

3.1.7   +=

加等于

3.1.8   -=

减等于

3.1.9   *=

乘等于

3.1.10   /=

除等于

3.1.11   %=

取余等于

3.1.12   ++

自加1

,i++先计算表达式的值,然后再++

,++i是先++,再计算表达式的值

3.1.13   --

自减一

3.1.14   逗号运算符


int a = 2;

int b = 3;

int c = 4;

int d = 5;

int i = (a = b, c + d);

 

逗号表达式先求逗号左边的值,然后求右边的值,整个语句的值是逗号右边的值。

3.1.15   运算符优先级


优先级


运算符


结合性


1


++(后缀),--(后缀),()(调用函数),{}(语句块),.,->


从左到右


2


++(前缀),--(前缀),+(前缀),-(前缀),!(前缀),~(前缀),sizeof,*(取指针值),&(取地址),(type)(类型转化)


从右到左


3


*, /, %


从左到右


4


+,-


从左到右


5


<< >>


从左到右


6


< > <= >=


从左到右


7


== !=


从左到右


8


&


从左到右


9


^


从左到右


10


|


从左到右


11


&&


从左到右


12


||


从左到右


13


?


从右到左


14


=,*=,%=,+=,-=,<<=,>>=,&=,|=,^=


从右到左


15


,(逗号运算符)


从左到右

3.2   复合语句

{}代码块

3.3   空语句

只有一个;号的语句就是空语句,空语句在C语言里面和合法的,并且是在某些场合必用的

3.4   类型转化


double f = (double)3 / 2;

()为强制类型转化运算符

时间: 2024-11-05 22:50:17

C语言基础-第二课-数据类型与运算符的相关文章

C语言基础第二课 -----布尔类型,关系运算符,逻辑运算符,

/* 布尔类型: 1.c89没有布尔类型,c99有布尔类型.c工程支持c89,oc工程c99. 2.两种数值: bool true(真)   false(假) C语言 BOOL YES(真)      NO(假)   OC语言 3.真和假的表示 C语言   非0即为真  0就是假 OC语言   YES定义为1  NO定义为0 4.输出转换符是%d 5.作用:用于分支结构和循环的判断. */ //    BOOL a1 = YES; //    BOOL a2 = NO; //    printf

黑马程序员-c语言基础:各种数据类型的输出占位符

c语言中的输出操作相对java来说是比较麻烦的,每种数据类型的输出都有各自的占位符: 下面是各种数据类型的输出占位符: short/int : %d int a = 1; printf("这个整数是:%d", a); long: %ld; (long 是int得修饰,不能算是一种单独的数据类型,只是比int多了四个字节的存储空间) long long: %lld char : %c float/double : %f  float默认是6位小数输出:可以在%f中控制:例如:%.2f:输

语言基础和基本数据类型

语言基础 打开程序,1.sln.2.csproj Console.Write("内容"); 控制台输出内容,不会换行Console.WriteLine("内容"); 输出内容,自动换行Console.ReadLine(); 接收用户输入的内容,回车结束Console.ReadKey(); 接收用户按下的第一个任意键 练习 using System;using System.Collections.Generic;using System.Linq;using Sys

C语言基础 第一课 ---------基本数据类型,常量,变量

int main() { //单行注释:注释一行 /* 多行注释:在这个区间内,都属于多行注释,可以换行. */ #pragma mark---基本数据类型---- /* char   字符类型    包含: ‘a~z’ ‘A~Z’ ‘0~9’等等 int    整型类型    包含: 数字1234567890 等等 float  浮点型      包含: 数字1.2 2.5等等 short  短整型      包含: 数字123456789等等 long   长整形      包含: 数字12

Java基础 - 第二天 Eclipse、运算符、Scanner类

第1章    Eclipse 1.1     Eclipse概述 l 概述 Eclipse是一个专门针对Java的集成开发工具(IDE),是IBM公司的产品.是免费.开源.由Java语言编写.所以,需要有JRE运行环境并配置好环境变量.它可以极大地提升我们的开发效率.可以自动编译,检查错误.在公司中,使用的就是Eclipse进行开发. l 特点描述 n 免费 n 纯Java语言编写 n 免安装 n 扩展性强 l 下载和安装 n 下载 http://eclipse.org/ n 安装 绿色版 解压

python基础第二课

一  认识模块 1.1  sys #!/usr/bin/env python3 # Author: Sam Gao import sys print(sys.path) #打印PYTHONPATH环境变量 # ['/home/sam/PycharmProjects/s14/day1', # '/home/sam/PycharmProjects/s14', # '/usr/lib/python35.zip', # '/usr/lib/python3.5', # '/usr/lib/python3.

Day02_JAVA语言基础第二天

1.常量(理解) 1.概念         在程序运行过程中,其值不会发生改变的量 2.分类(掌握) A .字面值常量 整数常量:1,2,-3 小数常量:2.3,-232.3 字符常量:'A' 字符串常量:"Hello World" 布尔常量: true false 空常量 null B .自定义常量 类.接口.数组 2.进制(了解) 1.概念 X进制就是逢X进1 2. JAVA中的进制 二进制:0b开头,JDK1.7以后才后的 八进制: 0开头 十六进制:0x开头 十进制:默认就是,

第二章 数据类型、运算符和表达式

0x 考试内容要求 掌握C++的数据类型 解常量定义 掌握常量的用法 掌握运算符种类以及其优先级和结合性 熟练掌握表达式 1x C++语言的数据类型 C++中每个变量或者常量都需要拥有自己的一种数据类型 C++将数据类型分为三种: 基本数据类型 构造类型(导出数据类型) 自定义类型 1x.1 基本类型 逻辑型--bool BOOL布尔型,用0,1来表示逻辑真假 只拥有个值:true.false分别用1.0表示 字符型--char 取值范围:ASCII,扩充ASCII 占用一个字节,即8位 ASC

Go语言基础之基本数据类型

基本数据类型 整型 整型分为以下两个大类: 按长度分为:int8.int16.int32.int64 对应的无符号整型:uint8.uint16.uint32.uint64 其中,uint8就是我们熟知的byte型,int16对应C语言中的short型,int64对应C语言中的long型. 类型 描述 uint8 无符号 8位整型 (0 到 255) uint16 无符号 16位整型 (0 到 65535) uint32 无符号 32位整型 (0 到 4294967295) uint64 无符号