字符串和字符不兼容

string and char incompatibilities

本文关键字:不兼容 字符 字符串      更新时间:2023-10-16

我很惊讶在c++中没有一个内置的方法来强制转换字符串和字符。这是我的问题:我想更新文本文件中的一行,所以:

#include <stdlib.h>
#include <fstream>
#include <windows.h>
#include <iostream>
#include <stdio.h>
using namespace std;
int main(void) {
  char l1 [12];
  char l2 [15];
  char l3 [15];
  char l4 [15];
  char md [16];
  FILE * myfile2 = fopen("state.txt", "r+");
  fgets(l1,12,myfile2);
  fgets(l2,12,myfile2);
  fgets(l3,12,myfile2);
  fgets(l4,12,myfile2);
  fseek ( myfile2 , 0 , SEEK_SET );
  strcpy(md , "detectoroff");
  fputs (md,myfile2);
  strcpy(md,l2);
  fputs (md,myfile2);
  strcpy(md,l3);
  fputs (md,myfile2);
  strcpy(md,l4);
  fputs (md,myfile2);
  Sleep(1000);
  fclose(myfile2);
  return EXIT_SUCCESS;
}

最初的文本文件有

    a
    b
    c
    d

当运行代码时,输出是

detectoroffb
    c
    d

如果我替换行

  strcpy(md , "detectoroff");
由这个

  strcpy(md , "detectoroffn");

现在的结果是ok的,但如果我运行这两次,出现在第一个空行和另一个如果它运行三次等。如何解决这个问题?

修改l1的声明为:

char l1 [13];

detectoroff是11个字符。换行符需要另一个字符,空字节需要另一个字符,表示字符串的结束,总共是13。由于您仅用12个字符声明l1,因此fgets()写入数组边界之外。这将导致未定义的行为。

使用std::string和c++流方法,你就不会遇到这样的问题了

不要害怕使用几千字节。

#include <cstdlib>
#include <cstdio>
int main(void) {
  using namespace std;
  static const int BUFFERSIZE = 4096;
  char line_1[BUFFERSIZE];
  char line_2[BUFFERSIZE];
  char line_3[BUFFERSIZE];
  char line_4[BUFFERSIZE];
  char md [] = "detectoroffn";
  FILE * myfile2 = fopen("state.txt", "r+");
  fgets(line_1, BUFFERSIZE, myfile2);
  fgets(line_2, BUFFERSIZE, myfile2);
  fgets(line_3, BUFFERSIZE, myfile2);
  fgets(line_4, BUFFERSIZE, myfile2);
  fseek(myfile2, 0, SEEK_SET );
  fputs(md, myfile2);
  fputs(line_2, myfile2);
  fputs(line_3, myfile2);
  fputs(line_4, myfile2);
  fclose(myfile2);
  return EXIT_SUCCESS;
}

最好是用c++而不是C风格编写这个程序:

#include <fstream>
#include <string>
int main(void) {
  using namespace std;
  string line_1, line_2, line_3, line_4;
  string md("detectoroff");
  fstream myfile2("state.txt", fstream::in|fstream::out);
  getline(myfile2, line_1);
  getline(myfile2, line_2);
  getline(myfile2, line_3);
  getline(myfile2, line_4);
  myfile2.clear();
  myfile2.seekg(0, ios::beg);
  myfile2
    << md << 'n'
    << line_2 << 'n'
    << line_3 << 'n'
    << line_4 << 'n';
  myfile2.close();
  return 0;
}