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共享文件夹的使用:

  在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 }

(以上所述内容为学习朱老师的嵌入式课程后复习笔记所得,目的是自己复习巩固知识,同时把自己学到的知识分享出来。能力有限,水平一般,如有错误,欢迎指正,谢谢!)

猜你喜欢

转载自www.linuxidc.com/Linux/2017-02/141081.htm