十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
#includestdio.h
创新互联提供高防服务器租用、云服务器、香港服务器、成都西信服务器托管等
#includestring
void main()
{
char ch[15]="12345";
printf("覆盖之前字符为:%s\n",ch);
strcpy(ch,"1122334455");
printf("覆盖之后字符为:%s\n",ch);
}
内存里是部分覆盖了,你看以在查看内存看看。
输出XYZ我认为是因为puts(a);这样之输出一个字符串;
覆盖后数组a的前三个字节是XYZ,第四字节是结束标志\0;
第五字节开始是dfg,所以你写puts((a[4])); 就可以输出dfg
gets()函数会读入字符串数据,并在后面加'\0'。gets(b)执行之后b[]里面就是:" is red.\0s blue.\0"
众所周知,'\0'是字符串结束标志,printf 的时候到'\0'就结束字符串输出了,所以输出的就是" is red."而不是所有的内容。
如果你加上b[8] = '-';
结果就是:
Fig flower is red.
Fig flower is red.-s blue.
说明内容只是覆盖了前面的一部分,懂?
用读写r+ 或 w+ 方法打开。
if((fp=fopen("USER.txt","r+"))==NULL)
任何时候想回到文件一开始,就用回绕函数:
rewind(fp);
这样再写就覆盖了。
"a" 打开来 是 从文件尾开始添加新内容。
fwrite写入时覆盖不覆盖原来文件是用参数决定的
fwrite原型:
size_t fwrite(const void* buffer, size_t size, size_t count, FILE* stream);
返回值:返回实际写入的数据块数目
(1)buffer:是一个指针,对fwrite来说,是要获取数据的地址;
(2)size:要写入内容的单字节数;
(3)count:要进行写入size字节的数据项的个数;
(4)stream:目标文件指针;
(5)返回实际写入的数据项个数count。
是否覆盖决定于stream
FILE *stream=fopen("文件名","mod");
其中mod如下:
(1)r 以只读方式打开文件,该文件必须存在。
(2)r+ 以可读写方式打开文件,该文件必须存在。
(3)rb+ 读写打开一个二进制文件,允许读写数据,文件必须存在。
(4)w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
(5)w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
(6)a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
(7)a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)
(8)wb 只写打开或新建一个二进制文件;只允许写数据。
(9)wb+ 读写打开或建立一个二进制文件,允许读和写。
(10)ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
fwrite函数是覆盖而不是插入。
只要打开文件时知名支持写操作,那么使用fwrite函数时均是覆盖模式,而不会插入。
即在当前位置写入数据,后续数据并不会依次后移,而是直接覆盖。
比如,如果文件中有数据123456789,在3的位置写入字符abc,那么结果为
12abc6789。
如果要实现插入效果,可以将后续数据读到内存,然后写入要写的数据,再写入原本读出的数据。