1:c语言的数据结构类型:
(1)基本类型:<1>数值类型:整型(短整型 short, 长整型 long/long long, 整型 int ,无符号型 unsinged ); 浮点型 (单精度浮点型 float ,双精度浮点型 double ,长双精度浮点型 long double ).
(2)结构类型:<1>数组,<2>结构体struct ,<3>公用体union <4> 枚举类型 enum
(3)指针类型 (4) 空类型void
2:内存与变量:
(1)内存:计算机执行程序时,组成程序的指令和程序所 *** 作的数据都必须存储在某个地方,这个地方就是机器的内存。
计算机数据存储空间的基本单位:1GB=2^10MB=2^20KB=2^30byte如以下程序展示了通过变量来访问内存数据的例子:实现将华氏温度转换成摄氏温度输出
#include
int main()
{
int celsius,fahr;
scanf("%d",&fahr);
celsius=5*(fahr-32)/9;
printf("fahr=%d,celsius=%d\n",fahr,celsius);
return 0;
}
程序运行后输出结果如下:
fahr=**,celsius=**
其中上述程序中的fahr,celsius是变量名,各自对应着计算机内存单元中的一个存储单元(一个或多个字节)程序通过变量名来读取某个内存单元中的数据或者在其中存储一个新数据。
(2)变量:高级语言都能通过变量名来访问内存中的数据,用变量名来标识内存中的某个存储位置——有一个或者多个连续的字节组成,在程序中使用变量名,实际上引用的是内存中对应的某个存储位置。
注意将一个值存入变量中是有破坏性的,它将替换掉该内存中原有的数值。
在c语言中,变量命名必须遵守以下规则: 《1》变量名可以由字母,数字,和下划线组成;《2》变量名不能包含除下划线以外的任何特殊字符,比如:%,#,逗号,空格等;《3》变量名必须以字母或者下划线开头;《4》变量名不能包含空白字符(空白字符有:换行符,空格,制表符);《5》c语言中的某些词(int float double 等)称为保留字,具有特殊意义,不能用作变量名;《6》c语言中区分大小写,因此变量a与变量A是两个不同的变量。
《1》给变量起一个有含义的名字可以使程序具有自文档性,增加程序的可读性;《2》由多个单词组成的变量名能增加程序的可读性;《3》给简单变量命名时,第一个字母一定要小写。
(3)整数类型:短整型short int 整型int 长整型long int 无符号短整型 unsigned short int 无符号整型 unsigned int 无符号长整型 unsigned long int
(4)变量的声明和使用:1,变量声明的格式:变量声明首先要指定变量的类型,然后说明变量的名称;2:在c语言中一行代码还可以同时声明多个变量;3,在使用变量之前一定要为其赋一个值,没有默认值并且尚未在程序中被赋值变量是未初始化的,如果试图访问未初始化的变量,可能会出现不可预知的结果;4:建议将变量声明部分和可执行语句部分,用一个空行分隔;5:不要使用未被初始化的变量,否则结果会不可控制。
(5)赋值运算:用“=”号将变量和一个表达式连接起来的式子,一般称为赋值表达式;
赋值运算具有破坏性,通过赋值运算将一个新值存入到一个内存单元中,这个值将替换掉该存储单元里原有的旧值,正常情况下,赋值运算符两端的值的数据类型相同。
3:格式化输入/输出函数
(1)格式化输出函数printf():此函数位于标准c语言库中,所以在程序开头要加上文件包含指令:
#include
printf()函数的标准格式为:
printf("格式控制串“,输出参数表);
格式控制串是指定数据的输出格式,格式控制串由格式字符(包括转换说明符,标志域宽,精度)和普通字符组成,转换说明符和百分号一起使用,用来说明内存中数据的输出格式。
普通字符在输出时原样输出。
输出参数表是指待输出的数据,可以是常量,变量或者其他更加复杂的表达式,也可以没有输出项。
当有多个输出项时,中间用逗号隔开,输出项必须与格式字符在类型和数量上完全一样。
常用的转换字符串: %c 按字符型输出单个字符;
%d 按十进制整数输出带符号整数(正数不输出符号);
%f 按小数形式输出浮点型数据,默认输出6位小数;
输出格式中的宽度修饰符,宽度修饰符用一个十进制整数来表示输出数据的位数,插在%与转换说明符之间,其作用是控制打印数据的宽度,也称为”域宽“。
%md代表数据以十进制整数形式输出,宽度为m列,数据不足m列的左补空格,超过m列的情况下按实际位数输出;例如:
#include
int main()
{
int a=10000;
printf("%10d",a);
return 0;
}
输出结果为: 10000
输出结果中数位占4位,靠右对齐,左边有6个空格
%-md则与上述的宽度相同,只是这次是左对齐;
(2)格式化输入函数scanf():scanf()从标准输入流按指定格式读取数据,然后转换为机内码存入对应内存地址。
变量名前的”&“是地址运算符,作用是获取变量的地址。
scanf()函数的格式:scanf(格式控制字符串,内存地址1,内存地址2,......内存地址n)
一些新的转换说明符:
(1)格式符:d,i,u,o,x:%d或%i以十进制整数符号形式转变换输入数据; %u以十进制整数无符号形式转换输入数据; %o 以八进制有符号整数形式转换输入数据;%x或%X以十六进制有符号整数形式转换输入数据。
(2)h或l前缀:读入短整数时,加前缀字母h,如%hd; 读入长整数时,加前缀字母l,如%ld;
(3)读入64位整数:如果编译器支持_int64,用格式符%164d,如果编译器支持long long,用格式符%lld。
(4)宽度:用十进制整数指定输入的宽度(即字符数)。
(5)复制抑制符号*:用以表示该输入项读入后不赋予相应的变量,即跳过该输入值。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)