次の方法で共有


codecvt::out

外部 [byte]、. のシーケンスに内部 CharType、のシーケンスを変換します。

result out(
    StateType& _State,
    const CharType* _First1, 
    const CharType* _Last1,
    const CharType*& _Next1,
    Byte* _First2, 
    Byte* _Last2, 
    Byte*& _Next2
) const;

パラメーター

  • _State
    メンバー関数の呼び出しの間で維持する変換の状態。

  • _First1
    変換するシーケンスの先頭へのポインター。

  • _Last1
    変換するシーケンスの末尾へのポインター。

  • _Next1
    最後の CharType 後の最初の変換されていない CharType へのポインターへの参照が変換されます。

  • _First2
    変換されたシーケンスの先頭へのポインター。

  • _Last2
    変換されたシーケンスの末尾へのポインター。

  • _Next2
    最後の **[byte]**変換された後の最初の変換されていない [byte] へのポインターへの参照。

戻り値

このメンバー関数は do_out (_State、_First1、_Last1、_Next1、_First2、_Last2、_Next2) を返します。

解説

詳細については、「codecvt::do_out」を参照してください。

使用例

// codecvt_out.cpp
// compile with: /EHsc
#define _INTL
#include <locale>
#include <iostream>
#include <wchar.h>
using namespace std;
#define LEN 90
int main( )   
{
   char pszExt[LEN+1];
   wchar_t *pwszInt = L"This is the wchar_t string to be converted.";
   memset( &pszExt[0], 0, ( sizeof( char ) )*( LEN+1 ) );
   char* pszNext;
   const wchar_t* pwszNext;
   mbstate_t state;
   locale loc("C");//English_Britain");//German_Germany
   int res = use_facet<codecvt<wchar_t, char, mbstate_t> >
      ( loc ).out( state,
      pwszInt, &pwszInt[wcslen( pwszInt )], pwszNext ,
      pszExt, &pszExt[wcslen( pwszInt )], pszNext );
   pszExt[wcslen( pwszInt )] = 0;
   cout << ( ( res!=codecvt_base::error ) ? "It worked: " : "It didn't work: " )
   << "The converted string is:\n ["
   << &pszExt[0]
   << "]" << endl;
}
  

必要条件

ヘッダー: <locale>

名前空間: std

参照

関連項目

codecvt Class