QByteArray类提供了字节数组,包含于<QByteArray>头文件中,从Q3CString类继承而来。
QByteArray可以存储raw bytes和传统的8-bits的字符串,都是以'\0'结尾的,使用比char*更方便
QString也可以存储字符串信息,但通常以16-bits形式Unicode方式存储,这有利于非ASCII和非Latin-1格式的数据的存储,例如GBK等中文
size()大小,不包含'\0' ,qstrlen()包含'\0'
resize()可以重新定义大小
data()所存储的数据对象,返回一个指针
at()与[]效果一样,都是去第i+1的字节
Left(int len) right(int len) mid(int pos, int len)都是从该字符串中提取左、右和从pos开始的len个字节的成员函数,返回QByteArray类型
Prepend() append() 分别是从前面和后面添加字符串
Replace(5,3,"&")从第五个字节起的3个字节都用"&"来被替换
indexOf("pch")在该字符数组中检索pch字符串,返回第一个pch第一个字符的位置,若未找到则返回-1
lastIndexOf()返回最后一个符合的字符串首字符的位置
isNull()判断字符数组是否为空("")=0
isEmpty()判断该字符数组是否有内容("")=1
QByteArray ()构造一个empty的字符数组
QByteArray ( const char * str )用str来初始化
QByteArray ( const char * data, int size )用前size个字节来初始化
QByteArray ( int size, char ch )size个字节都是 ch
QByteArray ( const QByteArray & other )拷贝构造函数
Chop(int n)从最后删除n个字节
Clear()清空
int QByteArray::count ( const QByteArray & ba ) const返回ba在字符数组中出现的次数
#include <QCoreApplication>
#include <iostream>
#include <QDebug>
using namespace std;
QByteArray intToByte(int i)
{
QByteArray abyte0;
abyte0.resize(4);
abyte0[0] = (uchar) (0x000000ff & i);
abyte0[1] = (uchar) ((0x0000ff00 & i) >> 8);
abyte0[2] = (uchar) ((0x00ff0000 & i) >> 16);
abyte0[3] = (uchar) ((0xff000000 & i) >> 24);
return abyte0;
}
int bytesToInt(QByteArray bytes) {
int addr = bytes[0] & 0x000000FF;
addr |= ((bytes[1] << 8) & 0x0000FF00);
addr |= ((bytes[2] << 16) & 0x00FF0000);
addr |= ((bytes[3] << 24) & 0xFF000000);
return addr;
}
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QByteArray s, s1;
s.resize(5);
s[0] = '1';
s[1] = '2';
s[2] = '3';
s[3] = '\0';
s[4] = 'a';
//std::cout << s << endl;
qDebug() << s << endl;
s1=intToByte(12345678);
int i1 = bytesToInt(s1);
qDebug() << s1[0] << endl;
qDebug() << s1[1] << endl;
qDebug() << s1[2] << endl;
qDebug() << s1[3] << endl;
qDebug() << i1 << endl;
return a.exec();
}