您的位置:首页 > 编程语言 > C语言/C++

C语言学习总结(四) 剩余内容

2015-12-11 17:03 239 查看

第六章、剩余内容

(预处理指令,宏定义,条件编译,文件操作)

预处理指令

简单的来说就是在程序编译之前需要做的事情





1.宏定义

概念:

是一个替换代码的预处理指令,可以在编译之前进行代码替换(宏展开,条件编译,文件包含).

当需要用一些重复性代码或简单的函数运算时,可以用宏定义.提高效率

用法:

开始替换: #define 被替换内容 替换成的内容

如:

#define ka1 6

表示从这行开始下面所有代码中的ka1 替换成6

结束替换:

#undef 被替换内容

如: #undef ka1 表示到一行, 宏定义失效

特点:

命名尽量以大写或小写k开头.便于区分.(规范)

被双引号的引起来的不会被替换

宏定义只会做代码替换,不会关注任何逻辑,容易出现优先级错误(加括号解决).

替换可以设置作用域.如果不设置,作用域则是这行代码出现到代码的最后一行.

2.条件编译

概念:

是一个根据条件编译代码的预处理指令,可以让一段代码只在满足条件才编译.提高编译效率

使用:

#if 条件表达式

#elif 条件表达式

#else

与宏定义相关:

#ifdef 宏名 表示定义了宏

#ifndef 宏名 表示没有定义宏

#endif 结束条件编译.注意一定要加.

四,什么时候用?

当一些代码只需要在一定条件下编译时.

五,有什么特点?

1.条件编译不能访问需要编译后才能执行的代码.

2.条件编译不需要用大括号,所以必须加上结束标识,否则涵盖下面的所有代码.

3.条件编译一般跟宏定义配合使用,防止重复包含及交叉包含.

头文件

一,是什么?

是C语言中以.h结尾的文件,如stdio.h .

二,有什么用?

用于声名(描述)一个函数,把多个代码文件(如a.c;b.c;…)中的函数,声明在这个文件中,以便于重用 、防止定义的冲突.

三,怎么用?

定义: 新建一个以.h结尾的文件,把需要用到的函数的声名直接放在里面.

引用: 自定义的头文件:#include “头文件名.h”

编译器类库里的头文件:#include <头文件名.h>

四,什么时候用?

当程序需要由多个c文件组成时.

五,有什么特点?

1.在头文件中仅做声名,不做具体实现

2.在头文件有声名只能确保编译成功成.o文件;但不确保能链接成功.

3.自定义的头文件引用时必须要有路径.

#include的使用

一,是什么?

是C语言中的一个预处理指令.

二,有什么用?

用于把一个文件的内容拷贝到这行命令所在的位置.

三,怎么用?

引用: 自定义的文件:#include “文件路径和名称”

编译器类库里的文件:#include <文件名>

四,什么时候用?

当程序需要用到别的文件时.

文件操作(OC中有单独的文件操作方法,这里作为了解)

概念:

是对文件或文件内容的输入(读)与输出(写). 文件操作的函数在<stdio.h>中声名.

文件的操作流程:

1)导入头文件 stdio.h

2) 定义文件指针

3)打开文件

4)操作文件

5)关闭文件

操作原理:

3、文件指针

FILE 结构体

FILE *fp; 结构体指针
作用:存储一个文件的首地址,指向一个文件

4、文件的打开和关闭

打开 fopen(文件名,操作方式);

fopen("a.txt","r");

//a.txt默认的去products目录去 找,/Users/apple/Library/Developer/Xcode/DerivedData/C15-综合项

目- cmassyrpkwjxularuygrjqhojbwj/Build/Products/Debug

fopen("/Users/apple/Desktop/a.txt","r");

操作方式:

rwab+t : 读写追加二级制读写文本

w -- 写入文件的时候,如果文件不存在,则创建存在则覆盖

r+ w+ wb+ a+

关闭文件: fclose(文件指针);

5、文件操作的函数

1) 字符型数据的读取和写入

写入:
fputc('字符',文件指针);

char c='A';

fputc(c,fp);

读取:

char ch = fgetc(fp); 2)字符串类型数据的读取和写入

写入:

fputs(数组名/指针名,fp); //fputs(数组名,stdout);

读取:

fgets(数组名/指针名,长度,fp);

fgets实际读取的字符个数是长度-1

1)遇到\n 结束,遇到EOF也会结束

3)数据块的读取和写入

写入:

fwrite(写入的变量地址,数据块的大小,块数,fp);

int a =123;
fwrite(&a,sizeof(int),1,fp);

struct Student stu1;

fwrite(&stu1,sizeof(struct Student),1,fp);

读取:

struct Student s1;

fread(变量的地址,数据块的大小,块数,fp)

fread(&s1,sizeof(struct Student),1,fp); //使用s1进行输出

4)格式化的读取和写入

写入数据和读取数据按照一定的格式进行

写入:

fprintf(文件指针,"格式化的字符串",变量列表);

fprintf(fp,"%d,%c,%d#",10,'a',20);

10,a,20#10,a,20#10,a,20#

读取

fscanf(fp,"%d,%c,%d#",&a,&ch,&b);

fprintf(fp,"%d,%s,%d",20,"abc",30);

fscanf(fp,"%d,%s,%d",&a,str,&b);

str = abc,30

改成:

fprintf(fp,"%d,%d,%s",20,20,"abc");

fscanf(fp,"%d,%d,%s",&a,&b,str);

6、文件的随机读取

设定文件的头指针的位置

默认fp是指向文件的首地址

1)rewind(fp); //fp指向首地址

2)fseek(fp,偏移的距离,起始点);

fseek(fp,32L,SEEK_SET); //从文件头部开始,偏移32个字节

7、文件的检测函数

feof() 用来检测文件是否到了末尾

如果没有到末尾 0

到末尾 1

缺点:多执行一次



特点:

1.打开文件的模式限定操作的方式.

2.打开操作文件后一定要关闭文件,否则容易引起内存泄漏.

3.输入与输出是相对于操作者而言.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: