Вектор распечатывает неправильное значение - PullRequest
0 голосов
/ 12 октября 2011

Привет, я получил вопрос по поводу следующего кода.Я скопирую строку символа, которую я прочитал из файла, в вектор и распечатаю этот вектор на экранепрограмма скопирует строку из текстового файла, но вектор выдает только последний элемент вектора.что я тут не так ??:

#include <fstream>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <string.h>
#include <sstream>
#include <vector>
#include "mbusread.h"
using namespace std;


int main()
{

    int dev_nr;
    int anzahl;
    ifstream addr;
    string buffer;
    string dev_no;
    stringstream devss;
    char *reg_no_c = new char [buffer.length()+1];
    char *start_reg_c = new char [buffer.length()+1];
    char *adresse_c = new char [buffer.length()+1];
    char *id_c = new char [buffer.length()+1];
    char *zeit_c = new char [buffer.length()+1];

    addr.open("Addr.xml", ios::in); //Addressendatei auslesen
    do //Anzahl suchen
    {
        getline(addr, buffer);
    }   while(strcmp (buffer.c_str(), "<Anzahl>")!=0);
        getline(addr, buffer);

        stringstream bufferss(buffer);
        bufferss >> anzahl;
        anzahl++;

        vector<const char *> ip(anzahl);
        vector<const char *> start_reg(anzahl);
        vector<const char *> reg_no(anzahl);
        vector<const char *> id(anzahl);
        vector<const char *> zeit(anzahl);


    for(dev_nr=1;dev_nr<anzahl;dev_nr++)
    {
        addr.seekg(ios::beg);
        devss << "<dev" << dev_nr << ">";
        dev_no = devss.str();
        devss.str("");
        devss.clear();

        do {
            getline(addr, buffer);
            if(addr.eof())
            {
             break;
            }
          } while (strcmp (buffer.c_str(),dev_no.c_str()) != 0);

        do // ip suchen
        {
            getline(addr, buffer);
        }while(strcmp (buffer.c_str(), "<ip>")!=0);
        getline(addr, buffer);
        if(addr.eof())
        {
         break;
        }
        strcpy(adresse_c, buffer.c_str()); // ip einlesen
        ip[dev_nr - 1] = adresse_c;
        cout << ip[dev_nr - 1] << endl;

        do // start_reg suchen
        {
            getline(addr, buffer);
        }while(strcmp(buffer.c_str(), "<start_reg>")!=0);
        if(addr.eof())
        {
         break;
        }
        getline(addr, buffer);              //Schreibt Startregister in Daten
        strcpy(start_reg_c, buffer.c_str()); // ip einlesen
        start_reg[dev_nr - 1] = start_reg_c;
        cout << start_reg[dev_nr - 1] << endl;

        do // reg_no suchen
        {
            getline(addr, buffer);
        }while(strcmp(buffer.c_str(), "<reg_no>")!=0);
        if(addr.eof())
        {
         break;
        }
        getline(addr, buffer);              //Schreibt die Anzahl der ausgelesenen Register in Daten
        strcpy(reg_no_c, buffer.c_str()); // ip einlesen
        reg_no[dev_nr - 1] = reg_no_c;
        cout << reg_no[dev_nr - 1] << endl;

        do // ID suchen
        {
            getline(addr, buffer);
        }while(strcmp(buffer.c_str(), "<ID>")!=0);
        if(addr.eof())
        {
         break;
        }
        getline(addr, buffer);              //Schreibt die ID des Sensors in Daten
        strcpy(id_c, buffer.c_str()); // ip einlesen
        id[dev_nr - 1] = id_c;
        cout << id[dev_nr - 1] << endl;

        do
        {
            getline(addr, buffer);
        }while(strcmp(buffer.c_str(), "<Time>")!=0);
        if(addr.eof())
        {
            break;
        }
        getline(addr, buffer);
        strcpy(zeit_c, buffer.c_str()); // ip einlesen
        zeit[dev_nr - 1] = zeit_c;
        cout << zeit[dev_nr - 1] << endl;

    }

    for(int i = 0; i < anzahl; i++)
    {
        cout << "ip " << ip[i] << endl;
        cout << "id " << id[i] << endl;
        cout << "start_reg " << start_reg[i] << endl;
        cout << "reg_no " << reg_no[i] << endl;
        cout << "zeit " << zeit[i] << endl;
    }
}

Ответы [ 2 ]

1 голос
/ 12 октября 2011

Не настоящий ответ, но я считаю, что вы действительно должны научиться читать XML-файл. Ваш код настолько запутан, хотя на самом деле он просто пытается «взломать» синтаксический анализ xml-файла, и многие считают, что исправлять его не стоит.

0 голосов
/ 14 октября 2011

Ваша проблема начинается прямо вверху кода

string buffer;
string dev_no;
stringstream devss;
char *reg_no_c = new char [buffer.length()+1];
char *start_reg_c = new char [buffer.length()+1];
char *adresse_c = new char [buffer.length()+1];
char *id_c = new char [buffer.length()+1];
char *zeit_c = new char [buffer.length()+1];

А эта точка buffer пуста, поэтому length() возвращает 0, и вы выделяете только один байт для строк С.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...