2014-03-19 47 views
0

我想送我的自定義結構如下圖所示:如何通過MFC中的CSocket發送自定義結構?

struct Setup 
{ 
int nPort; 
BOOL bFirstType; 
BOOL bSecondType; 
CStringList strPreset1; 
CStringList strPreset2; 
}; 

但是,有一些問題,因爲CStringList

在接收端,CStringList::GetCount()效果不錯,但斷言時,你得到的字符串數據時出現錯誤。

我想一次發送我的數據。

所以,我試圖將結構轉換爲BYTE和char *但失敗。

我怎樣才能一次發送結構數據?

回答

1

你應該將你的數據轉換爲字符串形式,即。 json或xml,並將其作爲文本發送,然後在另一端解析它並重新創建結構。

不知道你是如何嘗試將你的結構轉換爲字節,以及如何失敗,但如果正確地完成上面的工作將會工作。

--- [編輯] ---

我忘了MFC提供CArchive類與CMemFile在一起可能是有用的系列化。這個解決方案實際上可以安全地用於兩個MFC應用程序之間。

struct Setup 
{ 
int nPort; 
BOOL bFirstType; 
BOOL bSecondType; 
CStringList strPreset1; 
CStringList strPreset2; 
}; 

int main() 
{ 
    Setup in; 
    in.nPort = 81; 
    in.bFirstType = TRUE; 
    in.bSecondType = FALSE; 
    in.strPreset1.AddTail(_T("test1a")); 
    in.strPreset1.AddTail(_T("test1b")); 
    in.strPreset1.AddTail(_T("test1c")); 
    in.strPreset2.AddTail(_T("test2a")); 
    in.strPreset2.AddTail(_T("test2b")); 
    in.strPreset2.AddTail(_T("test2c")); 

    // Serialization part 
    CMemFile memfile; 
    CArchive ar(&memfile, CArchive::store); 

    ar << in.nPort; 
    ar << in.bFirstType; 
    ar << in.bSecondType; 
    in.strPreset1.Serialize(ar); 
    in.strPreset2.Serialize(ar);  
    ar.Close(); 

    INT dataLen = (INT)memfile.GetLength(); 
    BYTE* data = memfile.Detach(); 

    // Copy serialized data to some buffer, or to Socket, File, etc. 
    std::vector<BYTE> toSent(data, data + dataLen); 

    free(data); // after detach and when no longer needed must be freed with free() 



    // Now, ie. your second application received your data, so deserialize it. 

    CMemFile memfile2; 
    memfile2.Attach(&toSent.front(), toSent.size()); 
    CArchive ar2(&memfile2, CArchive::load); 

    Setup out;  
    ar2 >> out.nPort; 
    ar2 >> out.bFirstType; 
    ar2 >> out.bSecondType; 
    out.strPreset1.Serialize(ar2); 
    out.strPreset2.Serialize(ar2); 
    ar2.Close(); 


    // Verify if ok, just for testing purposes 
    ASSERT(in.nPort == out.nPort); 
    ASSERT(in.bFirstType == out.bFirstType); 
    ASSERT(in.bSecondType == out.bSecondType); 
    ASSERT(in.strPreset1.GetSize() == out.strPreset1.GetSize()); 
    ASSERT(in.strPreset2.GetSize() == out.strPreset2.GetSize()); 

    return 0; 
} 
0

可以序列的結構成一個文本串/字節/流(如JSON,XML協議緩衝器等),並且經由CSocket的發送出去,當收到序列化的數據,反序列化,則可以處理它。

相關問題