黑马程序员——C语言基础---C语言学习中容易疏漏的地方总结(下)

------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------

知识点24:静态变量、全局变量声明但是没有初始化是有初值的(int0 char \0)

但是局部变量声明没有初始化是没有初值的

 

知识点25:结构体整体初始化必须在声明时进行

[cpp]  view plain copy
 
  1. struct Person p1 = {"zhangsan", 18,'F'};//这是正确的  

 

//下面的时错误的

 

[cpp]  view plain copy
 
  1. struct Person p2;  
  2. p2 = {"zhangsan", 18, 'F'};  

//初始化也可以这样写

 

 

[cpp]  view plain copy
 
  1. struct Person p1 = {.name = "zhangsan",.age = 18, .gender = 'F'};  

知识点26:结构体占用的内存是最大成员占用内存的倍数(补齐算法),如

 

 

[cpp]  view plain copy
 
  1. struct Student{  
  2.        int age;//4个字节  
  3.        char*name;//指针类型占八个字节  
  4. };  
  5. struct Student stu;  
  6. stu.age = 20;  
  7. stu.name = "jack";  
  8.    
  9. int s = sizeof(stu);  
  10. printf("%d\n", s);//输出是16 原理:4+8=12--->16  



 

 

知识点27:结构体变量的几种定义方式:

方式一:

 

[cpp]  view plain copy
 
  1. struct Student{  
  2.        int age;  
  3.        char *name;  
  4. };  
  5. struct Student stu1;  

方式二:

 

 

[cpp]  view plain copy
 
  1. struct Student{  
  2.        int age;  
  3.        char *name;  
  4. }stu2;//这是定义类型的同时定义变量,只能写一次,否则类型重复定义  

方式三:

 

 

[cpp]  view plain copy
 
  1. struct {  
  2.        int age;  
  3.        char *name;  
  4. }stu3;//这种方法不能再次定义这个类型的变量  

个人认为最好的一种方式:

 

[cpp]  view plain copy
 
  1. typedef struct Student{  
  2.        int age;  
  3.        char *name;  
  4. }Student;  
  5. Student stu4;  



 

知识点28:预处理指令(三种):

1.宏定义

2.条件编译

3.文件包含

 

 

1.宏定义的配对使用和带参数的宏

 

[cpp]  view plain copy
 
  1. #define  
  2. ...  
  3. #undef  

 

带参数的宏

 

[cpp]  view plain copy
 
  1. #define sum(v1,v2) ((v1) + (v2))//括号是必须的  

例如:

 

 

[cpp]  view plain copy
 
  1. #define pingfang(a) a*a  
  2. #define pingfang(a) (a*a)  

 

 

调用时

 

[cpp]  view plain copy
 
  1. pingfang(10)/pingfang(2)//不正确  
  2. pingfang(5+5)//不正确  

带参数的宏效率比函数高

 

 

2.条件编译(一般是判断宏的值)

 

[cpp]  view plain copy
 
  1. #if 条件  
  2. ...  
  3. #elif 条件  
  4. ...  
  5. #else  
  6. ...  
  7. #endif(非常重要)不然后面的代码全部无效  

 

 

[cpp]  view plain copy
 
  1. #ifdef 等价于  
  2. #if defined()  

 

 

 

[cpp]  view plain copy
 
  1. #ifndef 等价于  
  2. #if !defined()  

3.文件包含

 

1.<>表示系统自带的文件,""表示自定义文件

2.不允许循环包含,比如a.h包含b.h,b.h又包含a.h

 知识点29:typedef 只是给类型起了个别名并不是定义新类型

 

[cpp]  view plain copy
 
  1.  struct Student{  
  2.        int age;  
  3.        char *name;  
  4. };  
  5. typedef struct Student Student;  

等价于

 

 

[cpp]  view plain copy
 
  1. typedef struct Student{  
  2.        int age;  
  3.        char *name;  
  4. }Student;  

也等价于

 

 

[cpp]  view plain copy
 
  1. typedef struct {  
  2.        int age;  
  3.        char *name;  
  4. }Student;  

类似的给枚举类型起名

 

 

[cpp]  view plain copy
 
  1. typedef enum Sex  
  2. {  
  3.        Man,Women  
  4. }Sex;  

下面这种情况的写法比较特殊

 

//下面是函数指针类型的自定义数据类型,返回值类型和参数类型要匹配

 

[cpp]  view plain copy
 
  1. #include <stdio.h>  
  2. typedef int (*TypeFuncPointer)(int, int);  
  3. int add(int a, intb)  
  4. {  
  5.     return a + b;  
  6. }  
  7. int minus(int a, intb)  
  8. {  
  9.        return a - b;  
  10. }  
  11. int main()  
  12. {  
  13.     TypeFuncPointer p = add;//使用自定义类型Π 
  14.     TypeFuncPointer p2 = minus;//使用自定义类型Π 
  15.     printf("add = %d\n",p(1, 2));  
  16.     printf("minus = %d\n",p2(1, 2));  
  17.     return 0;  
  18. }  

下面是定义结构体的指针类型

 

 

[cpp]  view plain copy
 
  1. typedef struct Student{  
  2.        int age;  
  3.        char *name;  
  4. }*PtrStu;  
  5. //使用方式  
  6. Student stu ={18, "zhangsan"};  
  7. PtrStu p = &stu;  

宏定义也是可以为类型起名的

 

 

[cpp]  view plain copy
  1. #define Integer int  

 

相当于

 

[cpp]  view plain copy
 
  1. typedef int Integer  

注意和typedef的区别

 

例如:

 

[cpp]  view plain copy
  1. typedef char * String  
  2. #define String2char *  
  3. //使用  
  4. String s1,s2;//s1和s2都是char *类型  
  5. String2 s3,s4;//s3是char*类型的,但是s4是char类型的  

知识点30:static和 extern区别是能否进行跨文件访问

 

1.函数

2.变量

对函数的作用

外部函数:定义的函数能被本文件和其他文件访问

 内部函数;定义的函数只能被本文件访问

 默认情况下,所有函数都是外部函数(相当于带关键字extern),所以可以省略extern作用:

 完整的定义和引用一个外部函数都加extern

 引用时也是默认是外部函数所以也省略extern

 

 static作用:定义一个内部函数

使用:static返回类型函数名(参数列表)

不能被其他文件调用

 

一个项目中,本文件的外部函数名不能和其他文件的外部函数同名(error)

本文件中的内部函数(static)可以和其他文件的函数名同名的

对变量的作用:

全局变量分为两种:

外部变量:定义的变量可以被其他文件访问

1.默认情况下所有的全局变量都是外部变量

2.不同文件中的同名外部变量都代表同一个

3.定义一个外部变量不加extern,声明才加extern

同样的声明是没有错误的

内部变量:定义的变量不能被其他文件访问

不同文件的同名内部变量互不影响

转载于:https://www.cnblogs.com/qiang0901/p/4466931.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值