做网站1200,西部空间官方网站,新网站怎么快速收录,wordpress新建的页面不存在文章字数#xff1a;8400 干货指数#xff1a;⭐⭐⭐⭐⭐C语言程序的结构认识用一个简单的c程序例子#xff0c;介绍c语言的基本构成、格式、以及良好的书写风格#xff0c;使小伙伴对c语言有个初步认识。例1#xff1a;计算两个整数之和的c程序#xff1a;#include main… 文章字数8400 干货指数⭐⭐⭐⭐⭐C语言程序的结构认识用一个简单的c程序例子介绍c语言的基本构成、格式、以及良好的书写风格使小伙伴对c语言有个初步认识。例1计算两个整数之和的c程序#include main() { int a,b,sum; a20; /*定义变量a,bsum为整型变量*/ b15; /*把整数20赋值给整型变量a*/ sumab; /*把整数15赋值给整型变量b*/ printf(“a%d,b%d,sum%d\n”,a,b,sum); /*把两个数之和赋值给整型变量sum*/ }重点说明:1、任何一个c语言程序都必须包括以下格式main() { }——这是c语言的基本结构任何一个程序都必须包含这个结构。括号内可以不写任何内容那么该程序将不执行任何结果。2、main()——在c语言中称之为“主函数”一个c程序有且仅有一个main函数任何一个c程序总是从main函数开始执行main函数后面的一对圆括号不能省略。3、被大括号{ }括起来的内容称为main函数的函数体这部分内容就是计算机要执行的内容。4、在{ }里面每一句话后面都有一个分号()在c语言中我们把以一个分号结尾的一句话叫做一个c语言的语句分号是语句结束的标志。printf(“a%d,b%d,sum%d\n”,a,b,sum); ——通过执行这条c语言系统提供给我们直接使用的屏幕输出函数用户即可看到运行结果本程序运行后将在显示器上显示如下结果a20,b15,sum35。6、#include——注意以#号开头。不以分号结尾 这一行没有分号所以不是语句在c语言中称之为命令行或者叫做“预编译处理命令”。7、程序中以 /*开头并且以*/结尾的部分表示程序的注释部分注释可以添加在程序的任何位置为了提高程序的可读性而添加但计算机在执行主函数内容时完全忽略注释部分换而言之就是计算机当做注释部分不存在于主函数中。C程序的生成过程C程序是先由源文件经编译生成目标文件然后经过连接生成可执行文件。源程序的扩展名为 .c 目标程序的扩展名为 .obj , 可执行程序的扩展名为 .exe 。标识符在编写程序时必须为函数、变量等命名这个名字称为标识符。C语言中标识符的命名规则如下标识符只能由字母、数字、下划线组成标识符的第一个字母必须是字母和下划线标识符区分大小写字母如If和if是两个完全不同的标识符。合法标识符如下A6, b_3 , _mn 非法的标识符如下ab#12 , 8m , tr3:4 , yes no标识符不能与程序中具有特殊意义的关键字相同不能与用户编制的函数名、C语言库函数相同在程序中各种标识符尽量不要重复以便区分。选择变量名和其他标识符时应注意做到 “见名知义”。标识符分为如下三类1、关键字关键字是具有特定含义的专门用来说明c语言特定成分的一类标识符不能用作用户的标识符。2、预定义标识符预定义标识符在c语言中也有特定的含义但可以用作用户标识符预定义标识符分为两类1)库函数名字比如printfscanf,sinisdigit等 2)编译处理命令名比如define,include3、用户标识符用户根据需要自己定义的标识符称为用户标识符。无论如何自定义标识符都必须符合标识符的三条命名规则。常量在程序运行中其值不能被改变的量称为常量。常量有5种类型整型常量、实型常量、字符常量、字符串常量和符号常量。4.1 数值转换数值的四种表现形式①二进制所有数字由0,1构成逢二进一二进制数中不会出现2。②八进制以数字0(注意不是以字母O,o)开头所有数字由0~7构成逢八进一八进制数中不会出现8。例0112,0123,077等③十进制所有数字由0~9构成逢十进一十进制数中不会出现10。例0,12-15等④十六进制以0x或者0X(数字0加字母x)开头,所有数字由0~9A~F(或者a~f)构成逢十六进一(其中A、B、C、D、E、F分别代表10、11、12、13、14、15) 例0x4A、0X14c7等在计算机内部数字均以二进制形式表示和存放用户输入的普通十进制数字都要被计算机转换成二进制才能在计算机内部存储同样计算机的运算结果也为二进制一般要将其转换成十进制数再输出给用户阅读这种转换通常由计算机自动实现。1)将十进制转换二进制、八进制和十六进制除法将十进制数除以2记录余数得到的商继续除以2直到商为0然后将各次相处所得的余数从后往前逆序排列所得余数数字序列就是该十进制数对应的二进制数。八进制和十六进制转换方法同上。例十进制数13转换成二进制数的值为1101转换八进制为015转换成十六进制为D.2)将二进制、八进制和十六进制转换成十进制乘积求和将二进制的每一位从低位到高位(右边为低位左边为高位)分别乘以20,21,22。。。。然后将这些值求和。3)二进制与八进制、十六进制数之间的相互转换①二进制转八进制从右往左每三位一组转换成十进制数将所得数据组合就是对应的八进制数(注意高位不足三位补零)。例(010 110 111)2(267)8②二进制转十六进制从右往左每四位一组转换成十进制数将所得数据组合就是对应的十六进制数(注意高位不足四位补零)。例(0101 1011)2(5B)16③八进制转化二进制每一位数字转换为三位二进制数字 例(13)8(001 011)2 (注意去掉前面的两个00,因为0在高位没有意义) ④十六进制转化二进制每一位数字转换为四位二进制数字 例(E3)16(1110 0011)24.2 数形常量整型常量有3种形式十进制整型常量、八进制整型常量和十六进制整型常量。(注意c语言中没有直接表示二进制的整型常量在c语言源程序中不会出现二进制。)书写方式如下十进制整型常量123 0 -24 , 85L(长整型常量) 等 八进制整型常量051 -026 0773 等 十六进制整型常量0x55 , 0x1101 , 0x , 0x5AC0 , -0xFF。其中L为长整型。4.3 实型常量实型常量有两种表示形式小数形式和指数形式。小数形式5.4 0.074 -23.0 指数形式5.4e0 4.3e-3 -3.3e41)小数部分为0的实型常量可以写为453.0 或453。2)用小数表示时小数点的两边必须有数不能写成“ .453“和“453.“而应该写成“0.453“和“453.0“。3)用指数写法时e前必须有数字e后面的指数必须为整数(注意整数阶码可以是正数负数也可以是八进制数、十六进制数但必须为整数)。4.4 字符常量字符常量的标志是一对单引号‘ ’c语言中的字符常量有两类1)由一对单引号括起来的一个字符如‘a ’, ‘r’ ,‘#’。注意: ′a′ 和 ′A′ 是两个不同的字符常量。2)由一对单引号括起来以反斜杠\开头后跟若干数字或者字母比如‘\n’,其中“\“是转义的意思,后面跟不同的字符表示不同的意思这类字符常量叫转义字符。4.5 字符串常量C语言中以双引号括起来的由若干个字符组成的序列即为字符串常量。例“ni hao” “happy”等等。4.6 符号常量符号常量是由宏定义“#define“定义的常量在C程序中可用标识符代表一个常量。例计算圆的面积的c程序。#include #define PI 3. main() {float rs; r12.5; SPI *r*r; printf(“s %f ”,s); }说明#define 是宏定义此程序中所有出现PI的地方都代表3.,同时PI称为符号常量。习惯上我们用大写字母来表示符号常量小写字母表示变量这样比较容易区别。变量变量就是其值可以改变的量。变量要有变量名在内存中占据一定的存储单元存储单元里存放的是该变量的值。不同类型的变量其存储单元的大小不同变量在使用前必须定义。5.1 整型变量整型变量分为4种基本型(int)、短整型(short int 或short)、长整型(long int 或 long)和无符号型(unsigned int unsigned shortunsigned long)。不同的编译系统对上述四种整型数据所占用的位数和数值范围有不同的规定。类型说明符单词signed来说明“有符号”(即有正负数之分)不写signed也隐含说明为有符号unsigned用来说明“无符号”(只表示正数)。5.2 实型变量C语言中实型变量分为单精度类型( float )和双精度类型( double )两种。如:float a , b ; double m ;在vc中float 型数据在内存中占4个字节(32位)double型数据占8个字节。单精度实数提供7位有效数字双精度实数提供1516位有效数字。实型常量不分float型和double型一个实型常量可以赋给一个float 型或double型变量但变量根据其类型截取实型常量中相应的有效数字。注意实型变量只能存放实型值不能用整型变量存放实型值也不能用实型变量存放整型值。5.3 字符变量字符变量用来存放字符常量定义形式char 变量名其中关键字char定义字符型数据类型占用一个字节的存储单元。例char cr1,cr2; cr1 ‘A’ , cr2‘B’ 将一个字符赋给一个字符变量时并不是将该字符本身存储到内存中而是将该字符对应的ASCII码存储到内存单元中。由于在内存中字符以ASCII码存放它的存储形式和整数的存储形式类似所以C语言中字符型数据与整型数据之间可以通用一个字符能用字符的形式输出也能用整数的形式输出字符数据也能进行算术运算此时相当于对它们的ASCII码进行运算。类型的自动转换和强制转换当同一表达式中各数据的类型不同时编译程序会自动把它们转变成同一类型后再进行计算。转换优先级为char int float double 即左边级别“低“的类型向右边转换。具体地说若在表达式中优先级最高的数据是double型则此表达式中的其他数据均被转换成double型且计算结果也是double型若在表达式中优先级最高的数据是float型则此表达式中的其他数据均被转换成float型且计算结果也是float型。在做赋值运算时若赋值号左右两边的类型不同则赋值号右边的类型向左边的类型转换当右边的类型高于左边的类型时则在转换时对右边的数据进行截取。除自动转换外还有强制转换表示形式是( 类型 )(表达式)例(int)(ab)讨论当a值赋值为3.4b值赋值为2.7(int)(ab)和(int)ab的值分别为多少C运算符认识1、算术运算符:用于各类数值运算。包括加()、减(-)、乘(*)、除(/)、求余(%)、自增()、自减(--)共七种。2、赋值运算符:用于赋值运算分为简单赋值()、复合算术赋值(,-,*,/,%)和复合位运算赋值(,|,^,,)三类共十一种。 span3、逗号运算符:用于把若干表达式组合成一个表达式()。4、关系运算符:用于比较运算。包括大于()、小于()、小于等于()和不等于(!)六种。 span5、逻辑运算符:用于逻辑运算。包括与()、或(||)、非(!)三种。6、条件运算符:这是一个三目运算符用于条件求值(?:)。7、位操作运算符:参与运算的量按二进制位进行运算。包括位与()、位或(|)、位非(~)、位异或(^)、左移()六种。8、指针运算符:用于取内容(*)和取地址()二种运算。9、求字节数运算符:用于计算数据类型所占的字节数(sizeof)。10、特殊运算符:有括号()下标[]成员(→.)等几种。另外按参与运算的对象个数C语言运算符可分为单目运算符 (如 )、双目运算符 (如- )和三目运算符 (如 ? )。算术运算符和算术表达式8.1 基本的算数运算符(1)(加法运算符或正值运算符如25)。(2)-(减法运算符或负值运算符如4-2)。(3)*(乘法运算符如3*8)。(4)/(除法运算符如11/5)。/的运算分为两种情况 a、“除”的左右两边都为整数时所得结果必然是整数(注意仅取整数部分不是四舍五入) 比如5/2的值为2不是2.5,1/2的值为0。 b、“除”的左右两边至少有一个是实型数据(即小数)时所得结果为实型数据。比如5/2.0的值为2.5,7.0/2.0的值为3.5.(5)%(模运算符或称求余运算符%两侧均应为整型数据如9%7的值为2)。需要说明的是当运算对象为负数时所得结果随编译器不同而不同在vc中结果的符号与被除数相同比如13%-2值为1而-15%2值为-1。8.2 算术表达式和运算符的优先级与结合性算术表达式是用算术运算符和括号将运算量(也称操作数)连接起来的、符合C语言语法规则的表达式。运算对象包括函数、常量和变量等。在计算机语言中算术表达式的求值规律与数学中的四则运算的规律类似其运算规则和要求如下。(1)在算术表达式中可使用多层圆括号但括号必须配对。运算时从内层圆括号开始由内向外依次计算各表达式的值。(2)在算术表达式中对于不同优先级的运算符可按运算符的优先级由高到低进行运算若表达式中运算符的优先级相同则按运算符的结合方向进行运算。(3)如果一个运算符两侧的操作数类型不同则先利用自动转换或强制类型转换使两者具有相同类型然后进行运算。8.3 自增自减运算符作用使变量的值增1或减1。如i--i (在使用i之前先使i的值加1、减1)。ii-- (在使用i之后使i的值加1、减1)。(1)只有变量才能用自增运算符 ()和自减运算符(--)而常量或表达式不能用如10或(xy)都是不合法的。(2)和--的结合方向是“自右向左“如 -i i的左边是负号运算符右边是自增运算符负号运算和自增运算都是 “自右向左“结合的相当于 -(i)。在循环语句中常用到自增(减)运算符在指针中也常用到该运算符考生要弄清楚“i”和“i”及“i--”和“--i”的区别,特别弄清楚表达式的值和变量的值。赋值运算符与赋值表达式9.1 赋值运算符与赋值表达式赋值符号 ““就是赋值运算符作用是将一个数据赋给一个变量或将一个变量的值赋给另一个变量由赋值运算符组成的表达式称为赋值表达式。一般形式为变量名 表达式。在程序中可以多次给一个变量赋值每赋一次值与它相应的存储单元中的数据就被更新一次内存中当前的数据就是最后一次所赋值的那个数据。例a12; 此表达式读作“将10的值赋值给变量a”。a、如果赋值号两边的运算对象类型不一致系统会自动进行类型转换转换的规则将赋值号右边表达式的值的类型转换成赋值号左边变量的类型例int y3.5在变量y中最终存储的是整数3。b、 可以将复制表达式的值再赋值给变量形成连续赋值。例如xy25 是一个连续赋值表达式xy25 等价于x(y25)所以表达式xy25 最终的值为25 。9.2 复合的赋值运算符在赋值运算符之前加上其他运算符可以构成复合赋值运算符。其中与算术运算有关的复合运算符是-*/% 。两个符号之间不可以有空格复合赋值运算符的优先级与赋值运算符的相同。表达式n1等价于nn1作用是取变量n中的值增1再赋给变量n,其他复合的赋值运算符的运算规则依次类推。如求表达aa-a*a 的值,其中a的初值为12 。步骤先进行“a-a*a“运算相当于aa-a*a12-144-132 。(2)再进行“a-132“运算相当于 aa(-132)264 。9.3 逗号运算符和逗号表达式在c语言中逗号除了作为分隔符还可以用作一种运算符----逗号运算符用逗号运算符将几个表达式连接起来例如abc,ab*c等称为逗号表达式。一般形式为表达式1 表达式2 表达式3 …表达式n例x2,y3,z4逗号表达式具有从左至右的结合性即先求解表达式1然后依次求解表达式2直到表达式n的值。表达式n的值就是整个逗号表达式的值。上述的逗号表达式的值就是表达式z4的值4.需要注意的是逗号运算符是所有运算符中级别最低的。例有如下程序段main() {int a2,b4,c6,x,y;y(xab),(bc); printf(y%d,x%d,y,x); }程序显示结果为y6,x6讨论将y(xab),(bc);改为y((xab),bc) 的程序结果关系运算符和关系表达式C语言中的逻辑值只有两个真(true)和假(flase)。用非零代表真用零代表假。因此对于任意一个表达式如果它的值为零就代表一个假值如果它的值为非零就代表一个真值。只要值不是零不管是正数负数整数实数都代表一个真值。例如-5的逻辑值为真。10.2 逗号运算符和逗号表达式“”和“||”的运算对象有两个故它们都是双目运算符而的运算对象只有一个因此它是单目运算符。逻辑运算举例如下(1)ab: 当两边都为“真”时表达式ab的值才是真。值得注意的是在数学中关系式0(2)a||b: 当||两边有一个为“真”时表达式a||b的值就是真。(3)!a: 表示取反如果a为真则!A为假反之亦然。例如-5的值就为0。在语言中由或||组成的逻辑表达式在某些特定情况下会产生“短路“现象。(1)x y z 只有当x为真(非0)时才需要判别y的值只有x和y都为真时才需要去判别z的值只要x为假就不必判别y和z整个表达式的值为0。口诀“一假必假”。例(51)(i0) (51)表达式的值为0所以计算机运行中就跳过(i0)此表达式(51)(i0)表达式的值为0。(2)x||y||z ,只要x的值为真(非零)就不必判别y和z的值 整个表达式的值为1只有x的值为假才需要判别y的值只有x和y的值同时为假才需要判别z的值口诀“一真必真”。位运算11.1 位运算符在计算机中数据都是以二进制数形式存放的位运算就是指对存储单元中二进制位的运算。C语言提供6种位运算符。11.2 位运算位运算符 |~ ∧ 按优先级从高到低排列的顺序是位运算符中求反运算“~“优先级最高而左移和右移相同居于第二接下来的顺序是按位与 ““、按位异或 “∧“和按位或 “|“。顺序为~ ∧ | 。例1左移运算符“例如a4 指把a的各二进位向左移动4位。如a00000011(十进制3)左移4位后为00(十进制48)。例2右移运算符“”是双目运算符。其功能是把“ ”左边的运算数的各二进位全部右移若干位“”右边的数指定移动的位数。例如设 a15 a2 表示把右移为十进制3)。应该说明的是对于有符号数在右移时符号位将随同移动。当为正数时最高位补0而为负数时符号位为1最高位是补0或是补1 取决于编译系统的规定。例3设二进制数a是00 若通过异或运算a∧b 使a的高4位取反低4位不变则二进制数b是。解析异或运算常用来使特定位翻转只要使需翻转的位与1进行异或操作就可以了因为原数中值为1的位与1进行异或运算得0 原数中值为0的位与1进行异或运算结果得1。而与0进行异或的位将保持原值。异或运算还可用来交换两个值不用临时变量。免责声明本文内容来源于网络版权归原作者所有。如涉及作品版权问题请联系删除。-END-1《从事嵌入式行业的你现在年薪多少》2《从业5年我为什么说嵌入式没有辜负我的热爱与努力》3《有点难但是巨干大佬把C指针讲的透透的……》0102030405滑动查看更多每天辛勤发电的小创【分享、赞、在看】可不可拥有一个鸭