const char* concatenation
-
22-09-2019 - |
Вопрос
Мне нужно объединить два такими частями:
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;