您好,登錄后才能下訂單哦!
C++ 中怎么對Endian進行操作,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
1.判斷CPU的C++ Endian:
union { short s; char c[sizeof(short)]; } un; un.s = 0x0102; _isLittleEnd = (un.c[0] == 0x2);
***的_isLittleEnd是一個bool變量用來保存判定的結果:
2.如何把一個相反C++ Endian的數據轉換過來:
void Helper::swap(char ch[], int count) { int size = count / 2; int max = count - 1; for (int i = 0; i < size; i++) { char t = ch[i]; ch[i] = ch[max - i]; ch[max - i] = t; }
其實是將char[]數組就地反轉.
3.如何把short/int/double等數據反轉過來呢:
以int 為例的代碼如下:
int Helper::swap(int data) { union { int _i; char _c[sizeof(int)]; } un; un._i = data; swap(un._c, sizeof(int)); return un._i; }
到目前為止,用這個算法做的數據轉換還沒有發現錯誤的情況.也許是沒碰到罷了.
例如 我沒有測試1)對于負數這個算法是否正確.2)對于無符號數這個算法是否正確.因為這個文件規范里面不會出現這兩種數.
內容比較基礎.但覺得值得分享。在首頁上掛一會. 出去腐敗一把,回來再撤銷(如果回來還比較清醒的話).
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。