首页 > 代码库 > C语言的基本概念
C语言的基本概念
1、经典入门:hello world
1 #include <stdio.h> 2 3 int main(void) 4 { 5 printf("hello world.\n"); 6 7 return 0; 8 }
注:上面所使用的关键字:include 头文件包含
int 整型,用来表示整数的类型
void 空类型
return 函数返回
2、基本概念:
源文件:源文件即源程序代码文件,C语言源文件后缀名是.c;
头文件:头文件的后缀名为.h,C语言代码由源文件和头文件构成;
关键字:关键字是C语言已经定义好的一些字,这些字在C语言中代表着一些特殊含义,我们必须搞懂每个关键字的所有含义和用法,否则就看不懂C语言程序;
注释:C语言中的注释一般以//开头,或者/* */,注释是给程序员看的,编译器编译程序的时候是忽略注释内容的,所以机器根本看不见注释,也不理注释;
符号:C语言中包含很多符号,如; : , + - * / () [] {} 等等,每个符号都有自己的含义,必须理解它们的含义才能看懂C语言程序;
变量:可以发生变化的量。C语言程序中用变量来进行计算;
函数:函数是C语言的一个基本组成单位,一个C语言程序其实就是由一个或多个函数组成的,每个函数用来完成某项功能,函数也可以调用别的函数来完成其功能。函数的标志是()。C语言中有一个特殊的函数叫
main(),这个函数是整个程序内定的入口,也就是说整个C语言程序是从main()函数开始执行的,其他的函数都是直接或者间接被main()调用的。
3、写代码的步骤:
(1) 使用编辑器(如vi)编辑源代码;
(2) 使用编译器把源程序转化成可执行程序,我们在Linux中使用的编译器一般是gcc;
如:gcc hello.c 对hello.c进行编译后生成可执行文件a.out
gcc hello.c -o hello 对hello.c进行编译生成指定名字的可执行文件hello
(3) 执行编译生成的可执行程序,即./hello;
(4) 执行程序后若发现程序结果不对,这时候就要返回来看源代码哪里不对,然后对其进行修改,再编译执行,再看结果,如此反复直到程序执行结果正确为止;
4、VMWare共享文件夹的使用:
当我们是使用虚拟机VMWare中安装的Ubuntu时,我们一般会在Windows中编辑源代码,而在Linux中来编译和执行源代码,这时就需要在Windows与Linux间进行交互;
在Windows与Linux间进行交互有两种方法:smb服务器(需要自己搭建,较复杂,可以自己在网上寻找相关教程)、VMWare的共享文件夹(仅需简单设置即可使用,下面简单介绍);
建立Windows的共享文件夹:
(1) 先在Windows中创建一个文件夹,切记要使用英文名称;
(2) VMWare中的菜单栏里的VM -> Settings -> Options -> Shared Folders选项卡,右边上侧选择Always Enabled,下面点击Add,next,在打开的选项卡中HostPath项目中浏览选择刚才第一步中创建
的文件夹,下面Name中会自动弹出一个相同的名字,这个名字就是将来Windows中的文件夹在linux虚拟机中的映射文件夹,名字可以改也可以不改。然后一直OK,完成即可。
(3) 在linux中,直接到 /mnt/hgfs目录下,即可找到刚才第二步中Name相同的名字的文件夹,这个目录即是第一步中Windows中目录在linux下的映射。
5、数据类型:
(1) 整型:C语言中的整型对应数学中的整数,整型变量是用来描述一个整数值的,整型变量经过计算后也只能是整数(整型),不可能出现小数(浮点型);
C语言中整形有三种:int 整型
short int 短整型,可简写为short
long int 长整型,可简写为long
1 #include <stdio.h> 2 3 int main(void) 4 { 5 int a,b,c; // 定义三个了整形变量a、b、c 6 a = 12; // 赋值语句,将=右边的12赋值给左边的变量a 7 b = 23; 8 c = a + b; // 运算式,把a+b的结果赋值给c 9 printf("c = %d.\n",c); 10 11 return 0; 12 }
(2) 浮点型:C语言中的浮点型对应数学中的小数。浮点型有float和double两种,使用方式相同,而表示的范围和精度不同。float表示的范围小,精度低(小数点后6位),
而double表示范围大,精度高。(小数点后16位);
注:printf中打印float或double类型,是用%f,而不是%d;
1 #include <stdio.h> 2 3 int main(void) 4 { 5 /* 6 float f1 = 3.14; 7 8 printf("f1 = %f.\n",f1); // float精度够,正确输出我们需要的值 9 10 f1 = 3.141592653; 11 12 printf("f1 = %f.\n",f1); // float精度不够,所以按照精度取舍了 13 */ 14 double f1 = 3.14; 15 16 printf("f1 = %f.\n",f1); 17 18 f1 = 3.14159265312345678912; 19 20 printf("f1 = %2.20f.\n",f1); 21 22 return 0; 23 }
(3) 字符型:字符型对应ASCII字符。ASCII字符是一种编码,就是用数字编码来表示一个符号的一种方法,本质上说,字符型其实也是整型,只是这些整型数被用来表示一些字符的ASCII码值,所以叫做
字符型。字符型一般用8位二进制表示,无符号字符型范围是0~255;
1 #include <stdio.h> 2 3 int main(void) 4 { 5 char c1 = ‘K‘; 6 7 // 使用%d来打印是打印出字符所对应的ASCII码值,使用%c来打印是打印出字符本身 8 printf("c1 = %d, c1 = %c\n", c1, c1); 9 10 c1 = c1 + 5; 11 12 printf("c1 = %d, c1 = %c\n", c1, c1); 13 14 return 0; 15 }
(4) 有符号数和无符号数:数学中的数都是有符号的,即有正数和负数之分。所以计算机中的数据类型也有符号,分为有符号数和无符号数;
有符号数:整型: signed int 可简写为int
signed long int 可简写为long
signed short int 可简写为short
signed 表示signed int
浮点型: signed float 可简写为float
signed double 可简写为double
字符型: signed char 可简写为char
无符号数:整型: unsigned int 无简写
unsigned long int 可简写为unsigned long
unsigned short int 可简写为unsigned short
浮点型:没有无符号浮点数
字符型: unsigned char 无简写
注:对于整形和字符型来说,有符号数和无符号数表示的范围是不同的;
6、常用运算符:
(1) 数学运算符:与数学中意义相同: + 加号
- 减号
* 乘号
/ 除号
% 取余符号
() 括号里的表达式优先级最高
与数学中的意义不同:= 赋值运算符,不同于数学中的等号。赋值运算符的作用是经过运算后符号左边(左值,一般是一个变量)的值等于右边(右值,一般是常数或变量)的值了
+= x = x + y; 等价于 x += y
-= x = x - y; 等价于 x -= y
*= x = x * y; 等价于 x *= y
/= x = x / y; 等价于 x /= y
%= x = x % y; 等价于 x %= y
1 #include <stdio.h> 2 3 int main(void) 4 { 5 /* 6 int a, b, c, d, e; 7 8 a = 13; 9 b = 4; 10 c = 7; 11 12 d = a + b / c; // 除的优先级高,先除再加 13 e = (a + b) / c; // 括号里的表达式优先级最高,先算括号里的表达式再算括号外的表达式 14 15 printf("d = %d, e = %d.\n", d, e); 16 */ 17 int a, b, c, d; 18 19 a = 17; 20 b = 4; 21 c = a / b; // 除 22 d = a % b; // 取余 23 24 printf("a = %d, b = %d, c = %d, d = %d.\n", a, b, c, d); 25 26 return 0; 27 }
(2) 判断运算符:== 等于
!= 不等于
> 大于
< 小于
>= 大于等于
<= 小于等于
(3) 逗号运算符:, 主要是用来分割
(4) ++与--:++ a++; 等价于 ++a; 等价于 a = a + 1; 等价于 a += 1;
-- a--; 等价于 --a; 等价于 a = a - 1; 等价于 a -= 1;
1 #include <stdio.h> 2 3 int main(void) 4 { 5 int a, b, c, d; 6 7 a = 4; 8 a++; 9 printf("a = %d.\n", a); 10 11 //a = 4; 12 ++a; 13 printf("a = %d.\n", a); 14 15 //a = 4; 16 a += 1; 17 printf("a = %d.\n", a); 18 19 //a = 4; 20 a = a + 1; 21 printf("a = %d.\n", a); 22 23 return 0; 24 }
(以上所述内容为学习朱老师的嵌入式课程后复习笔记所得,目的是自己复习巩固知识,同时把自己学到的知识分享出来。能力有限,水平一般,如有错误,欢迎指正,谢谢!)
2017-02-25 19:15:48
C语言的基本概念