对于数组type a[N], 要将其写入文件有两种方式可以使用。
1 将数组以二进制方式写入文件。如
fwrite(a, sizeof(a), 1, fp)
可以将数组整体以二进制方式写入文件中。
2 按照元素,依次写入文件。具体写入格式与数组的类型有关。如为int数组可以写作:
int i
for(i = 0i <Ni++)
fprintf("%d,", a[i])
两种方法各有优缺点:
1 代码量上,第一种方式更简单高效;
2 运行效率上,第一种方法的执行效率更高;
3 文件空间大小上:
如果数组中的字符串元素较多,那么二者写入后目标文件大小相似,或者第二种方式占用的空间较小。
如果数组中的整型或浮点型数据较多,那么第一种方式占用的空间较小。
4 目标文件可读性:
第一种方法得到的文件是二进制文件,需要用专门的阅读器打开,且必须是专业人士才可以读懂。
第二种方法更直观,直接打开文本文件就可以阅读输出结果。
的字符串输出到fp所指向的文件中(这个就是把HELLO写到PRN文件中)4、首先*a[2]是一个指针数组就相当于一个二维数组(这个你可以看成是a[2][3]的二维数组),而**p=a就是把这个二维数组的首地址赋值给p
那么p现在指向了二维数组中第一个字符的地址(p现在指向了"one"首地址,现在指向了o)
第一条输出语句:
printf("%s",*(p++)+1)那么*(p++)就是先使用*p然后p在自加一次,这时*p指向o地址然后*p+1那么此时*p就指向了n的地址,因为在输出语句里使用的是%s(它可以从当前地址一直输出到这个串的结尾),因此第一条输出结果就为ne
第二条输出语句:
printf("%c",**p-1)因为p在上一次输出语句中自加了一次,那么这时p就指向了下一个字符串的位置(即:p指向了t),而**p表示的是一个值(即:**p=t),再加上**p-1也就是t-1,而t-1在ASCII码中表示的是s,又因为%c是输出一个字符因此就输出一个s
那么最后结果就是nes了
注:a[0]就是"one"字符串的首地址,a[0][0](或者**p)就相当于o,而*p+1就相当于n了,如果在执行p=p+1这时**p就指向了下一个字符串即:t
a[1]就是"two"的首地址,而a[1][0]就相当于t
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)