Jag tänkte göra ett enkelt krypteringsprogram. Fast nu behöver jag visst hjälp. Detta är fjärde forumet jag testar i, ingen har kunnat ge mig ett vettigt svar ännu. Så här ser min kod ut:
fstream, seekp(), read(), write()
#include <fstream>
#include <iostream>
using namespace std;
int main () {
int countRead;
fstream OFile("enfil.txt", ios_base::out | ios_base::in | ios_base::binary);
char buffer[1024];
char key[100] = "omfghaxx";
while (!OFile.eof()) {
memset(buffer, 0, sizeof(buffer));
countRead = 0;
int orgPos = OFile.tellg();
OFile.read(buffer, 1024);
countRead = OFile.gcount();
for(int i = 0; i < countRead; i++) {
buffer[i] = buffer[i] + (key[i%strlen(key)]);
}
if (OFile.eof()) {
OFile.clear(ios_base::goodbit);
OFile.seekp(orgPos);
OFile.write(buffer, countRead);
OFile.clear(ios_base::eofbit);
}
else {
OFile.seekp(orgPos);
OFile.write(buffer, countRead);
}
}
OFile.close();
}
Filen ”enfil.txt” är 1 092 bytes. Problemet är att när den har gått igenom while
(!OFile.eof()) slingan en gång och ska köra OFile.read(buffer, 1023); så verkar inte read få eof, utan istället rapporterar OFile.gcount(); att read har läst 1023 bytes till. Jag tror att mitt problem har nånting med seekg() att göra men jag förstår inte riktigt vad. tack för hjälpen,