起きている現象
C++/CLI System::Stringをcharに変換したいのですが、
下記の[method1]のようなコードでchar変換を行い、
memcpyでchar型の変数にコピーしようとすると
プログラムがクラッシュしてしまいました。
自分で調べたこと、試したこと
##(1) char変換処理の変更
以下のサイトを参考に、std::stringを使わず、
System::Stringをcharに変換する処理を作ると
memcpyでエラーとならずコピーができました。[method2]
##(2) char変換結果の比較
下記のコードのように、method1とmethod2の結果を比較すると、
異なっていることがわかりました。(終端文字以降の部分で)
知りたいこと
method1を使用してchar型文字列に変換すると、
サイズ超過、メモリ破壊 など 起きうること、危険性について教えてください。
また、どのようなコードの書き方が望ましいのか、教えていただけないでしょうか。
#実験に使用したコード
C++/CLI
1#include "stdafx.h" 2#include <string> 3#include <msclr/marshal_cppstd.h> 4#include <time.h> 5 6using namespace System; 7using namespace System::Data; 8using namespace System::Runtime::InteropServices; 9 10// System::String^→std::stringへ変換 11std::string StringTostdstring(String^ StrData) 12{ 13 return msclr::interop::marshal_as<std::string>(StrData); 14} 15 16 17int main(array<System::String ^> ^args) 18{ 19 System::String^ strTemp = "SELECT * FROM OOO WHERE XXXXXXXXXX;"; // 長さは250文字程度 20 21 char szLog1[1024]; 22 char szLog2[1024]; 23 24 memset(szLog1,0x00,sizeof(szLog1)); 25 memset(szLog2,0x00,sizeof(szLog2)); 26 27 //method 1 28 memcpy(szLog1, StringTostdstring(strTemp).c_str(), 1024); // 実際のコードは、ここで実行中エラーとなりクラッシュする 29 30 //method 2 31 char* str2 = (char*)Marshal::StringToHGlobalAnsi(strTemp).ToPointer(); 32 memcpy(szLog2, str2, 1024); 33 Marshal::FreeHGlobal((IntPtr)str2); 34 35 if (memcmp(szLog1, szLog2, 1024) == 0) 36 { 37 int nD1 = 0; 38 } 39 else 40 { 41 int nD2 = 0; //szLog1, szLog2は一致しない 42 } 43 44 return 0; 45} 46
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/01/30 00:20
2020/01/30 00:57