QString 类是 Qt 中用于表示字符串的类,实现在 QtCore 共享库中。QString 类在实现上有以下特征。
1)字符串采用 Unicode 内部编码,可以表示世界上大多数语言的文字。
2)字符串的存储有引用计数,当一个 QString 对象被复制为另一个 QString 对象时,它们实际上指向相同的存储空间,仅仅是增加一个引用计数。
3)采用 “按需复制” 的技术,当指向相同存储空间的多个 QString 对象中的一个要被修改时,将真正复制一个新的字符串并进行修改。
构造
QString 类提供了很多不同原型的构造函数以方便使用。如:
Qstring(); // 构造空字符串 QString(QChar ch); // 由 QChar 对象 ch构造 QString(const QChar *pch, int size); // 由 QChar 数组pch构造,size 是数组大小 QString(const QString &obj); // 拷贝构造函数 QString(const char *str); // 由字符串 str 构造,str是一个普通字符串
判断
可以用下面的成员函数判断 QString 对象是否为空字符串:
bool isEmpty() const; // 判断是否为空字符串
转换
QString 类提供了很多函数用于将字符串转换为数值,如:
double toDouble(bool *ok = 0) const; // 转换为高精度浮点数 float toFloat(bool *ok = 0) cosnt; // 转换为浮点数 int toInt(bool *ok, int base = 10) const; // 转换为整型数 long toLong(bool *ok, int base = 10) cosnt; // 转换为长整型 short toShort(bool *ok, int base = 10) const; // 转换为短整型 uint toUInt(bool *ok = 0; int base = 10) const // 转换为无符号整型数 ulong toLong(bool *ok = 0, int base = 10) const; // 转换为无符号长整型数 ushort toUShort(bool *ok = 0, int base = 10) const; // 转换为无符号短整型数
注意: 当字符串以 0x开头时,转换的基自动转换为16, 当字符串以0开头时,转换的基自动为8。
下面这些成员函数可以将一个数值转换为字符串并设为 QString 对象的值:
QString &setNum(int n, int base = 10); // 整型数 QString &setNum(uint n, int base = 10); // 无符号整型数 QString &setNum(long n, int base = 10); // 长整型 QString &setNum(ulong n, int base = 10); // 无符号长整型数 QString &setNum(short n, int base = 10); // 短整型数 QString &setNum(ushort n, int base = 10); // 无符号短整型数 QString &setNum(double n, char format = 'g', int precision = 6); // 高精度浮点数 QString &setNum(float n, char format = 'g', int precision = 6); // 浮点数
QString number(int n, int base = 10); QString number(uint n, int base = 10); QString number(long n, int base = 10); QString number(ulong n ,int base = 10); QString number(double n, char format = 'q', int precision = 6);
QString 类也提供了大小写转换的函数,如:
QString toLower() const; // 转换为小写 QString toUpper() const; // 转换为大写
比较
QString 类提供了一个函数用于两个 QString 对象的比较:
int compare(const QString &s1, const QString &s2, Qt::CaseSensitivity cs = Qt::CaseSensitive);
这是一个静态成员函数,它可以比较 s1 和 s2 的大小,参数 cs 有以下两个取值。
Qt::CaseInsensitive: 表示对大小写不敏感 Qt::Casesensitive : 表示对大小写敏感
为了方便使用,QString 类还提供了以下重载函数用于比较:
int compare(const QString &other, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
bool operator < (StringType other) const; // 比较是否小于 other人 bool operator <= (StringType other) const; // 比较是否小于等于 other bool operator == (StringType other) const; // 比较是否等于 other bool operator > (StringType other) constt; // 比较是否大于 other bool operator >= (StringType other) const; // 比较是否大于等于 other bool operator != (StringType other) const; // 比较是否不等于 other
bool operator < (const char *s1, const QString &s2); // 比较 s1 是否小于 s2 bool operator <= (const char *s1, const QString &s2); // 比较 s1 是否小于等于 s2 bool operator == (const char *s1, const QString &s2); // 比较 s1 是否等于 s2 bool operator > (const char *s1, const QString &s2); // 比较 s1 是否大于 s2 bool operator >= (const char *s1, const QString &s2); // 比较 s1 是否大于等于 s2 bool operator != (const char *s1, const QString &s2); // 比较 s1 是否不等于 s2
查找
用以下的成员函数可以判断 QString 对象是否包含指定的字符串或字符:
bool contains(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive) const; bool contains(cosnt ch, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
int count(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive) const; int count(QChar ch, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
int indexOf(const QString &str, int from = 0, Qt::CaseSensitivity cs = Qt::CaseSensitive) const; int indexOf(QChar ch, int from = 0, Qt::CaseSensitivity cs = Qt::CaseSensitive) const;
QString 类中还有与此功能相似的函数用于从后往前查找字符串或字符:
int lastIndexOf(const QString &str, int from = -1, Qt::CaseSensitivity cs = Qt::CaseSensitive) const; int lastIndexOf(QChar ch, int from = -1, Qt::CaseSensitivity cs = Qt::CaseSensitive) const
字符串处理
QString 类支持用赋值操作符进行对象的复制,其赋值操作符的声明如下:
QString &operator = (const QString &other); // 复制另外一个 QString 对象 QString &operator = (const char *str); // 复制普通字符串 QString &operator = (char ch); // 复制字符 QString &operator = (QChar ch); // 复制 QChar 类对象
以下的成员函数可以将另一个字符串或字符接在 QString 对象后面,形成一个整体的字符串:
QString &append(const QString &str); // 接续 QString 对象 QString &append(const char *str); // 接续普通字符串 QString &append(QChar ch); // 接续 QChar 对象
它们的返回值是 QString 对象自己的引用,也就是说,可以用在这个返回值再次调用成员函数,形成连续的字符串接续操作。
为了让代码更直观, QString 类中还定义了一个操作符用于字符串的接续:
QString &operator += (const QString &other); // 续接 QString 对象 QString &operator += (const char *str); // 续接普通字符串 QString &operator += (char ch); // 接续字符型数据 QString &operator += (QChar ch); // 接续 QChar 对象
与 append 函数功能类似,以下的成员函数也能够将另一个字符串或字符与 QString 对象连接起来,但是接在原字符串的前面:
QString &prepend(const QString &str); // 在前面接续 QString 对象 QString &prepend(const char *str); // 在前面接续普通字符串 QString &prepend(QChar ch); // 在前面接续 QChar 对象
功能更一般化的是在 QString 对象的任意位置插入另一个字符串或字符,如:
QString &insert(int position, const QString &str); // 插入字符串 QString &insert(int position, const QChar *pch, int size); // 插入 QChar 数组 QString &insert(int position, QChar ch); // 插入 QChar 对象
与插入相反的操作是移除 QString 对象中的一部分,如:
QString &remove(int position, int n);
这个函数可以移除 QString 对象中从位置 position 开始的 n 个字符,下面两个成员函数则可以从 QString 对象中移除指定的字符串或字符:
QString &remove(QChar ch, Qt::CaseSensitivity cs = Qt::CaseSensitive); QString &remove(const QString &str, Qt::CaseSensitivity cs = Qt::CaseSensitive);
QString &replace(int position, int n, const QString &after); // QString 对象 QString &replace(int position, int n, const QChar *pch, int size); // QChar 数组 QString &replace(int opsition, int n, QChar after); // QChar 对象
这三个函数的功能是将 QString 对象从 position 开始的 n 个字符替换为新内容,新内容分别由 QString 对象、QChar 数组 和 QChar 对象表示。
以下成员函数则可以搜索指定的字符串或字符并开始替换:
QString &replace(const QString &before, const QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive); // QString 替换为 QString QString &replace(QChar ch, cosnt QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive); // QChar 替换为 QString QString &replace(QChar before, QChar after, Qt::CaseSensitivity cs = Qt::CaseSensitive); // Qchar 替换为 QChar
void clear();
void truncate(int position); // 从位置 position 截断,位置从0开始编号
void chop(int n); // 截掉最后的 n个字符
QString left(int n) const; // 得到左边 n 个字符构成的子字符串 QString right(int n) const; // 得到右边 n 个字符构成的子字符串 QString mid(int position, int n = -1) const; // 从中间得到子字符串
注意上述三个函数并不修改 QString 对象自身,而是返回一个临时对象以供使用。
下面这个成员函数可以截去 QString 对象中头部和尾部的空白字符:
QString trimmed() const;
空白字符包括空格、回车、换行、制表符等字符。下面这个成员函数不仅能去掉 QString 对象头尾的空白字符,还能将中间的连续多个空白字符全部替换成一个空格:
QString simlified() const;
const QString operator+(const QString &s1, const QString &s2); const QString operator+(const QString &s1, const char *s2); const QString operator+(const char s1, const QString &s2); const QString operator+(const QString &s, char ch);
注意加法操作符的两个操作数中必须至少有一个是 QString 对象,否则无法重载操作符。显然,加法操作副都不是 QString 类的成员。
索引
QString 类也像普通的字符串一样可以根据下标得到某个位置上的字符:
const QChar at(int position) const;
const QChar operator[] (int position) const; const QChar operator[] (uint position) const;
QCharRef operator[] (int position); QCharRef operator[] (uint position);
统计
以下两个成员函数都可以得到 QString 对象中字符的个数:
int size() const; int length() const;