Предположим, у меня есть следующий код:
fid = fopen(my_filename,'w','ieee-le','ISO-8859-1');
fwrite(fid,1,'short',10,'ieee-le')
Тогда это откроет ранее указанный файл, пропустит первые 10 байтов и запишет 1 в следующие два.
Но что происходит с первыми 10 байтами, если открытый файл раньше не существовал? Если бы я получил доступ к одному из них, что бы я в итоге получил и почему?
Я использую Linux, мой дистрибутив Ubuntu.





В таких вопросах самый простой способ выяснить это, как правило, попробовать самому, если это не слишком сложно. Теперь вы указали, что используете линукс, возможно, вы можете повторить тест на своей платформе и посмотреть, совпадают ли результаты.
Для платформы Окна значение skip:
00 (вероятно, то, что ОС присваивает как новое значение для файла)Примеры:
Этот код:
fid = fopen(my_filename,'w','ieee-le','ISO-8859-1');
fwrite(fid,1,'short',10,'ieee-le')
fclose(fid)
Создает следующий файл (видимый в шестнадцатеричном редакторе):

И если у вас есть более одного значения для записи:
fid = fopen(my_filename,'w','ieee-le','ISO-8859-1');
fwrite(fid,[1 2 3],'short',10,'ieee-le')
fclose(fid)
Вы по-прежнему получаете 10x значений 00 перед каждым значением short, которое вы активно пишете:

Это имело место для вновь созданного файла. Давайте посмотрим, что случилось с существующим файлом:
%% Let's create a file full of `FF`
FFarray = uint8(ones(36,1)*255) ;
fid = fopen(my_filename,'w','ieee-le','ISO-8859-1');
fwrite(fid,FFarray,'uint8')
fclose(fid)
Теперь, используя тот же код, что и раньше (с установленным permission на w):
fid = fopen(my_filename,'w','ieee-le','ISO-8859-1');
fwrite(fid,[1 2 3],'short',10,'ieee-le')
fclose(fid)
Да, мы все еще получаем то же самое. Теперь это согласуется с документацией MATLAB для указанного вами разрешения:
w => Откройте или создайте новый файл для записи. Отменить существующее содержимое, если есть.
Если вы просто измените это разрешение на r+ (Открыть файл для чтения и записи.):
fid = fopen(my_filename,'r+','ieee-le','ISO-8859-1');
fwrite(fid,[1 2 3],'short',10,'ieee-le')
fclose(fid)
Вы перезаписываете только непропущенные значения:

Я бы обязательно попробовал это завтра, если бы Крис Луенго еще этого не сделал. Все равно спасибо!
The
fseek()function shall allow the file-position indicator to be set beyond the end of existing data in the file. If data is later written at this point, subsequent reads of data in the gap shall return bytes with the value 0 until data is actually written into the gap.
Таким образом, если предположить, что MATLAB fwrite использует fseek для пропуска byes (что весьма вероятно), то пропущенные байты после конца файла будут заполнены нулями на любой POSIX-архитектуре (Linux, MacOS). Это не обязательно относится к Windows, которая не является POSIX.
Быстрый тест на MacOS подтверждает это поведение:
fn = 'test.bin';
fid = fopen(fn,'wb');
fwrite(fid,1,'uchar',10);
fclose(fid);
fid = fopen(fn,'r');
fread(fid,Inf,'uchar')
fclose(fid);
вывод:
ans =
0
0
0
0
0
0
0
0
0
0
1
Я не знаю точно, но я предполагаю, что это может быть ответ, зависящий от платформы. Я почти уверен, что MATLAB просто передает эти команды в ОС, поскольку они имитируют имена и функции файлов POSIX. Пожалуйста, укажите ОС, которую вы используете!