C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数

简介: 本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。

位运算和c语言文件操作详解

1. 位运算

位运算的操作对象只能是整型或字符型数据
C语言提供6种位运算符:
& 按位与
| 或
^ 异或
~ 取反
<< 左移
>> 右移

复合赋值运算符:
&=,|= ,^=,<<=,>>=

1.1 按位与运算

1&1=111
1&0=000
0&1=0
0&0=0
作用:清零

1.2 按位或运算

11=111
10=100
01=1
00=0
作用:将特定位置1

1.3 按位异或运算

1^1=0 相异为1
1^0=1 相同为0
0^1=1
0^0=0
作用:将特定位置1

1.4 按位取反运算

按位取反运算符是一个单目运算符。按位取反后0变1,1变0
计算机流程是将按位取反的数转换为2进制数,这个2进制数按位取反,然后再转换回原来的进制

速算技巧:对一个数按位取反得到的值为该数+1后再乘以-1

1.5 按位左移运算(<<)

格式:数<<n
功能:将二进制位按位依序左移n位

速算技巧:对一个十进制数左移n位后得到的值为该数乘以2^n^的积

1.6 按位右移运算(>>)

格式:数>>n
功能:将二进制位按位依序右移n位

速算技巧:若该数为一个负数并且不能被2^n^整除得到的数为商加-1

例题分析:

a)100  b)80 c) 64 d)32
main()
{
   
    char x=040;
    printf("%O\n",x<<1);
}

x=0408进制
%O是8进制输出 
x=040转换为2进制,再转10进制 是32
左移动 *264
64转换为8进制是100

2. 文件

2.1 文件概念

1.文件:记录在外部存贮介质(外存)上的数据的集合。

2.文件的分类:
文件文本(ASCII码文件):每个字符存储到文件中。
二进制文件:以二进制存储
c语言中对文件的存取是以字符(字节)为单位的。

3.文件类型指针
考试中,记住FILE就是文件类型名,它是一个结构体类型。对一个文件进行操作,通过文件指针进行的,定义如下:
FILE fp,in,*out;

2.2 文件的打开与关闭

2.2.1 文件的打开(fopen()函数)

格式:fopen(文件名,文件使用方式)
功能:按指定的"使用方式"打开文件,函数返回所打开==文件的指针==,该指针的基类型为文件类型。文件名和文件使用方式均为字符串。

如:以只读的方式打开文件data.txt,并用指针变量fp指向它。

FILE *fp;    //FILE可以理解为一种类型名,是文件的类型名
fp=fopen("data.txt","r")

格式:open(文件名,文件使用方式)
打开文件的“使用方式”:

12种,4种基本的,9种混合的
"r":打开已存在文件
"w":刷新写 创建写
"a":追加写 创建写
"+":r+ 增强

"r+" "w+" "a+"
"rb" "wb" "ab"
"rb+" "wb+" "ab+"

注意的点:

(1)文件使用方式只能用小写字母,文件名用大写或小写均一样。
如:
FLIE *fp;
fp=fopen("c:\\tc\\data.txt","w");
其中的\\是转义
(2)在"文件使用方式"中若含有字母b,则打开的是一个二进制文件(bit)
(3)当fopen"打开"失败时,函数返回NULL.
if((fp=fopen(文件名,文件使用方式))==NULL)
{
printf("can not open this file\n");
exit(0);
}
上述代码中,要注意的点是括号,==运算符号,优先级高于=

2.2.2 文件的打开(fclose()函数)

文件使用完后应该关闭该文件
格式:fclose(文件指针)
如:fclose(fp);

2.3 文件的写入读出

2.3.1 fputc()与fgetc()

(1)fputc()
格式:fputc(字符,文件指针)
功能:把一个字符写到文件指针所指的文件中。其中字符可以是字符常量也可以是字符变量。若输出成功则返回输出的字符,失败则返回EOF(stdio.h中定义为-1)

(2)fgetc(文件指针)
功能:从文件指针所指文件中读取一个字符。若读取成功则函数返回读取的字符,失败(遇到文件结束)则返回EOF

2.3.2 fgets()与fputs()

(3)fgets()
格式:fgets(str,n,fp)
功能:其中str表示一个字符指针,可以是字符数组名也可以是字符指针变量名。从fp所指文件中读取n-1个字符(不是n个字符),并在这些字符最后加一个字符串结束符'\0'后赋给str
函数返回str的首地址

(4)fputs()
格式:fputs(str,fp)
功能:向fp所指文件中写出(输出)str中的字符串,str可以是字符串,str可以是字符串常量,字符数组或字符指针变量。在输出时字符串的结束符'\0'不输出。若输出成功则返回0,失败返回EOF

2.3.3 fread()与fwrite()

(5)fread(),fwrite()
格式:
fread(buffer, size, count,fp);
fwrite(buffer, size, count,fp);

其中:
buffer是数据的地址
size是每次读写的字节数
count表示让函数进行多少次的读写
fp是要进行读写的文件指针变量
功能:用来读写一个连续的数据块
注:
(1)这两个函数按二进制方式进行读写

2.3.4 fprintf()与fscanf()

(6)fprintf(),fscanf()
格式:
fprintf(文件指针,格式说明符,输出列表);
fscanf(文件指针,格式说明符,输入列表);
功能:按格式说明符所指定的格式向文件中读写(输入输出)数据。其中格式说明符河输入(输出)列表的用法与scanf和printf函数相同。

补充:feof(文件指针)
作用是测试文件的当前读写位置是否在文件末尾,若是则返回非0值(真),否则返回0(假)。

while(!feof(fp))
{
   /写 文件
}

2.4 文件当前读写位置函数

2.4.1 rewind()

(1)rewind()
格式:rewind(文件指针)
作用:使当前的读写位置重新指向文件的开头。函数无返回值。

2.4.2 fseek()

(2)fseek()
格式:fseek(文件指针,位移量,起始点)
功能:将当前的读写位置从"起始点"开始按"位移量"所指定的移动字节数向后移动。

起始点有:
SEEK_SET 或0 (表示“文件的开始”)
SEEK_CUT 或1 (表示“当前位置”)
SEEK_END 或2 (表示文件末尾)

SEEK_SET 是宏名 0是宏内容

位移量:要在数值后加字母l或L
如:

fseek(fp,100L,SEEK_SET)

给出例题:
将位置指针定位到离文件头50个字节的地方
fseek(fp,50L,0)
将位置指针定位到离文件尾50个字节的地方
fseek(fp,-50L,2)
将位置指针定位到离文件头0个字节的地方
三种方法:
方法1:fp=fopen();
方法2:rewind(fp);
方法3:fseek(fp,0L,0);

2.4.3 ftell()

(3)ftell()
格式:ftell(文件指针)
功能:返回当前文件的位置,用相对于文件头的位移量表示。若返回-1L表示出错

相关文章
|
7天前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
46 16
|
7天前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
19 3
|
7天前
|
存储 算法 安全
【C语言程序设计——函数】分数数列求和1(头歌实践教学平台习题)【合集】
if 语句是最基础的形式,当条件为真时执行其内部的语句块;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。常量的值必须是唯一的,且在同一个。
11 2
|
11天前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
41 1
|
存储 C语言
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(下)
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(下)
|
Linux 编译器 C语言
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(上)
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(上)
|
机器学习/深度学习 移动开发 C语言

热门文章

最新文章