Portál AbcLinuxu, 13. července 2025 18:58
#include <string.h> char *src = "abcdef"; char *var = NULL; var = strndup(src + 1, 3);Stejně jako to, co jsi napsal v PHP, ani tohle nefunguje s UTF-8.
#include < string > std::string s = "abcdef" std::string novy = s.substr(1,3)
std::string s("abcdef"); std::cout << s.substr(1, 3) << "\n"; std::string ss = s.substr(1, 3);
Projdete si dokumentaci k std::basic_string, tam toho najdete vic. Pokud se nejedna ciste o studijni zvedavost, tak bych vam doporucil pouzit standardni prostredky a o rychlost/pametovou narocnost se zacnete starat az ve chvili, kdy vam zacne byt na prekazku. Napsat pouzitelnou retezcovou tridu tak, aby umoznovala sdileni i substringu rozhodne neni zadna prdel. Mimochodem, to phpko vam kopii vytvori.
Jak jiz Pan Kufner zminil, je treba zavolat free(). Pokud ho nezavolate, pamet zustane alokovana po celou dobu zivota programu. A v tom vasem prikladu nevratne, protoze jste ukazatel vraceny strndup() de facto zahodil.
char* s = strndup(src + 1, 3); printf("Test %s\n", s); free(s);
vim ~/.emacs
char *str = strdup("abcdef"); // nějak se do str dostal řetězec char *var; var = str + 1; // uříznem začátek var[3] = 0; // uříznem konecDej si pozor na to, co pak budeš uvolňovat. free(var) bude dělat blbosti.
#ifdef OSKLIVY_WINDOWS char *strndup(const char *src, int count) { char *r; r = strdup(src); r[count] = 0; return r; } #endif
To už spíš takhle:
char* strndup(const char* src, size_t count) { char* np = (char*) malloc(count+1); if (np) { strncpy(np, src, count); np[count] = '\0'; } return np; }
A ještě poznámku: místo '#ifdef OSKLIVY_WINDOWS
' by bylo na místě spíš něco jako '#ifndef _GNU_SOURCE
', protože strndup()
není v žádné POSIX specifikaci, je to GNU extension.
V každém případě bych ale v C++ upřednostnil použití třídy std::string
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.