char_traits::_Move_s
Copie un nombre spécifié de caractères dans une séquence à un autre, chevauchant probablement la séquence.
static char_type *_Move_s(
char_type *_Dest,
size_t _Dest_size,
const char_type *_From,
size_t _Count
);
Paramètres
_Dest
L'élément au début de la chaîne ou du tableau de caractères ciblé pour accepter la séquence copiée de caractères._Dest_size
La taille d' _Dest.Si char_type est char, alors il s'agit en octets.Si char_type est wchar_t, alors il s'agit des mots._From
L'élément au début de la chaîne ou de la table de source à copier._Count
Nombre d'éléments à copier de la chaîne source.
Valeur de retour
Le premier élément _Dest est copié dans la chaîne ou un tableau de caractères ciblé pour accepter la séquence copiée de caractères.
Notes
La source et de destination peuvent se chevaucher.
Exemple
// char_traits__Move_s.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type sFrom1[] = "abcd-1234-abcd";
char_traits<char>::char_type sTo1[] = "ABCD-1234";
char_traits<char>::char_type* result1;
cout << "The source string sFrom1 is: " << sFrom1 << endl;
cout << "The destination stringsTo1 is: " << sTo1 << endl;
result1 = char_traits<char>::_Move_s(sTo1,
char_traits<char>::length(sTo1), sFrom1, 4);
cout << "The result1 = _Move_s(sTo1, "
<< "char_traits<char>::length(sTo1), sFrom1, 4) is: "
<< result1 << endl << endl;
// When source and destination overlap
char_traits<char>::char_type sToFrom2[] = "abcd-1234-ABCD";
char_traits<char>::char_type* result2;
cout << "The source/destination string sToFrom2 is: "
<< sToFrom2 << endl;
const char* findc = char_traits<char>::find(sToFrom2, 4, 'c');
result2 = char_traits<char>::_Move_s(sToFrom2,
char_traits<char>::length(sToFrom2), findc, 8);
cout << "The result2 = _Move_s(sToFrom2, "
<< "char_traits<char>::length(sToFrom2), findc, 8) is: "
<< result2 << endl;
}
Configuration requise
en-tête : <string>
l'espace de noms : DST