Ссылка на строку, не обновляемая при вызове функции в C ++

StackOverflow https://stackoverflow.com/questions/2057523

  •  20-09-2019
  •  | 
  •  

Вопрос

Я пишу библиотеку arduino для отправки http-запроса в Интернете.

Я использую класс String из http://arduino.cc/en/Tutorial/TextString

Мой код ведет себя странно, когда я ссылаюсь на свои определенные строковые объекты после вызова функции.

Здесь на самом деле я пытаюсь получить тело моего GET-запроса и удаляю http-заголовки из ответа http GET-запроса.

Ниже приводится описание:

Вызов метода:

  String body;  
  if(pinger.Get(host,path,&body))
  {
    Serial.println("Modified String Outside :");
    Serial.println(body);
    Serial.println();
    Serial.println("Modified String Outside Address");
    Serial.println((int)&body);
  }

Выходной сигнал

Modified String Outside :
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Content-Type: text/html
Content-Length: 113
Date: Wed, 13 Jan 2010 14:36:28 GMT

<html>
<head>
<title>Ashish Sharma
</title>
</head>
<body>
Wed Jan 13 20:06:28 IST 2010
</body>
</html>


Modified String Outside Address
2273

Описание метода:

bool Pinger::Get(String host, String path, String *response) {
    bool connection = false;
    bool status = false;

    String post1 = "GET ";
    post1 = post1.append(path);
    post1 = post1.append(" HTTP/1.1");

    String host1 = "Host: ";
    host1 = host1.append(host);

    for (int i = 0; i < 10; i++) {
        if (client.connect()) {
            client.println(post1);
            client.println(host1);
            client.println();
            connection = true;
            break;
        }
    }

    int nlCnt = 0;
    while (connection) {
        if (client.available()) {
            int c = client.read();
            response->append((char) c);
            if (c == 0x000A && nlCnt == 0) {
                nlCnt++;
                if (response->contains("200")) {
                        status = true;
                        continue;
                    } else {
                        client.stop();
                        client.flush();
                        break;
                    }   
            }
        }
        if (!client.connected()) {
            client.stop();
            connection = false;
        }
    }           
    response = &response->substring(response->indexOf("\n\r\n"),response->length());    
    Serial.println("Modified String: ");
    Serial.println(*response);  

    Serial.println();
    Serial.print("Modified String Address: ");
    Serial.println((int)&response);
    return status;
}

Выходной сигнал:

Modified String: 
Ø
<html>
<head>
<title>Ashish Sharma
</title>
</head>
<body>
Wed Jan 13 20:06:28 IST 2010
</body>
</html>

Modified String Address: 2259

Как видно из примера, объект string reference выдает мне правильную строку внутри метода Get, но ссылка на содержимое строки изменяется при возврате метода Get.

Это было полезно?

Решение

Если я правильно понял ваш код, вы, вероятно, захотели бы сделать что-то вроде этого:

*response = response->substring(response->indexOf("\n\r\n"),response->length());

вместо того , чтобы

response = &response->substring(response->indexOf("\n\r\n"),response->length());

Также, вероятно, нет необходимости передавать указатель (ссылка, вероятно, сделала бы код намного приятнее ).

Другие советы

Во-первых, вы модифицируете адрес строки, а не самой строки.Но адрес строки был передан функции по значению, и таким образом скопирован.Изменение его внутри функции не приведет к изменению его снаружи.

Во-вторых, этот код здесь плохой:

response = &response->substring(response->indexOf("\n\r\n"),response->length());

Потому что он создает указатель на временный объект , что означает:висячий указатель, потому что временный объект будет уничтожен после вычисления выражения.

Что ты действительно хотите передать объект по ссылке (String& response) и измените его, а не его указатель:

response = response->substring(response->indexOf("\n\r\n"),response->length());

Это должно сработать, предоставленный в String класс, который вы используете правильно, перегружает поведение оператора присваивания =.

Линия

 Serial.println((int)&response);

внутри вашей функции неправильный ответ уже является указателем (String * response), с помощью &response вы получаете указатель на указатель.
Измените его на

Serial.println((int)response);

и вы должны получить тот же адрес, что и с

 Serial.println((int)&body);

где body - это строка, а &body - указатель на строку

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top