黑马程序员————C语言总结(1)
2015-07-08 20:53
260 查看
------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------
type 增强可移植性
1.只能修饰类型
2.typedef的解释由编译器而不是预处理执行
3.受限范围比#define更灵活
int *risk[10]; //具有10个元素的数组,每个元素是一个指向int的指针
int (*oof)[3][4]; //指针指向一个3X4的int数组
int (*uof)[3][4]; //3个元素的数组,每个元素指向一个有4个元素的int数组的指针
函数指针
void(* pf)(char *); //指向函数的指针,参数与返回值必须对应
pf=show; //show表示地址
pf=show(); //是错误的 show()是值
#define SQUARE(X) X*X
预处理指令不进行计算只进行字符串的替换
SQUARE为宏标识符 x为宏的参数 x*x为替换列表
x=4;
SQUARE(x+2) ==>x+2*x+2=14
SQUARE(++x) ==> ++x*++x ==> 不确定预处理不能用增减,函数参数可以
#define SQUARE(X) (X)*(X) x+2->(x+2)*(x+2)
##运算符和#一样##运算符可用于类函数宏的替换部分,还用于类对象宏的替换部分把两个语言符号组合成单个语言符号
#define XNAME(n) X##n
#define PR(X,...) printf("message"#X":"__VA_ARGS__) //省略号只能带路最后的宏参数
#undef指令取消一个给定的#define
#define
#undef
条件编译
#ifdef MAVIS //是否定义
#include "horse.h"
#else
#endif
#ifudef 判断是否未定义
#if SYS =1
//#if后跟常量表达式
#include "horse.h"
#eif SYS=2
#include "bird.h"
#endif
type 增强可移植性
1.只能修饰类型
2.typedef的解释由编译器而不是预处理执行
3.受限范围比#define更灵活
int *risk[10]; //具有10个元素的数组,每个元素是一个指向int的指针
int (*oof)[3][4]; //指针指向一个3X4的int数组
int (*uof)[3][4]; //3个元素的数组,每个元素指向一个有4个元素的int数组的指针
函数指针
void(* pf)(char *); //指向函数的指针,参数与返回值必须对应
pf=show; //show表示地址
pf=show(); //是错误的 show()是值
#define SQUARE(X) X*X
预处理指令不进行计算只进行字符串的替换
SQUARE为宏标识符 x为宏的参数 x*x为替换列表
x=4;
SQUARE(x+2) ==>x+2*x+2=14
SQUARE(++x) ==> ++x*++x ==> 不确定预处理不能用增减,函数参数可以
#define SQUARE(X) (X)*(X) x+2->(x+2)*(x+2)
##运算符和#一样##运算符可用于类函数宏的替换部分,还用于类对象宏的替换部分把两个语言符号组合成单个语言符号
#define XNAME(n) X##n
#define PR(X,...) printf("message"#X":"__VA_ARGS__) //省略号只能带路最后的宏参数
#undef指令取消一个给定的#define
#define
#undef
条件编译
#ifdef MAVIS //是否定义
#include "horse.h"
#else
#endif
#ifudef 判断是否未定义
#if SYS =1
//#if后跟常量表达式
#include "horse.h"
#eif SYS=2
#include "bird.h"
#endif
相关文章推荐
- [leetcode-54]Spiral Matrix(C语言)
- C++ Primer学习笔记(14)——虚函数的实现机制、纯虚函数
- c语言函数指针
- cout的输出格式初探
- 错排问题--十二金钗
- c语言:typedef + struct + 指针
- sizeof和strlen
- 根据输入文件名确定输出文件名
- C++中的头文件和源文件
- LeetCode-Subsets-解题报告
- LeetCode-Binary Tree Level Order Traversal-解题报告
- C++ 之RTTI
- LeetCode-Rotate Array-解题报告
- LeetCode-Reverse Bits-解题报告
- LeetCode-Number of 1 Bits-解题报告
- LeetCode-Binary Tree Right Side View-解题报告
- LeetCode-Number of Islands-解题报告
- LeetCode-Bitwise AND of Numbers Range-解题报告
- 自学笔记-C语言复习2015年7月8日
- LeetCode-Remove Linked List Elements-解题报道