Вопрос

Мне нужно объединить два такими частями:

const char *one = "Hello ";
const char *two = "World";

Как я могу это сделать?

Я прошел это char*S из сторонней библиотеки с интерфейсом C, поэтому я не могу просто использовать std::string вместо.

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

Решение

В вашем примере один а также два указатели в ЧАР, указывая на константы ЧАР. Вы не можете изменить константы ChAR, на которые указывает эти указатели. Так что что -то вроде:

strcat(one,two); // append string two to string one.

не будет работать. Вместо этого у вас должна быть отдельная переменная (массив char), чтобы удерживать результат. Что-то вроде этого:

char result[100];   // array to hold the result.

strcpy(result,one); // copy string one into the result.
strcat(result,two); // append string two to the result.

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

C Way:

char buf[100];
strcpy(buf, one);
strcat(buf, two);

C ++ способ:

std::string buf(one);
buf.append(two);

Время компиляции:

#define one "hello "
#define two "world"
#define concat(first, second) first second

const char* buf = concat(one, two);

Если вы используете C ++, почему бы вам не использовать std::string Вместо струн C-стиля?

std::string one="Hello";
std::string two="World";

std::string three= one+two;

Если вам нужно передать эту строку в C-функцию, просто передайте three.c_str()

С использованием std::string:

#include <string>

std::string result = std::string(one) + std::string(two);

Обновлять: измененный string total = string(one) + string(two);к string total( string(one) + two ); По соображениям производительности (избегает строительства строки второй и всего временной строки)

const char *one = "Hello ";
const char *two = "World";

string total( string(one) + two );    // OR: string total = string(one) + string(two);
// string total(move(move(string(one)) + two));  // even faster?

// to use the concatenation in const char* use
total.c_str()

Еще один пример:

// calculate the required buffer size (also accounting for the null terminator):
int bufferSize = strlen(one) + strlen(two) + 1;

// allocate enough memory for the concatenated string:
char* concatString = new char[ bufferSize ];

// copy strings one and two over to the new buffer:
strcpy( concatString, one );
strcat( concatString, two );

...

// delete buffer:
delete[] concatString;

Но если вы специально не хотите или не можете использовать стандартную библиотеку C ++, используя std::string Вероятно, безопаснее.

Кажется, что вы используете C ++ с библиотекой C, и поэтому вам нужно работать с const char *.

Я предлагаю завершить эти const char * в std::string:

const char *a = "hello "; 
const char *b = "world"; 
std::string c = a; 
std::string d = b; 
cout << c + d;

Прежде всего, вы должны создать немного динамического пространства памяти. Тогда вы можете просто воплотить в него две строки. Или вы можете использовать класс String C ++ ". Старая школа C Way:

  char* catString = malloc(strlen(one)+strlen(two)+1);
  strcpy(catString, one);
  strcat(catString, two);
  // use the string then delete it when you're done.
  free(catString);

Новый способ C ++

  std::string three(one);
  three += two;

Если вы не знаете размер струн, вы можете сделать что -то вроде этого:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int main(){
    const char* q1 = "First String";
    const char* q2 = " Second String";

    char * qq = (char*) malloc((strlen(q1)+ strlen(q2))*sizeof(char));
    strcpy(qq,q1);
    strcat(qq,q2);

    printf("%s\n",qq);

    return 0;
}

Вы можете использовать strstream. Анкет Это официально устарело, но, я думаю, это все еще отличный инструмент, если вам нужно работать со строками C.

char result[100]; // max size 100
std::ostrstream s(result, sizeof result - 1);

s << one << two << std::ends;
result[99] = '\0';

Это напишет one а потом two в поток и добавить прекращение \0 с использованием std::ends. Анкет В случае, если обе строки могут в конечном итоге писать точно 99 Персонажи - так что не останется места. \0 - Мы пишем один вручную на последней позиции.

const char* one = "one";
const char* two = "two";
char result[40];
sprintf(result, "%s%s", one, two);

Подключение двух постоянных указателей ChAR без использования команды STRCPY в динамическом распределении памяти:

const char* one = "Hello ";
const char* two = "World!";

char* three = new char[strlen(one) + strlen(two) + 1] {'\0'};

strcat_s(three, strlen(one) + 1, one);
strcat_s(three, strlen(one) + strlen(two) + 1, two);

cout << three << endl;

delete[] three;
three = nullptr;
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top