共用方式為


char_traits::move

複製指定的字元數序列中加入另一個,可以重疊的。

這個方法可能不安全的,因為它,取決於呼叫端檢查傳遞的值是正確的。 因此,請考慮改用 char_traits::_Move_s

static char_type *move( 
   char_type* _To,  
   const char_type* _From,  
   size_t _Num  
);

參數

  • _To
    在目標的字串或字元陣列開頭的項目接收字元複製的序列。

  • _From
    要複製的來源字串或字元陣列開頭的項目。

  • _Num
    從來源資料將複製的元素數。

傳回值

第一個 _To 項目複製到目標的字串或字元陣列接收字元複製的序列。

備註

來源和目的可能重疊。

範例

// char_traits_move.cpp
// compile with: /EHsc /W3
#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;
   // Note: char_traits::move is potentially unsafe, consider
   // using char_traits::_Move_s instead.
   result1 = char_traits<char>::move ( sTo1 ,  sFrom1 , 4 );  // C4996
   cout << "The result1 = move ( 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' );
   // Note: char_traits::move is potentially unsafe, consider
   // using char_traits::_Move_s instead.
   result2 = char_traits<char>::move ( sToFrom2 , findc , 8 );  // C4996
   cout << "The result2 = move ( sToFrom2 , findc , 8 ) is: "
        << result2 << endl;
}
  

需求

標頭:<string>

命名空間: std

請參閱

參考

char_traits 結構