掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
C++編程語言對于編程人員來說是非常重要的一個(gè)計(jì)算機(jī)應(yīng)用語言。我們今天會在這篇文章中為大家詳細(xì)介紹一下C++ Endian的基本應(yīng)用方式,希望朋友們可以從中對C++編程語言有一個(gè)深刻的了解。#t#

在潘集等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需定制制作,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計(jì),網(wǎng)絡(luò)營銷推廣,成都外貿(mào)網(wǎng)站制作,潘集網(wǎng)站建設(shè)費(fèi)用合理。
最近寫了一段代碼來讀取和輸出一個(gè)文件.這個(gè)文件的標(biāo)準(zhǔn)規(guī)范里面同時(shí)使用了LittleEndian和BigEndian.***次在C++中接觸這個(gè)問題.所以需要做一下工作:
1.判斷當(dāng)前CPU使用哪種C++ Endian?
2.如果當(dāng)前數(shù)據(jù)的Endian和當(dāng)前CPU相反,如何裝換?
代碼相當(dāng)直觀:
1.判斷CPU的C++ Endian:
- union {
- short s;
- char c[sizeof(short)];
- } un;
- un.s = 0x0102;
- _isLittleEnd = (un.c[0] == 0x2);
***的_isLittleEnd是一個(gè)bool變量用來保存判定的結(jié)果:
2.如何把一個(gè)相反C++ Endian的數(shù)據(jù)轉(zhuǎn)換過來:
- 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;
- }
其實(shí)是將char[]數(shù)組就地反轉(zhuǎn).
3.如何把short/int/double等數(shù)據(jù)反轉(zhuǎn)過來呢:
以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;
- }
到目前為止,用這個(gè)算法做的數(shù)據(jù)轉(zhuǎn)換還沒有發(fā)現(xiàn)錯(cuò)誤的情況.也許是沒碰到罷了.
例如 我沒有測試1)對于負(fù)數(shù)這個(gè)算法是否正確.2)對于無符號數(shù)這個(gè)算法是否正確.因?yàn)檫@個(gè)文件規(guī)范里面不會出現(xiàn)這兩種數(shù).
內(nèi)容比較基礎(chǔ).但覺得值得分享。在首頁上掛一會. 出去腐敗一把,回來再撤銷(如果回來還比較清醒的話).
以上就是對C++ Endian基本概念的講解

我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流