unsigned char QString 互转

 

转自:https://blog.csdn.net/qq_20553613/article/details/78774476

1.char* 转QString

方法一:直接用QString的构造函数转换,如下:

char* ch = "acuity";
QString str(ch);

 

方法二:用QString的静态转换函数获取,如fromUtf8()、fromLocal8bit()、fromUtf16(),如下:

char* ch = "acuity";
QString str = Qstring::fromUtf8(ch);

 

2.QString 转char*

方法一:借助QByteArray类,也是本人用得最多的方法,如下:

Qstring str;
char* ch;
QByteArray ba = str.toLatin1(); 
ch=ba.data();

 

第三行一般加上,整合一条语句(ch=str.toLatin1().data())有时会出问题。以上对应英文/ASII码来说,如果涉及中文,建议通用用utf-8格式,可以避免莫名其妙的乱码现。这一点在代码编辑上建议也是使用utf-8格式。如下:

Qstring str;
char* ch;
QByteArray ba = str.toUtf8(); 
ch=ba.data();

 

方法二:

对于涉及中文情况,也可以先将QString转换为标准库string类型,然后再将string转换为char*。如下:

QString str;
std::string str = filename.toStdString();
const char* ch = str.c_str();

QT中unsigned char转QString的方法

unsigned char是无符号字符,代表的范围为0-255,转QString要通过int来牵线,下面直接上代码与图:

QString uncharToQstring(unsigned char * id,int len)
{
    QString temp,msg;
    int j = 0;

    while (j<len)
    {
        temp = QString("%1").arg((int)id[j], 2, 16, QLatin1Char('0'));
        msg.append(temp);
        j++;
    }

    return msg;
}

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    unsigned char id[20] = {
        0x0a, 0x10, 0xFF, 0x20, 0x30, 0x02, 0x40, 0x03, 0x50, 0x60,
        0x5A, 0x30, 0x10, 0x1c, 0x10, 0x30, 0x40, 0x80, 0x40, 0x70
    };

    QString msg;
    msg = uncharToQstring(id,20);

    qDebug()<<msg;

    return a.exec();
}

结果:

 

QString unsigned char * 相互转换

Qt unsigned char *与QString之间的相互转换

//unsiged char *转QString

unsigned char *str = "fdd" ;
char *str1 = (char *)str;
QString str2 = QString(QLatin1String(str1));

//QString 转化成char *

QString str = "fdd";
QByteArray ba = str.toLatin1();
unsigned char * str1 = (unsigned char *)ba.data;

 

16进制QString和unsigned char数组互相转换

17位16进制mac字符串转为6位字节数组

demo: unsigned char* byteArr = hexStringToByteArray(QString("A1-B2-C3-D4-E5-F6")).data();

QVector<unsigned char> hexStringToByteArray(const QString& strMac)
{
    QVector<unsigned char> vecMac;
    unsigned char* p = vecMac.data();
    if (strMac.size() != 17)
    {
        return vecMac;
    }
    for (int i = 0; i < strMac.size(); i += 3)
    {
        QString num = strMac.mid(i, 2);
        bool ok = false;
        vecMac.push_back(num.toUInt(&ok, 16));
        if (!ok)
        {
            return QVector<unsigned char>();
        }
    }
    return vecMac;
}

6位字节数组转17位16进制QString

demo:

QString s_font_code = QString("A1-B2-C3-D4-E5-F6");

QVector<unsigned char> byteArr1 = hexStringToByteArray(s_font_code);

unsigned char* pByte1 = byteArr1.data();

QString byteArrayToHexString(unsigned char* str)
{
    QString result = "";
    //int lengthOfString = strlen(reinterpret_cast<const char*>(str));
    int lengthOfString = 6;
 
    QString s;
    for (int i = 0; i < lengthOfString; ++i)
    {
        s = QString("%1").arg(str[i], 0, 16);
 
        // account for single-digit hex values (always must serialize as two digits)
        if (s.length() == 1)
            result.append("0");
 
        result.append(s.toUpper());
        result.append('-');
    }
 
    //删除最后一个'-'
    result.chop(1);
 
    return result;
}

 

将unsigned char字符串以16进制的字符串显示

在C中,默认的基础数据类型均为signed,现在我们以char为例,说明(signed) char与unsigned char之间的区别
首先在内存中,char与unsigned char没有什么不同, 都是一个字节,唯一的区别是,char的最高位为符号位,因此char能表示-128~127,unsigned char没有符号位,因此能表示0~255,这个好理解,8个bit,最多256种情况,因此无论如何都能表示256个数字。

在实际使用过程种有什么区别呢?
主要是符号位,但是在普通的赋值,读写文件和网络字节流都没什么区别,反正就是一个字节,不管最高位是什么,最终的读取结果都一样,只是你怎么理解最高位而已,在屏幕上面的显示可能不一样。

但是我们却发现在表示byte时,都用unsigned char,这是为什么呢?
首先我们通常意义上理解,byte没有什么符号位之说,更重要的是如果将byte的值赋给int,long等数据类型时,系统会做一些额外的工作。如果是 char,那么系统认为最高位是符号位,而int可能是16或者32位,那么会对最高位进行扩展(注意,赋给unsigned int也会扩展)而如果是 unsigned char,那么不会扩展。
这就是二者的最大区别。

这里又想起另外一个问题:数字1和字符1在计算机实际储存的值

如果都是一个字节,那么数字1实际存储的是0x01,字符'1'实际存储的是0x31。

上一段代码,这段代码的功能是将unsigned char类型字符串的内容以其真实内存数据形式存储到另外一个字符串里

static const char hex_chars[] = "0123456789ABCDEF";
 
CString convert_hex(unsigned char *md/*字符串*/,int nLen/*转义多少个字符*/)
{
    CString strSha1(_T(""));
 
    unsigned int c = 0;
 
    // 查看unsigned char占几个字节
    // 实际占1个字节,8位
    int nByte = sizeof(unsigned char);
 
    for (int i = 0; i < nLen; i++)
    {
        // 查看md一个字节里的信息
        unsigned int x = 0;
        x = md[i];
        x = md[i] >> 4;// 右移,干掉4位,左边高位补0000
 
        c = (md[i] >> 4) & 0x0f;
        strSha1 += hex_chars[c];
        strSha1 += hex_chars[md[i] & 0x0f];
    }
    return strSha1;
}
 
void OnBnClickedButton2()
{
    unsigned char org[] = "123456789abcdf我爱你二进制";
 
    CString str;
    int i=1;
    i = i <<4;// 左移 执行完这行i的值为16
 
    str=convert_hex(org,20);
 
    OutputDebugString(str);
}

调试展示样例,部分参见 ASCII码映射表

最终得到的结果如下

 

posted @ 2024-01-09 18:17  阳光下的小土豆  阅读(2642)  评论(0编辑  收藏  举报