展开全部
磁盘上的数据是顺序存储的,你可以想象为一个数组。如果在中间添加一个新数据,那么后面的数据都得后移。如果提供这样的写入方式,那么每添加一个新数据就把数据往后挪一次,这显然是非常非常浪费时间的,而且文件越大(100M),插入次数越多(1秒1万次),越明显。正因为如此硬盘本身就不支持这个操作(至少目前没听说过),而C语言系统更不会支持这样的低效率的操作了。
理论上是可以对文件进行修改的,但那是在二进制的条件下。比如二进制方式存储的110和11都是占的4个字节,可以直接把110改为11。但是ASCII编码的情况下,110占三个字节,11占两个字节,把11修改为110文件的后面部分就需要移动。
删除操作同理。
C语言在二进制读写的方式下,可以将文件指针移动到某个位置,从该位置开始写入,但是那样的话后面的东西都会清除掉。
理论上是可以对文件进行修改的,但那是在二进制的条件下。比如二进制方式存储的110和11都是占的4个字节,可以直接把110改为11。但是ASCII编码的情况下,110占三个字节,11占两个字节,把11修改为110文件的后面部分就需要移动。
删除操作同理。
C语言在二进制读写的方式下,可以将文件指针移动到某个位置,从该位置开始写入,但是那样的话后面的东西都会清除掉。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询