QString 类提供 Unicode 字符串。 更多...
头: | #include <QString> |
qmake: | QT += core |
注意: 此类的所有函数 可重入 .
class | Null |
typedef | ConstIterator |
typedef | Iterator |
enum | NormalizationForm { NormalizationForm_D, NormalizationForm_C, NormalizationForm_KD, NormalizationForm_KC } |
enum | SectionFlag { SectionDefault, SectionSkipEmpty, SectionIncludeLeadingSep, SectionIncludeTrailingSep, SectionCaseInsensitiveSeps } |
flags | SectionFlags |
enum | SplitBehavior { KeepEmptyParts, SkipEmptyParts } |
typedef | const_iterator |
typedef | const_pointer |
typedef | const_reference |
typedef | const_reverse_iterator |
typedef | difference_type |
typedef | iterator |
typedef | pointer |
typedef | reference |
typedef | reverse_iterator |
typedef | size_type |
typedef | value_type |
QString () | |
QString (const QChar * unicode , int size = -1) | |
QString (QChar ch ) | |
QString (int size , QChar ch ) | |
QString (QLatin1String str ) | |
QString (const QString & other ) | |
QString (QString && other ) | |
QString (const char * str ) | |
QString (const QByteArray & ba ) | |
~QString () | |
QString & | append (const QString & str ) |
QString & | append (const QChar * str , int len ) |
QString & | append (QChar ch ) |
QString & | append (const QStringRef & reference ) |
QString & | append (QLatin1String str ) |
QString & | append (const char * str ) |
QString & | append (const QByteArray & ba ) |
QString | arg (const QString & a , int fieldWidth = 0, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (qulonglong a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (long a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (ulong a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (int a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (uint a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (short a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (ushort a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (double a , int fieldWidth = 0, char format = 'g', int precision = -1, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (char a , int fieldWidth = 0, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (QChar a , int fieldWidth = 0, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (qlonglong a , int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const |
QString | arg (const QString & a1 , const QString & a2 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 , const QString & a4 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 , const QString & a4 , const QString & a5 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 , const QString & a4 , const QString & a5 , const QString & a6 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 , const QString & a4 , const QString & a5 , const QString & a6 , const QString & a7 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 , const QString & a4 , const QString & a5 , const QString & a6 , const QString & a7 , const QString & a8 ) const |
QString | arg (const QString & a1 , const QString & a2 , const QString & a3 , const QString & a4 , const QString & a5 , const QString & a6 , const QString & a7 , const QString & a8 , const QString & a9 ) const |
const QChar | at (int position ) const |
iterator | begin () |
const_iterator | begin () const |
int | capacity () const |
const_iterator | cbegin () const |
const_iterator | cend () const |
void | chop (int n ) |
void | clear () |
int | compare (QLatin1String other , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | compare (const QString & other , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | compare (const QStringRef & ref , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
const_iterator | constBegin () const |
const QChar * | constData () const |
const_iterator | constEnd () const |
bool | contains (const QString & str , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | contains (QChar ch , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | contains (QLatin1String str , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | contains (const QStringRef & str , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | contains (const QRegExp & rx ) const |
bool | contains (QRegExp & rx ) const |
bool | contains (const QRegularExpression & re ) const |
bool | contains (const QRegularExpression & re , QRegularExpressionMatch * match ) const |
int | count (const QString & str , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | count (QChar ch , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | count () const |
int | count (const QStringRef & str , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | count (const QRegExp & rx ) const |
int | count (const QRegularExpression & re ) const |
const_reverse_iterator | crbegin () const |
const_reverse_iterator | crend () const |
QChar * | data () |
const QChar * | data () const |
iterator | end () |
const_iterator | end () const |
bool | endsWith (const QString & s , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | endsWith (const QStringRef & s , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | endsWith (QLatin1String s , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | endsWith (QChar c , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
QString & | fill (QChar ch , int size = -1) |
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 |
int | indexOf (QLatin1String str , int from = 0, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | indexOf (const QStringRef & str , int from = 0, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | indexOf (const QRegExp & rx , int from = 0) const |
int | indexOf (QRegExp & rx , int from = 0) const |
int | indexOf (const QRegularExpression & re , int from = 0) const |
int | indexOf (const QRegularExpression & re , int from , QRegularExpressionMatch * rmatch ) const |
QString & | insert (int position , const QString & str ) |
QString & | insert (int position , const QChar * unicode , int size ) |
QString & | insert (int position , QChar ch ) |
QString & | insert (int position , const QStringRef & str ) |
QString & | insert (int position , QLatin1String str ) |
QString & | insert (int position , const char * str ) |
QString & | insert (int position , const QByteArray & str ) |
bool | isEmpty () const |
bool | isNull () const |
bool | isRightToLeft () const |
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 |
int | lastIndexOf (QLatin1String str , int from = -1, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | lastIndexOf (const QStringRef & str , int from = -1, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
int | lastIndexOf (const QRegExp & rx , int from = -1) const |
int | lastIndexOf (QRegExp & rx , int from = -1) const |
int | lastIndexOf (const QRegularExpression & re , int from = -1) const |
int | lastIndexOf (const QRegularExpression & re , int from , QRegularExpressionMatch * rmatch ) const |
QString | left (int n ) const |
QString | leftJustified (int width , QChar fill = QLatin1Char( ' ' ), bool truncate = false) const |
QStringRef | leftRef (int n ) const |
int | length () const |
int | localeAwareCompare (const QString & other ) const |
int | localeAwareCompare (const QStringRef & other ) const |
QString | mid (int position , int n = -1) const |
QStringRef | midRef (int position , int n = -1) const |
QString | normalized (NormalizationForm mode , QChar::UnicodeVersion version = QChar::Unicode_Unassigned) const |
QString & | prepend (const QString & str ) |
QString & | prepend (const QChar * str , int len ) |
QString & | prepend (QChar ch ) |
QString & | prepend (const QStringRef & str ) |
QString & | prepend (QLatin1String str ) |
QString & | prepend (const char * str ) |
QString & | prepend (const QByteArray & ba ) |
void | push_back (const QString & other ) |
void | push_back (QChar ch ) |
void | push_front (const QString & other ) |
void | push_front (QChar ch ) |
reverse_iterator | rbegin () |
const_reverse_iterator | rbegin () const |
QString & | remove (int position , int n ) |
QString & | remove (QChar ch , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | remove (const QString & str , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | remove (const QRegExp & rx ) |
QString & | remove (const QRegularExpression & re ) |
reverse_iterator | rend () |
const_reverse_iterator | rend () const |
QString | repeated (int times ) const |
QString & | replace (int position , int n , const QString & after ) |
QString & | replace (int position , int n , const QChar * unicode , int size ) |
QString & | replace (int position , int n , QChar after ) |
QString & | replace (QChar before , QChar after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (const QChar * before , int blen , const QChar * after , int alen , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (QLatin1String before , QLatin1String after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (QLatin1String before , const QString & after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (const QString & before , QLatin1String after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (const QString & before , const QString & after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (QChar ch , const QString & after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (QChar c , QLatin1String after , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString & | replace (const QRegExp & rx , const QString & after ) |
QString & | replace (const QRegularExpression & re , const QString & after ) |
void | reserve (int size ) |
void | resize (int size ) |
void | resize (int size , QChar fillChar ) |
QString | right (int n ) const |
QString | rightJustified (int width , QChar fill = QLatin1Char( ' ' ), bool truncate = false) const |
QStringRef | rightRef (int n ) const |
QString | section (QChar sep , int start , int end = -1, SectionFlags flags = SectionDefault) const |
QString | section (const QString & sep , int start , int end = -1, SectionFlags flags = SectionDefault) const |
QString | section (const QRegExp & reg , int start , int end = -1, SectionFlags flags = SectionDefault) const |
QString | section (const QRegularExpression & re , int start , int end = -1, SectionFlags flags = SectionDefault) const |
QString & | setNum (int n , int base = 10) |
QString & | setNum (ushort n , int base = 10) |
QString & | setNum (short 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 (qlonglong n , int base = 10) |
QString & | setNum (qulonglong n , int base = 10) |
QString & | setNum (float n , char format = 'g', int precision = 6) |
QString & | setNum (double n , char format = 'g', int precision = 6) |
QString & | setRawData (const QChar * unicode , int size ) |
QString & | setUnicode (const QChar * unicode , int size ) |
QString & | setUtf16 (const ushort * unicode , int size ) |
QString | simplified () const |
int | size () const |
QStringList | split (const QString & sep , SplitBehavior behavior = KeepEmptyParts, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
QStringList | split (QChar sep , SplitBehavior behavior = KeepEmptyParts, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
QStringList | split (const QRegExp & rx , SplitBehavior behavior = KeepEmptyParts) const |
QStringList | split (const QRegularExpression & re , SplitBehavior behavior = KeepEmptyParts) const |
QVector<QStringRef> | splitRef (const QString & sep , SplitBehavior behavior = KeepEmptyParts, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
QVector<QStringRef> | splitRef (QChar sep , SplitBehavior behavior = KeepEmptyParts, Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
QVector<QStringRef> | splitRef (const QRegExp & rx , SplitBehavior behavior = KeepEmptyParts) const |
QVector<QStringRef> | splitRef (const QRegularExpression & re , SplitBehavior behavior = KeepEmptyParts) const |
void | squeeze () |
bool | startsWith (const QString & s , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | startsWith (const QStringRef & s , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | startsWith (QLatin1String s , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
bool | startsWith (QChar c , Qt::CaseSensitivity cs = Qt::CaseSensitive) const |
void | swap (QString & other ) |
CFStringRef | toCFString () const |
QString | toCaseFolded () const |
double | toDouble (bool * ok = Q_NULLPTR) const |
float | toFloat (bool * ok = Q_NULLPTR) const |
QString | toHtmlEscaped () const |
int | toInt (bool * ok = Q_NULLPTR, int base = 10) const |
QByteArray | toLatin1 () const |
QByteArray | toLocal8Bit () const |
long | toLong (bool * ok = Q_NULLPTR, int base = 10) const |
qlonglong | toLongLong (bool * ok = Q_NULLPTR, int base = 10) const |
QString | toLower () const |
NSString * | toNSString () const |
short | toShort (bool * ok = Q_NULLPTR, int base = 10) const |
std::string | toStdString () const |
std::u16string | toStdU16String () const |
std::u32string | toStdU32String () const |
std::wstring | toStdWString () const |
uint | toUInt (bool * ok = Q_NULLPTR, int base = 10) const |
ulong | toULong (bool * ok = Q_NULLPTR, int base = 10) const |
qulonglong | toULongLong (bool * ok = Q_NULLPTR, int base = 10) const |
ushort | toUShort (bool * ok = Q_NULLPTR, int base = 10) const |
QVector<uint> | toUcs4 () const |
QString | toUpper () const |
QByteArray | toUtf8 () const |
int | toWCharArray (wchar_t * array ) const |
QString | trimmed () const |
void | truncate (int position ) |
const QChar * | unicode () const |
const ushort * | utf16 () const |
bool | operator!= (QLatin1String other ) const |
bool | operator!= (const char * other ) const |
bool | operator!= (const QByteArray & other ) const |
QString & | operator+= (const QString & other ) |
QString & | operator+= (QChar ch ) |
QString & | operator+= (const QStringRef & str ) |
QString & | operator+= (QLatin1String str ) |
QString & | operator+= (const char * str ) |
QString & | operator+= (const QByteArray & ba ) |
QString & | operator+= (char ch ) |
bool | operator< (QLatin1String other ) const |
bool | operator< (const char * other ) const |
bool | operator< (const QByteArray & other ) const |
bool | operator<= (QLatin1String other ) const |
bool | operator<= (const char * other ) const |
bool | operator<= (const QByteArray & other ) const |
QString & | operator= (const QString & other ) |
QString & | operator= (QChar ch ) |
QString & | operator= (QLatin1String str ) |
QString & | operator= (QString && other ) |
QString & | operator= (const char * str ) |
QString & | operator= (const QByteArray & ba ) |
QString & | operator= (char ch ) |
QString & | operator= ( const Null & ) |
bool | operator== (QLatin1String other ) const |
bool | operator== (const char * other ) const |
bool | operator== (const QByteArray & other ) const |
bool | operator> (QLatin1String other ) const |
bool | operator> (const char * other ) const |
bool | operator> (const QByteArray & other ) const |
bool | operator>= (QLatin1String other ) const |
bool | operator>= (const char * other ) const |
bool | operator>= (const QByteArray & other ) const |
QCharRef | operator[] (int position ) |
const QChar | operator[] (int position ) const |
const QChar | operator[] (uint position ) const |
QCharRef | operator[] (uint position ) |
QString | asprintf (const char * cformat , ... ) |
int | compare (const QString & s1 , const QString & s2 , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
int | compare (const QString & s1 , QLatin1String s2 , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
int | compare (QLatin1String s1 , const QString & s2 , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
int | compare (const QString & s1 , const QStringRef & s2 , Qt::CaseSensitivity cs = Qt::CaseSensitive) |
QString | fromCFString (CFStringRef string ) |
QString | fromLatin1 (const char * str , int size = -1) |
QString | fromLatin1 (const QByteArray & str ) |
QString | fromLocal8Bit (const char * str , int size = -1) |
QString | fromLocal8Bit (const QByteArray & str ) |
QString | fromNSString (const NSString * string ) |
QString | fromRawData (const QChar * unicode , int size ) |
QString | fromStdString (const std::string & str ) |
QString | fromStdU16String (const std::u16string & str ) |
QString | fromStdU32String (const std::u32string & str ) |
QString | fromStdWString (const std::wstring & str ) |
QString | fromUcs4 (const uint * unicode , int size = -1) |
QString | fromUcs4 (const char32_t * str , int size = -1) |
QString | fromUtf8 (const char * str , int size = -1) |
QString | fromUtf8 (const QByteArray & str ) |
QString | fromUtf16 (const ushort * unicode , int size = -1) |
QString | fromUtf16 (const char16_t * str , int size = -1) |
QString | fromWCharArray (const wchar_t * string , int size = -1) |
int | localeAwareCompare (const QString & s1 , const QString & s2 ) |
int | localeAwareCompare (const QString & s1 , const QStringRef & s2 ) |
QString | number (long n , int base = 10) |
QString | number (uint n , int base = 10) |
QString | number (int n , int base = 10) |
QString | number (ulong n , int base = 10) |
QString | number (qlonglong n , int base = 10) |
QString | number (qulonglong n , int base = 10) |
QString | number (double n , char format = 'g', int precision = 6) |
QString | vasprintf (const char * cformat , va_list ap ) |
bool | operator!= (const QString & s1 , const QString & s2 ) |
bool | operator!= (const char * s1 , const QString & s2 ) |
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 ) |
const QString | operator+ (char ch , const QString & s ) |
bool | operator< (const char * s1 , const QString & s2 ) |
QDataStream & | operator<< (QDataStream & stream , const QString & string ) |
bool | operator<= (const QString & s1 , const QString & s2 ) |
bool | operator<= (const char * s1 , const QString & s2 ) |
bool | operator== (const char * s1 , const QString & s2 ) |
bool | operator> (const QString & s1 , const QString & s2 ) |
bool | operator> (const char * s1 , const QString & s2 ) |
bool | operator>= (const QString & s1 , const QString & s2 ) |
bool | operator>= (const char * s1 , const QString & s2 ) |
QDataStream & | operator>> (QDataStream & stream , QString & string ) |
QStringLiteral ( str ) | |
QT_NO_CAST_FROM_ASCII | |
QT_NO_CAST_TO_ASCII | |
QT_RESTRICTED_CAST_FROM_ASCII |
QString 类提供 Unicode 字符串。
QString stores a string of 16-bit QChar ,其中各 QChar corresponds one Unicode 4.0 character. (Unicode characters with code values above 65535 are stored using surrogate pairs, i.e., two consecutive QChar s.)
Unicode is an international standard that supports most of the writing systems in use today. It is a superset of US-ASCII (ANSI X3.4-1986) and Latin-1 (ISO 8859-1), and all the US-ASCII/Latin-1 characters are available at the same code positions.
Behind the scenes, QString 使用 隐式共享 (copy-on-write) to reduce memory usage and to avoid the needless copying of data. This also helps reduce the inherent overhead of storing 16-bit characters instead of 8-bit characters.
除了 QString ,Qt 还提供 QByteArray class to store raw bytes and traditional 8-bit '\0'-terminated strings. For most purposes, QString is the class you want to use. It is used throughout the Qt API, and the Unicode support ensures that your applications will be easy to translate if you want to expand your application's market at some point. The two main cases where QByteArray is appropriate are when you need to store raw binary data, and when memory conservation is critical (like in embedded systems).
一种方式初始化
QString
是只需传递
const char *
to its constructor. For example, the following code creates a
QString
of size 5 containing the data "Hello":
QString str = "Hello";
QString
converts the
const char *
数据成 Unicode 使用
fromUtf8
() 函数。
In all of the
QString
functions that take
const char *
parameters, the
const char *
is interpreted as a classic C-style '\0'-terminated string encoded in UTF-8. It is legal for the
const char *
parameter to be 0.
You can also provide string data as an array of QChar s:
static const QChar data[4] = { 0x0055, 0x006e, 0x10e3, 0x03a3 }; QString str(data, 4);
QString makes a deep copy of the QChar data, so you can modify it later without experiencing side effects. (If for performance reasons you don't want to take a deep copy of the character data, use QString::fromRawData () instead.)
Another approach is to set the size of the string using resize () and to initialize the data character per character. QString uses 0-based indexes, just like C++ arrays. To access the character at a particular index position, you can use operator[] (). On non-const strings, operator[] () returns a reference to a character that can be used on the left side of an assignment. For example:
QString str; str.resize(4); str[0] = QChar('U'); str[1] = QChar('n'); str[2] = QChar(0x10e3); str[3] = QChar(0x03a3);
For read-only access, an alternative syntax is to use the at () 函数:
QString str; for (int i = 0; i < str.size(); ++i) { if (str.at(i) >= QChar('a') && str.at(i) <= QChar('f')) qDebug() << "Found character in range [a-f]"; }
at () function can be faster than operator[] (), because it never causes a 深拷贝 to occur. Alternatively, use the left (), right (),或 mid () functions to extract several characters at a time.
A QString can embed '\0' characters ( QChar::Null ). The size () function always returns the size of the whole string, including embedded '\0' characters.
After a call to the resize () function, newly allocated characters have undefined values. To set all the characters in the string to a particular value, use the fill () 函数。
QString provides dozens of overloads designed to simplify string usage. For example, if you want to compare a QString with a string literal, you can write code like this and it will work as expected:
QString str; if (str == "auto" || str == "extern" || str == "static" || str == "register") { // ... }
You can also pass string literals to functions that take QStrings as arguments, invoking the
QString
(const char *) constructor. Similarly, you can pass a
QString
to a function that takes a
const char *
argument using the
qPrintable
() macro which returns the given
QString
作为
const char *
. This is equivalent to calling <
QString
>.
toLocal8Bit
().
constData
().
QString provides the following basic functions for modifying the character data: append (), prepend (), insert (), replace (),和 remove ()。例如:
QString str = "and"; str.prepend("rock "); // str == "rock and" str.append(" roll"); // str == "rock and roll" str.replace(5, 3, "&"); // str == "rock & roll"
If you are building a QString gradually and know in advance approximately how many characters the QString will contain, you can call reserve (), asking QString to preallocate a certain amount of memory. You can also call capacity () to find out how much memory QString actually allocated.
replace () 和 remove () functions' first two arguments are the position from which to start erasing and the number of characters that should be erased. If you want to replace all occurrences of a particular substring with another, use one of the two-parameter replace () overloads.
A frequent requirement is to remove whitespace characters from a string ('\n', '\t', ' ', etc.). If you want to remove whitespace from both ends of a QString , use the trimmed () function. If you want to remove whitespace from both ends and replace multiple consecutive whitespaces with a single space character within the string, use simplified ().
If you want to find all occurrences of a particular character or substring in a QString , use the indexOf () 或 lastIndexOf () functions. The former searches forward starting from a given index position, the latter searches backward. Both return the index position of the character or substring if they find it; otherwise, they return -1. For example, here's a typical loop that finds all occurrences of a particular substring:
QString str = "We must be <b>bold</b>, very <b>bold</b>"; int j = 0; while ((j = str.indexOf("<b>", j)) != -1) { qDebug() << "Found <b> tag at index position" << j; ++j; }
QString provides many functions for converting numbers into strings and strings into numbers. See the arg () functions, the setNum () functions, the number () static functions, and the toInt (), toDouble (), and similar functions.
To get an upper- or lowercase version of a string use toUpper () 或 toLower ().
Lists of strings are handled by the QStringList class. You can split a string into a list of strings using the split () function, and join a list of strings into a single string with an optional separator using QStringList::join (). You can obtain a list of strings from a string list that contain a particular substring or that match a particular QRegExp 使用 QStringList::filter () 函数。
If you want to see if a QString starts or ends with a particular substring use startsWith () 或 endsWith (). If you simply want to check whether a QString contains a particular character or substring, use the contains () function. If you want to find out how many times a particular character or substring occurs in the string, use count ().
QStrings can be compared using overloaded operators such as operator< (), operator<= (), operator== (), operator>= (), and so on. Note that the comparison is based exclusively on the numeric Unicode values of the characters. It is very fast, but is not what a human would expect; the QString::localeAwareCompare () function is a better choice for sorting user-interface strings.
To obtain a pointer to the actual character data, call data () 或 constData (). These functions return a pointer to the beginning of the QChar data. The pointer is guaranteed to remain valid until a non-const function is called on the QString .
QString
provides the following three functions that return a
const char *
version of the string as
QByteArray
:
toUtf8
(),
toLatin1
(),和
toLocal8Bit
().
To convert from one of these encodings, QString 提供 fromLatin1 (), fromUtf8 (),和 fromLocal8Bit (). Other encodings are supported through the QTextCodec 类。
As mentioned above,
QString
provides a lot of functions and operators that make it easy to interoperate with
const char *
strings. But this functionality is a double-edged sword: It makes
QString
more convenient to use if all strings are US-ASCII or Latin-1, but there is always the risk that an implicit conversion from or to
const char *
is done using the wrong 8-bit encoding. To minimize these risks, you can turn off these implicit conversions by defining the following two preprocessor symbols:
QT_NO_CAST_FROM_ASCII
disables automatic conversions from C string literals and pointers to Unicode.
QT_RESTRICTED_CAST_FROM_ASCII
allows automatic conversions from C characters and character arrays, but disables automatic conversions from character pointers to Unicode.
QT_NO_CAST_TO_ASCII
disables automatic conversion from
QString
to C strings.
One way to define these preprocessor symbols globally for your application is to add the following entry to your qmake 工程文件 :
DEFINES += QT_NO_CAST_FROM_ASCII \ QT_NO_CAST_TO_ASCII
You then need to explicitly call fromUtf8 (), fromLatin1 (),或 fromLocal8Bit () to construct a QString from an 8-bit string, or use the lightweight QLatin1String class, for example:
QString url = QLatin1String("http://www.unicode.org/");
Similarly, you must call toLatin1 (), toUtf8 (),或 toLocal8Bit () explicitly to convert the QString to an 8-bit string. (Other encodings are supported through the QTextCodec class.)
Note for C Programmers |
---|
Due to C++'s type system and the fact that
QString
is
隐式共享
, QStrings may be treated like
int
s or other basic types. For example:
QString Widget::boolToString(bool b) { QString result; if (b) result = "True"; else result = "False"; return result; }
|
For historical reasons, QString distinguishes between a null string and an empty string. A null string is a string that is initialized using QString 's default constructor or by passing (const char *)0 to the constructor. An empty string is any string with size 0. A null string is always empty, but an empty string isn't necessarily null:
QString().isNull(); // returns true QString().isEmpty(); // returns true QString("").isNull(); // returns false QString("").isEmpty(); // returns true QString("abc").isNull(); // returns false QString("abc").isEmpty(); // returns false
All functions except isNull () treat null strings the same as empty strings. For example, toUtf8 (). constData () returns a pointer to a '\0' character for a null string ( not a null pointer), and QString () compares equal to QString (""). We recommend that you always use the isEmpty () function and avoid isNull ().
成员函数中的自变量 format 可以指定 (如: arg (), number ()),自变量 format can be one of the following:
格式 | 含义 |
---|---|
e
|
format as [-]9.9e[+|-]999 |
E
|
format as [-]9.9E[+|-]999 |
f
|
format as [-]9.9 |
g
|
use
e
or
f
format, whichever is the most concise
|
G
|
use
E
or
f
format, whichever is the most concise
|
A precision is also specified with the argument format . For the 'e', 'E', and 'f' formats, the precision represents the number of digits after the decimal point. For the 'g' and 'G' formats, the precision represents the maximum number of significant digits (trailing zeroes are omitted).
Many strings are known at compile time. But the trivial constructor QString ("Hello"), will copy the contents of the string, treating the contents as Latin-1. To avoid this one can use the QStringLiteral macro to directly create the required data at compile time. Constructing a QString out of the literal does then not cause any overhead at runtime.
A slightly less efficient way is to use QLatin1String . This class wraps a C string literal, precalculates it length at compile time and can then be used for faster comparison with QStrings and conversion to QStrings than a regular C string literal.
使用
QString
'+'
operator, it is easy to construct a complex string from multiple substrings. You will often write code like this:
QString foo; QString type = "long"; foo->setText(QLatin1String("vector<") + type + QLatin1String(">::iterator")); if (foo.startsWith("(" + type + ") 0x")) ...
There is nothing wrong with either of these string constructions, but there are a few hidden inefficiencies. Beginning with Qt 4.6, you can eliminate them.
First, multiple uses of the
'+'
operator usually means multiple memory allocations. When concatenating
n
substrings, where
n > 2
, there can be as many as
n - 1
calls to the memory allocator.
In 4.6, an internal template class
QStringBuilder
has been added along with a few helper functions. This class is marked internal and does not appear in the documentation, because you aren't meant to instantiate it in your code. Its use will be automatic, as described below. The class is found in
src/corelib/tools/qstringbuilder.cpp
if you want to have a look at it.
QStringBuilder
uses expression templates and reimplements the
'%'
operator so that when you use
'%'
for string concatenation instead of
'+'
, multiple substring concatenations will be postponed until the final result is about to be assigned to a
QString
. At this point, the amount of memory required for the final result is known. The memory allocator is then called
once
to get the required space, and the substrings are copied into it one by one.
Additional efficiency is gained by inlining and reduced reference counting (the
QString
created from a
QStringBuilder
typically has a ref count of 1, whereas
QString::append
() needs an extra test).
There are two ways you can access this improved method of string construction. The straightforward way is to include
QStringBuilder
wherever you want to use it, and use the
'%'
operator instead of
'+'
when concatenating strings:
#include <QStringBuilder> QString hello("hello"); QStringRef el(&hello, 2, 3); QLatin1String world("world"); QString message = hello % el % world % QChar('!');
A more global approach which is the most convenient but not entirely source compatible, is to this define in your .pro file:
DEFINES *= QT_USE_QSTRINGBUILDER
和
'+'
will automatically be performed as the
QStringBuilder
'%'
everywhere.
另请参阅 fromRawData (), QChar , QLatin1String , QByteArray ,和 QStringRef .
Qt 样式同义词 QString::const_iterator .
Qt 样式同义词 QString::iterator .
此枚举描述 Unicode 文本的各种规范化形式。
常量 | 值 | 描述 |
---|---|---|
QString::NormalizationForm_D
|
0
|
典型分解 |
QString::NormalizationForm_C
|
1
|
典型分解,紧接着是典型合成 |
QString::NormalizationForm_KD
|
2
|
兼容性分解 |
QString::NormalizationForm_KC
|
3
|
兼容性分解,紧接着是典型合成 |
另请参阅 normalized () 和 Unicode 标准附录 #15 .
This enum specifies flags that can be used to affect various aspects of the section () function's behavior with respect to separators and empty fields.
常量 | 值 | 描述 |
---|---|---|
QString::SectionDefault
|
0x00
|
Empty fields are counted, leading and trailing separators are not included, and the separator is compared case sensitively. |
QString::SectionSkipEmpty
|
0x01
|
Treat empty fields as if they don't exist, i.e. they are not considered as far as start and end are concerned. |
QString::SectionIncludeLeadingSep
|
0x02
|
Include the leading separator (if any) in the result string. |
QString::SectionIncludeTrailingSep
|
0x04
|
Include the trailing separator (if any) in the result string. |
QString::SectionCaseInsensitiveSeps
|
0x08
|
Compare the separator case-insensitively. |
The SectionFlags type is a typedef for QFlags <SectionFlag>. It stores an OR combination of SectionFlag values.
另请参阅 section ().
This enum specifies how the split () function should behave with respect to empty strings.
常量 | 值 | 描述 |
---|---|---|
QString::KeepEmptyParts
|
0
|
若字段为空,将它保持在结果中。 |
QString::SkipEmptyParts
|
1
|
若字段为空,不将它包括在结果中。 |
另请参阅 split ().
This typedef provides an STL-style const iterator for QString .
另请参阅 QString::iterator .
The QString::const_pointer typedef provides an STL-style const pointer to a QString 元素 ( QChar ).
This typedef provides an STL-style const reference for a QString 元素 ( QChar ).
This typedef provides an STL-style const reverse iterator for QString .
该 typedef 在 Qt 5.6 引入。
另请参阅 QString::reverse_iterator and QString::const_iterator .
QString::size_type typedef provides an STL-style type for difference between pointers.
The QString::iterator typedef provides an STL-style non-const iterator for QString .
另请参阅 QString::const_iterator .
QString::const_pointer typedef provides an STL-style pointer to a QString 元素 ( QChar ).
This typedef provides an STL-style reference for a QString 元素 ( QChar ).
This typedef provides an STL-style non-const reverse iterator for QString .
该 typedef 在 Qt 5.6 引入。
另请参阅 QString::const_reverse_iterator and QString::iterator .
The QString::size_type typedef provides an STL-style type for sizes (int).
This typedef provides an STL-style value type for QString .
Constructs a null string. Null strings are also empty.
另请参阅 isEmpty ().
Constructs a string initialized with the first size characters of the QChar array unicode .
若 unicode is 0, a null string is constructed.
若 size is negative, unicode is assumed to point to a nul-terminated array and its length is determined dynamically. The terminating nul-character is not considered part of the string.
QString makes a deep copy of the string data. The unicode data is copied as is and the Byte Order Mark is preserved if present.
另请参阅 fromRawData ().
Constructs a string of size 1 containing the character ch .
Constructs a string of the given size with every character set to ch .
另请参阅 fill ().
Constructs a copy of the Latin-1 string str .
另请参阅 fromLatin1 ().
构造副本为 other .
This operation takes 常量时间 ,因为 QString is 隐式共享 . This makes returning a QString from a function very fast. If a shared instance is modified, it will be copied (copy-on-write), and that takes 线性时间 .
另请参阅 operator= ().
移动构造 QString instance, making it point at the same object that other 所指向的。
该函数在 Qt 5.2 引入。
Constructs a string initialized with the 8-bit string str . The given const char pointer is converted to Unicode using the fromUtf8 () 函数。
You can disable this constructor by defining
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
注意:
Defining
QT_RESTRICTED_CAST_FROM_ASCII
also disables this constructor, but enables a
QString(const char (&ch)[N])
constructor instead. Using non-literal input, or input with embedded NUL characters, or non-7-bit characters is undefined in this case.
另请参阅 fromLatin1 (), fromLocal8Bit (),和 fromUtf8 ().
Constructs a string initialized with the byte array ba . The given byte array is converted to Unicode using fromUtf8 (). Stops copying at the first 0 character, otherwise copies the entire byte array.
You can disable this constructor by defining
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
另请参阅 fromLatin1 (), fromLocal8Bit (),和 fromUtf8 ().
销毁字符串。
追加字符串 str onto the end of this string.
范例:
QString x = "free"; QString y = "dom"; x.append(y); // x == "freedom"
这如同使用 insert () 函数:
x.insert(x.size(), y);
append() 函数通常非常快 ( 常量时间 ),因为 QString preallocates extra space at the end of the string data so it can grow without reallocating the entire string each time.
另请参阅 operator+= (), prepend (),和 insert ().
此函数重载 append ().
追加 len characters from the QChar array str 到此字符串。
该函数在 Qt 5.0 引入。
此函数重载 append ().
追加字符 ch 到此字符串。
追加给定字符串 reference to this string and returns the result.
该函数在 Qt 4.4 引入。
此函数重载 append ().
追加 Latin-1 字符串 str 到此字符串。
此函数重载 append ().
追加字符串 str to this string. The given const char pointer is converted to Unicode using the fromUtf8 () 函数。
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 append ().
追加字节数组 ba to this string. The given byte array is converted to Unicode using the fromUtf8 () 函数。
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
返回字符串副本,替换最小编号位置标记为字符串
a
,即:
%1
,
%2
, ...,
%99
.
fieldWidth specifies the minimum amount of space that argument a shall occupy. If a requires less space than fieldWidth , it is padded to fieldWidth with character fillChar . A positive fieldWidth produces right-aligned text. A negative fieldWidth produces left-aligned text.
此范例展示如何创建
status
字符串为处理文件列表时报告进度:
QString i; // current file's number QString total; // number of files to process QString fileName; // current file's name QString status = QString("Processing file %1 of %2: %3") .arg(i).arg(total).arg(fileName);
首先,
arg(i)
替换
%1
。然后
arg(total)
替换
%2
。最后,
arg(fileName)
替换
%3
.
One advantage of using arg() over
asprintf
() is that the order of the numbered place markers can change, if the application's strings are translated into other languages, but each arg() will still replace the lowest numbered unreplaced place marker, no matter where it appears. Also, if place marker
%i
appears more than once in the string, the arg() replaces all of them.
If there is no unreplaced place marker remaining, a warning message is output and the result is undefined. Place marker numbers must be in the range 1 to 99.
此函数重载 arg ().
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
base argument specifies the base to use when converting the integer a into a string. base must be between 2 and 36, with 8 giving octal, 10 decimal, and 16 hexadecimal numbers.
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
a argument is expressed in the given base , which is 10 by default and must be between 2 and 36.
The '%' can be followed by an 'L', in which case the sequence is replaced with a localized representation of a . The conversion uses the default locale. The default locale is determined from the system's locale settings at application startup. It can be changed using QLocale::setDefault (). The 'L' flag is ignored if base is not 10.
QString str; str = QString("Decimal 63 is %1 in hexadecimal") .arg(63, 0, 16); // str == "Decimal 63 is 3f in hexadecimal" QLocale::setDefault(QLocale(QLocale::English, QLocale::UnitedStates)); str = QString("%1 %L2 %L3") .arg(12345) .arg(12345) .arg(12345, 0, 16); // str == "12345 12,345 3039"
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
base argument specifies the base to use when converting the integer a to a string. The base must be between 2 and 36, with 8 giving octal, 10 decimal, and 16 hexadecimal numbers.
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
a argument is expressed in base base , which is 10 by default and must be between 2 and 36. For bases other than 10, a is treated as an unsigned integer.
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
The '%' can be followed by an 'L', in which case the sequence is replaced with a localized representation of a . The conversion uses the default locale, set by QLocale::setDefault (). If no default locale was specified, the "C" locale is used. The 'L' flag is ignored if base is not 10.
QString str; str = QString("Decimal 63 is %1 in hexadecimal") .arg(63, 0, 16); // str == "Decimal 63 is 3f in hexadecimal" QLocale::setDefault(QLocale(QLocale::English, QLocale::UnitedStates)); str = QString("%1 %L2 %L3") .arg(12345) .arg(12345) .arg(12345, 0, 16); // str == "12345 12,345 3039"
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
base argument specifies the base to use when converting the integer a into a string. The base must be between 2 and 36.
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
base argument specifies the base to use when converting the integer a into a string. The base must be between 2 and 36, with 8 giving octal, 10 decimal, and 16 hexadecimal numbers.
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
base argument specifies the base to use when converting the integer a into a string. The base must be between 2 and 36, with 8 giving octal, 10 decimal, and 16 hexadecimal numbers.
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
Argument a is formatted according to the specified format and precision 。见 自变量格式 了解细节。
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
double d = 12.34; QString str = QString("delta: %1").arg(d, 0, 'E', 3); // str == "delta: 1.234E+01"
The '%' can be followed by an 'L', in which case the sequence is replaced with a localized representation of a . The conversion uses the default locale, set by QLocale::setDefault (). If no default locale was specified, the "C" locale is used.
若 fillChar is '0' (the number 0, ASCII 48), this function will use the locale's zero to pad. For negative numbers, the zero padding will probably appear before the minus sign.
另请参阅 QLocale::toString ().
此函数重载 arg ().
a argument is interpreted as a Latin-1 character.
此函数重载 arg ().
此函数重载 arg ().
fieldWidth specifies the minimum amount of space that a is padded to and filled with the character fillChar . A positive value produces right-aligned text; a negative value produces left-aligned text.
base argument specifies the base to use when converting the integer a into a string. The base must be between 2 and 36, with 8 giving octal, 10 decimal, and 16 hexadecimal numbers.
若 fillChar is '0' (the number 0, ASCII 48), the locale's zero is used. For negative numbers, zero padding might appear before the minus sign.
此函数重载 arg ().
这如同
str.arg(a1).arg(a2)
, except that the strings
a1
and
a2
are replaced in one pass. This can make a difference if
a1
contains e.g.
%1
:
QString str; str = "%1 %2"; str.arg("%1f", "Hello"); // returns "%1f Hello" str.arg("%1f").arg("Hello"); // returns "Hellof %2"
A similar problem occurs when the numbered place markers are not white space separated:
QString str; str = "%1%3%2"; str.arg("Hello").arg(20).arg(50); // returns "Hello500" str = "%1%2%3"; str.arg("Hello").arg(50).arg(20); // returns "Hello5020"
Let's look at the substitutions:
Hello
替换
%1
so the string becomes
"Hello%3%2"
.
20
替换
%2
so the string becomes
"Hello%320"
.
50
替换
%32
.
Thus the string finally becomes
"Hello500"
.
In such cases, the following yields the expected results:
QString str; str = "%1%2%3"; str.arg("Hello", QString::number(20), QString::number(50)); // returns "Hello5020"
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3)
, except that the strings
a1
,
a2
and
a3
are replaced in one pass.
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3).arg(a4)
, except that the strings
a1
,
a2
,
a3
and
a4
are replaced in one pass.
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3).arg(a4).arg(a5)
, except that the strings
a1
,
a2
,
a3
,
a4
,和
a5
are replaced in one pass.
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3).arg(a4).arg(a5).arg(a6))
, except that the strings
a1
,
a2
,
a3
,
a4
,
a5
,和
a6
are replaced in one pass.
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3).arg(a4).arg(a5).arg(a6).arg(a7)
, except that the strings
a1
,
a2
,
a3
,
a4
,
a5
,
a6
,和
a7
are replaced in one pass.
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3).arg(a4).arg(a5).arg(a6).arg(a7).arg(a8)
, except that the strings
a1
,
a2
,
a3
,
a4
,
a5
,
a6
,
a7
,和
a8
are replaced in one pass.
此函数重载 arg ().
这如同调用
str.arg(a1).arg(a2).arg(a3).arg(a4).arg(a5).arg(a6).arg(a7).arg(a8).arg(a9)
, except that the strings
a1
,
a2
,
a3
,
a4
,
a5
,
a6
,
a7
,
a8
,和
a9
are replaced in one pass.
[static]
QString
QString::
asprintf
(const
char
*
cformat
,
...
)
Safely builds a formatted string from the format string cformat and an arbitrary list of arguments.
The format string supports the conversion specifiers, length modifiers, and flags provided by printf() in the standard C++ library. The
cformat
string and
%s
arguments must be UTF-8 encoded.
注意:
%lc
escape sequence expects a unicode character of type
char16_t
,或
ushort
(as returned by
QChar::unicode
())。
%ls
escape sequence expects a pointer to a zero-terminated array of unicode characters of type
char16_t
, or ushort (as returned by
QString::utf16
()). This is at odds with the printf() in the standard C++ library, which defines
%lc
to print a wchar_t and
%ls
to print a
wchar_t*
, and might also produce compiler warnings on platforms where the size of
wchar_t
is not 16 bits.
警告: We do not recommend using QString::asprintf() in new Qt code. Instead, consider using QTextStream or arg (), both of which support Unicode strings seamlessly and are type-safe. Here's an example that uses QTextStream :
QString result; QTextStream(&result) << "pi = " << 3.14; // result == "pi = 3.14"
For translations , especially if the strings contains more than one escape sequence, you should consider using the arg () function instead. This allows the order of the replacements to be controlled by the translator.
该函数在 Qt 5.5 引入。
另请参阅 arg ().
Returns the character at the given index position in the string.
position must be a valid index position in the string (i.e., 0 <= position < size ()).
另请参阅 operator[] ().
返回 STL 样式迭代器 pointing to the first character in the string.
另请参阅 constBegin () 和 end ().
此函数重载 begin ().
Returns the maximum number of characters that can be stored in the string without forcing a reallocation.
The sole purpose of this function is to provide a means of fine tuning QString 's memory usage. In general, you will rarely ever need to call this function. If you want to know how many characters are in the string, call size ().
返回常量 STL 样式迭代器 pointing to the first character in the string.
该函数在 Qt 5.0 引入。
返回常量 STL 样式迭代器 pointing to the imaginary character after the last character in the list.
该函数在 Qt 5.0 引入。
移除 n characters from the end of the string.
若 n is greater than or equal to size (), the result is an empty string; if n is negative, it is equivalent to passing zero.
范例:
QString str("LOGOUT\r\n"); str.chop(2); // str == "LOGOUT"
If you want to remove characters from the beginning of the string, use remove () 代替。
另请参阅 truncate (), resize (), remove (),和 QStringRef::chop ().
Clears the contents of the string and makes it null.
[static]
int
QString::
compare
(const
QString
&
s1
, const
QString
&
s2
,
Qt::CaseSensitivity
cs
= Qt::CaseSensitive)
比较 s1 with s2 and returns an integer less than, equal to, or greater than zero if s1 is less than, equal to, or greater than s2 .
若 cs is Qt::CaseSensitive , the comparison is case sensitive; otherwise the comparison is case insensitive.
Case sensitive comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-visible strings with localeAwareCompare ().
int x = QString::compare("aUtO", "AuTo", Qt::CaseInsensitive); // x == 0 int y = QString::compare("auto", "Car", Qt::CaseSensitive); // y > 0 int z = QString::compare("auto", "Car", Qt::CaseInsensitive); // z < 0
该函数在 Qt 4.2 引入。
另请参阅 operator== (), operator< (),和 operator> ().
此函数重载 compare ().
Same as compare(*this, other , cs ).
该函数在 Qt 4.2 引入。
此函数重载 compare ().
Lexically compares this string with the other string and returns an integer less than, equal to, or greater than zero if this string is less than, equal to, or greater than the other string.
Same as compare(*this, other , cs ).
该函数在 Qt 4.2 引入。
[static]
int
QString::
compare
(const
QString
&
s1
,
QLatin1String
s2
,
Qt::CaseSensitivity
cs
= Qt::CaseSensitive)
此函数重载 compare ().
Performs a comparison of s1 and s2 , using the case sensitivity setting cs .
该函数在 Qt 4.2 引入。
[static]
int
QString::
compare
(
QLatin1String
s1
, const
QString
&
s2
,
Qt::CaseSensitivity
cs
= Qt::CaseSensitive)
此函数重载 compare ().
Performs a comparison of s1 and s2 , using the case sensitivity setting cs .
该函数在 Qt 4.2 引入。
此函数重载 compare ().
Compares the string reference, ref , with the string and returns an integer less than, equal to, or greater than zero if the string is less than, equal to, or greater than ref .
[static]
int
QString::
compare
(const
QString
&
s1
, const
QStringRef
&
s2
,
Qt::CaseSensitivity
cs
= Qt::CaseSensitive)
此函数重载 compare ().
返回常量 STL 样式迭代器 pointing to the first character in the string.
Returns a pointer to the data stored in the QString . The pointer can be used to access the characters that compose the string.
Note that the pointer remains valid only as long as the string is not modified.
注意: The returned string may not be '\0'-terminated. Use size () to determine the length of the array.
另请参阅 data (), operator[] (),和 fromRawData ().
返回常量 STL 样式迭代器 pointing to the imaginary character after the last character in the list.
另请参阅 constBegin () 和 end ().
返回
true
if this string contains an occurrence of the string
str
;否则返回
false
.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString str = "Peter Pan"; str.contains("peter", Qt::CaseInsensitive); // returns true
此函数重载 contains ().
返回
true
if this string contains an occurrence of the character
ch
;否则返回
false
.
此函数重载 contains ().
返回
true
if this string contains an occurrence of the latin-1 string
str
;否则返回
false
.
该函数在 Qt 5.3 引入。
返回
true
if this string contains an occurrence of the string reference
str
;否则返回
false
.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.8 引入。
此函数重载 contains ().
返回
true
if the regular expression
rx
matches somewhere in this string; otherwise returns
false
.
此函数重载 contains ().
返回
true
if the regular expression
rx
matches somewhere in this string; otherwise returns
false
.
If there is a match, the rx regular expression will contain the matched captures (see QRegExp::matchedLength , QRegExp::cap ).
该函数在 Qt 4.5 引入。
此函数重载 contains ().
返回
true
if the regular expression
re
matches somewhere in this string; otherwise returns
false
.
该函数在 Qt 5.0 引入。
此函数重载 contains ().
返回
true
if the regular expression
re
matches somewhere in this string; otherwise returns
false
.
If the match is successful and match is not a null pointer, it also writes the results of the match into the QRegularExpressionMatch object pointed to by match .
该函数在 Qt 5.1 引入。
另请参阅 QRegularExpression::match ().
Returns the number of (potentially overlapping) occurrences of the string str in this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
另请参阅 contains () 和 indexOf ().
此函数重载 count ().
Returns the number of occurrences of character ch in the string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
另请参阅 contains () 和 indexOf ().
This function overloads count().
如同 size ().
此函数重载 count ().
Returns the number of (potentially overlapping) occurrences of the string reference str in this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.8 引入。
另请参阅 contains () 和 indexOf ().
此函数重载 count ().
Returns the number of times the regular expression rx matches in the string.
This function counts overlapping matches, so in the example below, there are four instances of "ana" or "ama":
QString str = "banana and panama"; str.count(QRegExp("a[nm]a")); // returns 4
此函数重载 count ().
Returns the number of times the regular expression re matches in the string.
This function counts overlapping matches, so in the example below, there are four instances of "ana" or "ama":
QString str = "banana and panama"; str.count(QRegularExpression("a[nm]a")); // returns 4
该函数在 Qt 5.0 引入。
返回常量 STL-style reverse iterator pointing to the first character in the string, in reverse order.
该函数在 Qt 5.6 引入。
另请参阅 begin (), rbegin (),和 rend ().
返回常量 STL-style reverse iterator pointing to one past the last character in the string, in reverse order.
该函数在 Qt 5.6 引入。
另请参阅 end (), rend (),和 rbegin ().
Returns a pointer to the data stored in the QString . The pointer can be used to access and modify the characters that compose the string.
不像 constData () 和 unicode (), the returned data is always '\0'-terminated.
范例:
QString str = "Hello world"; QChar *data = str.data(); while (!data->isNull()) { qDebug() << data->unicode(); ++data; }
Note that the pointer remains valid only as long as the string is not modified by other means. For read-only access, constData () 更快,因为它从不导致 深拷贝 的出现。
另请参阅 constData () 和 operator[] ().
这是重载函数。
注意: The returned string may not be '\0'-terminated. Use size () to determine the length of the array.
另请参阅 fromRawData ().
返回 STL 样式迭代器 pointing to the imaginary character after the last character in the string.
此函数重载 end ().
返回
true
if the string ends with
s
;否则返回
false
.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
QString str = "Bananas"; str.endsWith("anas"); // returns true str.endsWith("pple"); // returns false
另请参阅 startsWith ().
此函数重载 endsWith ().
返回
true
if the string ends with the string reference
s
;否则返回
false
.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.8 引入。
另请参阅 startsWith ().
此函数重载 endsWith ().
返回
true
if the string ends with
c
;否则返回
false
.
此函数重载 endsWith ().
Sets every character in the string to character ch 。若 size is different from -1 (default), the string is resized to size beforehand.
范例:
QString str = "Berlin"; str.fill('z'); // str == "zzzzzz" str.fill('A', 2); // str == "AA"
另请参阅 resize ().
[static]
QString
QString::
fromCFString
(
CFStringRef
string
)
构造新的 QString containing a copy of the string CFString.
注意: this function is only available on OS X and iOS.
该函数在 Qt 5.2 引入。
[static]
QString
QString::
fromLatin1
(const
char
*
str
,
int
size
= -1)
返回 QString initialized with the first size characters of the Latin-1 string str .
若 size is -1 (default), it is taken to be strlen( str ).
另请参阅 toLatin1 (), fromUtf8 (),和 fromLocal8Bit ().
[static]
QString
QString::
fromLatin1
(const
QByteArray
&
str
)
这是重载函数。
返回 QString initialized with the Latin-1 string str .
该函数在 Qt 5.0 引入。
[static]
QString
QString::
fromLocal8Bit
(const
char
*
str
,
int
size
= -1)
返回 QString initialized with the first size characters of the 8-bit string str .
若 size is -1 (default), it is taken to be strlen( str ).
QTextCodec::codecForLocale () is used to perform the conversion.
另请参阅 toLocal8Bit (), fromLatin1 (),和 fromUtf8 ().
[static]
QString
QString::
fromLocal8Bit
(const
QByteArray
&
str
)
这是重载函数。
返回 QString initialized with the 8-bit string str .
该函数在 Qt 5.0 引入。
[static]
QString
QString::
fromNSString
(const
NSString
*
string
)
构造新的 QString containing a copy of the string NSString.
注意: this function is only available on OS X and iOS.
该函数在 Qt 5.2 引入。
[static]
QString
QString::
fromRawData
(const
QChar
*
unicode
,
int
size
)
构造 QString that uses the first size Unicode characters in the array unicode . The data in unicode is not copied. The caller must be able to guarantee that unicode will not be deleted or modified as long as the QString (or an unmodified copy of it) exists.
Any attempts to modify the QString or copies of it will cause it to create a deep copy of the data, ensuring that the raw data isn't modified.
Here's an example of how we can use a QRegularExpression on raw data in memory without requiring to copy the data into a QString :
QRegularExpression pattern("\u00A4"); static const QChar unicode[] = { 0x005A, 0x007F, 0x00A4, 0x0060, 0x1009, 0x0020, 0x0020}; int size = sizeof(unicode) / sizeof(QChar); QString str = QString::fromRawData(unicode, size); if (str.contains(pattern) { // ... }
警告: A string created with fromRawData() is not '\0'-terminated, unless the raw data contains a '\0' character at position size . This means unicode () will not return a '\0'-terminated string (although utf16 () does, at the cost of copying the raw data).
另请参阅 fromUtf16 () 和 setRawData ().
[static]
QString
QString::
fromStdString
(const
std::string
&
str
)
返回副本为 str string. The given string is converted to Unicode using the fromUtf8 () 函数。
另请参阅 fromLatin1 (), fromLocal8Bit (), fromUtf8 (),和 QByteArray::fromStdString ().
[static]
QString
QString::
fromStdU16String
(const
std::u16string
&
str
)
返回副本为 str string. The given string is assumed to be encoded in UTF-16.
该函数在 Qt 5.5 引入。
另请参阅 fromUtf16 (), fromStdWString (),和 fromStdU32String ().
[static]
QString
QString::
fromStdU32String
(const
std::u32string
&
str
)
返回副本为 str string. The given string is assumed to be encoded in UCS-4.
该函数在 Qt 5.5 引入。
另请参阅 fromUcs4 (), fromStdWString (),和 fromStdU16String ().
[static]
QString
QString::
fromStdWString
(const
std::wstring
&
str
)
返回副本为 str string. The given string is assumed to be encoded in utf16 if the size of wchar_t is 2 bytes (e.g. on windows) and ucs4 if the size of wchar_t is 4 bytes (most Unix systems).
另请参阅 fromUtf16 (), fromLatin1 (), fromLocal8Bit (), fromUtf8 (), fromUcs4 (), fromStdU16String (),和 fromStdU32String ().
[static]
QString
QString::
fromUcs4
(const
uint
*
unicode
,
int
size
= -1)
返回 QString initialized with the first size characters of the Unicode string unicode (ISO-10646-UCS-4 encoded).
若 size is -1 (default), unicode must be terminated with a 0.
该函数在 Qt 4.2 引入。
另请参阅 toUcs4 (), fromUtf16 (), utf16 (), setUtf16 (), fromWCharArray (),和 fromStdU32String ().
[static]
QString
QString::
fromUcs4
(const
char32_t
*
str
,
int
size
= -1)
返回 QString initialized with the first size characters of the Unicode string str (ISO-10646-UCS-4 encoded).
若 size is -1 (default), str must be terminated with a 0.
该函数在 Qt 5.3 引入。
另请参阅 toUcs4 (), fromUtf16 (), utf16 (), setUtf16 (), fromWCharArray (),和 fromStdU32String ().
[static]
QString
QString::
fromUtf8
(const
char
*
str
,
int
size
= -1)
返回 QString initialized with the first size bytes of the UTF-8 string str .
若 size is -1 (default), it is taken to be strlen( str ).
UTF-8 is a Unicode codec and can represent all characters in a Unicode string like QString . However, invalid sequences are possible with UTF-8 and, if any such are found, they will be replaced with one or more "replacement characters", or suppressed. These include non-Unicode sequences, non-characters, overlong sequences or surrogate codepoints encoded into UTF-8.
This function can be used to process incoming data incrementally as long as all UTF-8 characters are terminated within the incoming data. Any unterminated characters at the end of the string will be replaced or suppressed. In order to do stateful decoding, please use QTextDecoder .
另请参阅 toUtf8 (), fromLatin1 (),和 fromLocal8Bit ().
[static]
QString
QString::
fromUtf8
(const
QByteArray
&
str
)
这是重载函数。
返回 QString initialized with the UTF-8 string str .
该函数在 Qt 5.0 引入。
[static]
QString
QString::
fromUtf16
(const
ushort
*
unicode
,
int
size
= -1)
返回 QString initialized with the first size characters of the Unicode string unicode (ISO-10646-UTF-16 encoded).
若 size is -1 (default), unicode must be terminated with a 0.
This function checks for a Byte Order Mark (BOM). If it is missing, host byte order is assumed.
This function is slow compared to the other Unicode conversions. Use QString (const QChar *, int) or QString (const QChar *) if possible.
QString makes a deep copy of the Unicode data.
另请参阅 utf16 (), setUtf16 (),和 fromStdU16String ().
[static]
QString
QString::
fromUtf16
(const
char16_t
*
str
,
int
size
= -1)
返回 QString initialized with the first size characters of the Unicode string str (ISO-10646-UTF-16 encoded).
若 size is -1 (default), str must be terminated with a 0.
This function checks for a Byte Order Mark (BOM). If it is missing, host byte order is assumed.
This function is slow compared to the other Unicode conversions. Use QString (const QChar *, int) or QString (const QChar *) if possible.
QString makes a deep copy of the Unicode data.
该函数在 Qt 5.3 引入。
另请参阅 utf16 (), setUtf16 (),和 fromStdU16String ().
[static]
QString
QString::
fromWCharArray
(const
wchar_t
*
string
,
int
size
= -1)
返回副本为 string , where the encoding of string depends on the size of wchar. If wchar is 4 bytes, the string is interpreted as UCS-4, if wchar is 2 bytes it is interpreted as UTF-16.
若 size is -1 (default), the string has to be 0 terminated.
该函数在 Qt 4.2 引入。
另请参阅 fromUtf16 (), fromLatin1 (), fromLocal8Bit (), fromUtf8 (), fromUcs4 (),和 fromStdWString ().
Returns the index position of the first occurrence of the string str in this string, searching forward from index position from . Returns -1 if str 找不到。
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString x = "sticky question"; QString y = "sti"; x.indexOf(y); // returns 0 x.indexOf(y, 1); // returns 10 x.indexOf(y, 10); // returns 10 x.indexOf(y, 11); // returns -1
若 from is -1, the search starts at the last character; if it is -2, at the next to last character and so on.
另请参阅 lastIndexOf (), contains (),和 count ().
此函数重载 indexOf ().
Returns the index position of the first occurrence of the character ch in the string, searching forward from index position from . Returns -1 if ch could not be found.
Returns the index position of the first occurrence of the string str in this string, searching forward from index position from . Returns -1 if str 找不到。
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString x = "sticky question"; QString y = "sti"; x.indexOf(y); // returns 0 x.indexOf(y, 1); // returns 10 x.indexOf(y, 10); // returns 10 x.indexOf(y, 11); // returns -1
若 from is -1, the search starts at the last character; if it is -2, at the next to last character and so on.
该函数在 Qt 4.5 引入。
另请参阅 lastIndexOf (), contains (),和 count ().
此函数重载 indexOf ().
Returns the index position of the first occurrence of the string reference str in this string, searching forward from index position from . Returns -1 if str 找不到。
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.8 引入。
此函数重载 indexOf ().
Returns the index position of the first match of the regular expression rx in the string, searching forward from index position from . Returns -1 if rx didn't match anywhere.
范例:
QString str = "the minimum"; str.indexOf(QRegExp("m[aeiou]"), 0); // returns 4
此函数重载 indexOf ().
Returns the index position of the first match of the regular expression rx in the string, searching forward from index position from . Returns -1 if rx didn't match anywhere.
If there is a match, the rx regular expression will contain the matched captures (see QRegExp::matchedLength , QRegExp::cap ).
范例:
QString str = "the minimum"; str.indexOf(QRegExp("m[aeiou]"), 0); // returns 4
该函数在 Qt 4.5 引入。
此函数重载 indexOf ().
Returns the index position of the first match of the regular expression re in the string, searching forward from index position from . Returns -1 if re didn't match anywhere.
范例:
QString str = "the minimum"; str.indexOf(QRegularExpression("m[aeiou]"), 0); // returns 4
该函数在 Qt 5.0 引入。
这是重载函数。
Returns the index position of the first match of the regular expression re in the string, searching forward from index position from . Returns -1 if re didn't match anywhere.
If the match is successful and rmatch is not a null pointer, it also writes the results of the match into the QRegularExpressionMatch object pointed to by rmatch .
范例:
QString str = "the minimum"; QRegularExpressionMatch match; str.indexOf(QRegularExpression("m[aeiou]"), 0, &match); // returns 4 // match.captured() == mi
该函数在 Qt 5.5 引入。
Inserts the string str at the given index position and returns a reference to this string.
范例:
QString str = "Meal"; str.insert(1, QString("ontr")); // str == "Montreal"
若给定 position 大于 size (), the array is first extended using resize ().
另请参阅 append (), prepend (), replace (),和 remove ().
此函数重载 insert ().
Inserts the first size characters of the QChar array unicode at the given index position in the string.
此函数重载 insert ().
插入 ch at the given index position in the string.
此函数重载 insert ().
Inserts the string reference str at the given index position and returns a reference to this string.
若给定 position 大于 size (), the array is first extended using resize ().
该函数在 Qt 5.5 引入。
此函数重载 insert ().
Inserts the Latin-1 string str at the given index position .
此函数重载 insert ().
Inserts the C string str at the given index position and returns a reference to this string.
若给定 position 大于 size (), the array is first extended using resize ().
This function is not available when QT_NO_CAST_FROM_ASCII is defined.
该函数在 Qt 5.5 引入。
此函数重载 insert ().
Inserts the byte array str at the given index position and returns a reference to this string.
若给定 position 大于 size (), the array is first extended using resize ().
This function is not available when QT_NO_CAST_FROM_ASCII is defined.
该函数在 Qt 5.5 引入。
返回
true
if the string has no characters; otherwise returns
false
.
范例:
QString().isEmpty(); // returns true QString("").isEmpty(); // returns true QString("x").isEmpty(); // returns false QString("abc").isEmpty(); // returns false
另请参阅 size ().
返回
true
if this string is null; otherwise returns
false
.
范例:
QString().isNull(); // returns true QString("").isNull(); // returns false QString("abc").isNull(); // returns false
Qt makes a distinction between null strings and empty strings for historical reasons. For most applications, what matters is whether or not a string contains any data, and this can be determined using the isEmpty () 函数。
另请参阅 isEmpty ().
返回
true
if the string is read right to left.
另请参阅 QStringRef::isRightToLeft ().
Returns the index position of the last occurrence of the string str in this string, searching backward from index position from 。若 from is -1 (default), the search starts at the last character; if from is -2, at the next to last character and so on. Returns -1 if str 找不到。
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString x = "crazy azimuths"; QString y = "az"; x.lastIndexOf(y); // returns 6 x.lastIndexOf(y, 6); // returns 6 x.lastIndexOf(y, 5); // returns 2 x.lastIndexOf(y, 1); // returns -1
另请参阅 indexOf (), contains (),和 count ().
此函数重载 lastIndexOf ().
Returns the index position of the last occurrence of the character ch , searching backward from position from .
此函数重载 lastIndexOf ().
Returns the index position of the last occurrence of the string str in this string, searching backward from index position from 。若 from is -1 (default), the search starts at the last character; if from is -2, at the next to last character and so on. Returns -1 if str 找不到。
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString x = "crazy azimuths"; QString y = "az"; x.lastIndexOf(y); // returns 6 x.lastIndexOf(y, 6); // returns 6 x.lastIndexOf(y, 5); // returns 2 x.lastIndexOf(y, 1); // returns -1
该函数在 Qt 4.5 引入。
另请参阅 indexOf (), contains (),和 count ().
此函数重载 lastIndexOf ().
Returns the index position of the last occurrence of the string reference str in this string, searching backward from index position from 。若 from is -1 (default), the search starts at the last character; if from is -2, at the next to last character and so on. Returns -1 if str 找不到。
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.8 引入。
另请参阅 indexOf (), contains (),和 count ().
此函数重载 lastIndexOf ().
Returns the index position of the last match of the regular expression rx in the string, searching backward from index position from . Returns -1 if rx didn't match anywhere.
范例:
QString str = "the minimum"; str.lastIndexOf(QRegExp("m[aeiou]")); // returns 8
此函数重载 lastIndexOf ().
Returns the index position of the last match of the regular expression rx in the string, searching backward from index position from . Returns -1 if rx didn't match anywhere.
If there is a match, the rx regular expression will contain the matched captures (see QRegExp::matchedLength , QRegExp::cap ).
范例:
QString str = "the minimum"; str.lastIndexOf(QRegExp("m[aeiou]")); // returns 8
该函数在 Qt 4.5 引入。
此函数重载 lastIndexOf ().
Returns the index position of the last match of the regular expression re in the string, which starts before the index position from . Returns -1 if re didn't match anywhere.
范例:
QString str = "the minimum"; str.lastIndexOf(QRegularExpression("m[aeiou]")); // returns 8
该函数在 Qt 5.0 引入。
这是重载函数。
Returns the index position of the last match of the regular expression re in the string, which starts before the index position from . Returns -1 if re didn't match anywhere.
If the match is successful and rmatch is not a null pointer, it also writes the results of the match into the QRegularExpressionMatch object pointed to by rmatch .
范例:
QString str = "the minimum"; QRegularExpressionMatch match; str.lastIndexOf(QRegularExpression("m[aeiou]"), -1, &match); // returns 8 // match.captured() == mu
该函数在 Qt 5.5 引入。
Returns a substring that contains the n leftmost characters of the string.
The entire string is returned if n is greater than or equal to size (), or less than zero.
QString x = "Pineapple"; QString y = x.left(4); // y == "Pine"
另请参阅 right (), mid (),和 startsWith ().
Returns a string of size width that contains this string padded by the fill character.
若
truncate
is
false
和
size
() of the string is more than
width
, then the returned string is a copy of the string.
QString s = "apple"; QString t = s.leftJustified(8, '.'); // t == "apple..."
若
truncate
is
true
和
size
() of the string is more than
width
, then any characters in a copy of the string after position
width
are removed, and the copy is returned.
QString str = "Pineapple"; str = str.leftJustified(5, '.', true); // str == "Pinea"
另请参阅 rightJustified ().
Returns a substring reference to the n leftmost characters of the string.
若 n is greater than or equal to size (), or less than zero, a reference to the entire string is returned.
QString x = "Pineapple"; QStringRef y = x.leftRef(4); // y == "Pine"
该函数在 Qt 4.4 引入。
另请参阅 left (), rightRef (), midRef (),和 startsWith ().
Returns the number of characters in this string. Equivalent to size ().
另请参阅 resize ().
[static]
int
QString::
localeAwareCompare
(const
QString
&
s1
, const
QString
&
s2
)
比较 s1 with s2 and returns an integer less than, equal to, or greater than zero if s1 is less than, equal to, or greater than s2 .
The comparison is performed in a locale- and also platform-dependent manner. Use this function to present sorted lists of strings to the user.
On macOS and iOS this function compares according the "Order for sorted lists" setting in the International preferences panel.
此函数重载 localeAwareCompare ().
Compares this string with the other string and returns an integer less than, equal to, or greater than zero if this string is less than, equal to, or greater than the other 字符串。
The comparison is performed in a locale- and also platform-dependent manner. Use this function to present sorted lists of strings to the user.
如同
localeAwareCompare(*this, other)
.
此函数重载 localeAwareCompare ().
Compares this string with the other string and returns an integer less than, equal to, or greater than zero if this string is less than, equal to, or greater than the other 字符串。
The comparison is performed in a locale- and also platform-dependent manner. Use this function to present sorted lists of strings to the user.
如同
localeAwareCompare(*this, other)
.
该函数在 Qt 4.5 引入。
[static]
int
QString::
localeAwareCompare
(const
QString
&
s1
, const
QStringRef
&
s2
)
此函数重载 localeAwareCompare ().
比较 s1 with s2 and returns an integer less than, equal to, or greater than zero if s1 is less than, equal to, or greater than s2 .
The comparison is performed in a locale- and also platform-dependent manner. Use this function to present sorted lists of strings to the user.
该函数在 Qt 4.5 引入。
Returns a string that contains n characters of this string, starting at the specified position index.
Returns a null string if the position index exceeds the length of the string. If there are less than n characters available in the string starting at the given position ,或者若 n is -1 (default), the function returns all characters that are available from the specified position .
范例:
QString x = "Nine pineapples"; QString y = x.mid(5, 4); // y == "pine" QString z = x.mid(5); // z == "pineapples"
Returns a substring reference to n characters of this string, starting at the specified position .
若 position exceeds the length of the string, a null reference is returned.
If there are less than n characters available in the string, starting at the given position ,或者若 n is -1 (default), the function returns all characters from the specified position onwards.
范例:
QString x = "Nine pineapples"; QStringRef y = x.midRef(5, 4); // y == "pine" QStringRef z = x.midRef(5); // z == "pineapples"
该函数在 Qt 4.4 引入。
另请参阅 mid (), leftRef (),和 rightRef ().
Returns the string in the given Unicode normalization mode , according to the given version of the Unicode standard.
[static]
QString
QString::
number
(
long
n
,
int
base
= 10)
Returns a string equivalent of the number n 根据指定 base .
The base is 10 by default and must be between 2 and 36. For bases other than 10, n is treated as an unsigned integer.
格式始终使用 QLocale::C , i.e., English/UnitedStates. To get a localized string representation of a number, use QLocale::toString () with the appropriate locale.
long a = 63; QString s = QString::number(a, 16); // s == "3f" QString t = QString::number(a, 16).toUpper(); // t == "3F"
另请参阅 setNum ().
[static]
QString
QString::
number
(
uint
n
,
int
base
= 10)
这是重载函数。
[static]
QString
QString::
number
(
int
n
,
int
base
= 10)
这是重载函数。
[static]
QString
QString::
number
(
ulong
n
,
int
base
= 10)
这是重载函数。
[static]
QString
QString::
number
(
qlonglong
n
,
int
base
= 10)
这是重载函数。
[static]
QString
QString::
number
(
qulonglong
n
,
int
base
= 10)
这是重载函数。
[static]
QString
QString::
number
(
double
n
,
char
format
= 'g',
int
precision
= 6)
Returns a string equivalent of the number n , formatted according to the specified format and precision 。见 自变量格式 了解细节。
不像 QLocale::toString (), this function does not honor the user's locale settings.
另请参阅 setNum () 和 QLocale::toString ().
前置字符串 str to the beginning of this string and returns a reference to this string.
范例:
QString x = "ship"; QString y = "air"; x.prepend(y); // x == "airship"
此函数重载 prepend ().
前置 len characters from the QChar array str to this string and returns a reference to this string.
该函数在 Qt 5.5 引入。
此函数重载 prepend ().
前置字符 ch 到此字符串。
此函数重载 prepend ().
Prepends the string reference str to the beginning of this string and returns a reference to this string.
该函数在 Qt 5.5 引入。
此函数重载 prepend ().
Prepends the Latin-1 string str 到此字符串。
此函数重载 prepend ().
前置字符串 str to this string. The const char pointer is converted to Unicode using the fromUtf8 () 函数。
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 prepend ().
前置字节数组 ba to this string. The byte array is converted to Unicode using the fromUtf8 () 函数。
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
This function is provided for STL compatibility, appending the given
other
string onto the end of this string. It is equivalent to
append(other)
.
另请参阅 append ().
这是重载函数。
Appends the given ch character onto the end of this string.
This function is provided for STL compatibility, prepending the given
other
string to the beginning of this string. It is equivalent to
prepend(other)
.
另请参阅 prepend ().
这是重载函数。
Prepends the given ch character to the beginning of this string.
返回 STL-style reverse iterator pointing to the first character in the string, in reverse order.
该函数在 Qt 5.6 引入。
另请参阅 begin (), crbegin (),和 rend ().
这是重载函数。
该函数在 Qt 5.6 引入。
移除 n characters from the string, starting at the given position index, and returns a reference to the string.
If the specified position index is within the string, but position + n is beyond the end of the string, the string is truncated at the specified position .
QString s = "Montreal"; s.remove(1, 4); // s == "Meal"
Removes every occurrence of the character ch in this string, and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString t = "Ali Baba"; t.remove(QChar('a'), Qt::CaseInsensitive); // t == "li Bb"
这如同
replace(ch, "", cs)
.
另请参阅 replace ().
Removes every occurrence of the given str string in this string, and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
这如同
replace(str, "", cs)
.
另请参阅 replace ().
Removes every occurrence of the regular expression rx in the string, and returns a reference to the string. For example:
QString r = "Telephone"; r.remove(QRegExp("[aeiou].")); // r == "The"
另请参阅 indexOf (), lastIndexOf (),和 replace ().
Removes every occurrence of the regular expression re in the string, and returns a reference to the string. For example:
QString r = "Telephone"; r.remove(QRegularExpression("[aeiou].")); // r == "The"
该函数在 Qt 5.0 引入。
另请参阅 indexOf (), lastIndexOf (),和 replace ().
返回 STL-style reverse iterator pointing to one past the last character in the string, in reverse order.
该函数在 Qt 5.6 引入。
另请参阅 end (), crend (),和 rbegin ().
这是重载函数。
该函数在 Qt 5.6 引入。
Returns a copy of this string repeated the specified number of times .
若 times is less than 1, an empty string is returned.
范例:
QString str("ab"); str.repeated(4); // returns "abababab"
该函数在 Qt 4.5 引入。
替换 n characters beginning at index position with the string after and returns a reference to this string.
注意: If the specified position index is within the string, but position + n goes outside the strings range, then n will be adjusted to stop at the end of the string.
范例:
QString x = "Say yes!"; QString y = "no"; x.replace(4, 3, y); // x == "Say no!"
此函数重载 replace ().
替换 n characters beginning at index position with the first size characters of the QChar array unicode and returns a reference to this string.
此函数重载 replace ().
替换 n characters beginning at index position with the character after and returns a reference to this string.
此函数重载 replace ().
Replaces every occurrence of the character before with the character after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
此函数重载 replace ().
Replaces each occurrence in this string of the first blen 字符的 before with the first alen 字符的 after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.5 引入。
此函数重载 replace ().
Replaces every occurrence of the string before with the string after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
注意: The text is not rescanned after a replacement.
该函数在 Qt 4.5 引入。
此函数重载 replace ().
Replaces every occurrence of the string before with the string after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
注意: The text is not rescanned after a replacement.
该函数在 Qt 4.5 引入。
此函数重载 replace ().
Replaces every occurrence of the string before with the string after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
注意: The text is not rescanned after a replacement.
该函数在 Qt 4.5 引入。
此函数重载 replace ().
Replaces every occurrence of the string before with the string after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
范例:
QString str = "colour behaviour flavour neighbour"; str.replace(QString("ou"), QString("o")); // str == "color behavior flavor neighbor"
注意: The replacement text is not rescanned after it is inserted.
范例:
QString equis = "xxxxxx"; equis.replace("xx", "x"); // equis == "xxx"
此函数重载 replace ().
Replaces every occurrence of the character ch in the string with after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
此函数重载 replace ().
Replaces every occurrence of the character c with the string after and returns a reference to this string.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
注意: The text is not rescanned after a replacement.
该函数在 Qt 4.5 引入。
此函数重载 replace ().
Replaces every occurrence of the regular expression rx in the string with after . Returns a reference to the string. For example:
QString s = "Banana"; s.replace(QRegExp("a[mn]"), "ox"); // s == "Boxoxa"
For regular expressions containing capturing parentheses , occurrences of \1 , \2 , ..., in after are replaced with rx .cap(1), cap(2), ...
QString t = "A <i>bon mot</i>."; t.replace(QRegExp("<i>([^<]*)</i>"), "\\emph{\\1}"); // t == "A \\emph{bon mot}."
另请参阅 indexOf (), lastIndexOf (), remove (),和 QRegExp::cap ().
此函数重载 replace ().
Replaces every occurrence of the regular expression re in the string with after . Returns a reference to the string. For example:
QString s = "Banana"; s.replace(QRegularExpression("a[mn]"), "ox"); // s == "Boxoxa"
For regular expressions containing capturing groups, occurrences of \1 , \2 , ..., in after are replaced with the string captured by the corresponding capturing group.
QString t = "A <i>bon mot</i>."; t.replace(QRegularExpression("<i>([^<]*)</i>"), "\\emph{\\1}"); // t == "A \\emph{bon mot}."
该函数在 Qt 5.0 引入。
另请参阅 indexOf (), lastIndexOf (), remove (), QRegularExpression ,和 QRegularExpressionMatch .
试图分配内存为至少 size characters. If you know in advance how large the string will be, you can call this function, and if you resize the string often you are likely to get better performance. If size is an underestimate, the worst that will happen is that the QString will be a bit slower.
The sole purpose of this function is to provide a means of fine tuning QString 's memory usage. In general, you will rarely ever need to call this function. If you want to change the size of the string, call resize ().
This function is useful for code that needs to build up a long string and wants to avoid repeated reallocation. In this example, we want to add to the string until some condition is
true
, and we're fairly sure that size is large enough to make a call to reserve() worthwhile:
QString result; int maxSize; bool condition; QChar nextChar; result.reserve(maxSize); while (condition) result.append(nextChar); result.squeeze();
另请参阅 squeeze () 和 capacity ().
Sets the size of the string to size 字符。
若 size is greater than the current size, the string is extended to make it size characters long with the extra characters added to the end. The new characters are uninitialized.
若 size is less than the current size, characters are removed from the end.
范例:
QString s = "Hello world"; s.resize(5); // s == "Hello" s.resize(8); // s == "Hello???" (where ? stands for any character)
If you want to append a certain number of identical characters to the string, use the resize (int, QChar ) overload.
If you want to expand the string so that it reaches a certain width and fill the new positions with a particular character, use the leftJustified () 函数:
若 size is negative, it is equivalent to passing zero.
QString r = "Hello"; r = r.leftJustified(10, ' '); // r == "Hello "
另请参阅 truncate () 和 reserve ().
这是重载函数。
不像 resize (int), this overload initializes the new characters to fillChar :
QString t = "Hello"; r.resize(t.size() + 10, 'X'); // t == "HelloXXXXXXXXXX"
该函数在 Qt 5.7 引入。
Returns a substring that contains the n rightmost characters of the string.
The entire string is returned if n is greater than or equal to size (), or less than zero.
QString x = "Pineapple"; QString y = x.right(5); // y == "apple"
另请参阅 left (), mid (),和 endsWith ().
Returns a string of size () width that contains the fill character followed by the string. For example:
QString s = "apple"; QString t = s.rightJustified(8, '.'); // t == "...apple"
若
truncate
is
false
和
size
() of the string is more than
width
, then the returned string is a copy of the string.
若 truncate is true and the size () of the string is more than width , then the resulting string is truncated at position width .
QString str = "Pineapple"; str = str.rightJustified(5, '.', true); // str == "Pinea"
另请参阅 leftJustified ().
Returns a substring reference to the n rightmost characters of the string.
若 n is greater than or equal to size (), or less than zero, a reference to the entire string is returned.
QString x = "Pineapple"; QStringRef y = x.rightRef(5); // y == "apple"
该函数在 Qt 4.4 引入。
另请参阅 right (), leftRef (), midRef (),和 endsWith ().
This function returns a section of the string.
This string is treated as a sequence of fields separated by the character, sep . The returned string consists of the fields from position start to position end inclusive. If end is not specified, all fields from position start to the end of the string are included. Fields are numbered 0, 1, 2, etc., counting from the left, and -1, -2, etc., counting from right to left.
flags argument can be used to affect some aspects of the function's behavior, e.g. whether to be case sensitive, whether to skip empty fields and how to deal with leading and trailing separators; see SectionFlags .
QString str; QString csv = "forename,middlename,surname,phone"; QString path = "/usr/local/bin/myapp"; // First field is empty QString::SectionFlag flag = QString::SectionSkipEmpty; str = csv.section(',', 2, 2); // str == "surname" str = path.section('/', 3, 4); // str == "bin/myapp" str = path.section('/', 3, 3, flag); // str == "myapp"
若 start or end is negative, we count fields from the right of the string, the right-most field being -1, the one from right-most field being -2, and so on.
str = csv.section(',', -3, -2); // str == "middlename,surname" str = path.section('/', -1); // str == "myapp"
另请参阅 split ().
此函数重载 section ().
QString str; QString data = "forename**middlename**surname**phone"; str = data.section("**", 2, 2); // str == "surname" str = data.section("**", -3, -2); // str == "middlename**surname"
另请参阅 split ().
此函数重载 section ().
This string is treated as a sequence of fields separated by the regular expression, reg .
QString line = "forename\tmiddlename surname \t \t phone"; QRegExp sep("\\s+"); str = line.section(sep, 2, 2); // str == "surname" str = line.section(sep, -3, -2); // str == "middlename surname"
警告: Using this QRegExp version is much more expensive than the overloaded string and character versions.
另请参阅 split () 和 simplified ().
此函数重载 section ().
This string is treated as a sequence of fields separated by the regular expression, re .
QString line = "forename\tmiddlename surname \t \t phone"; QRegularExpression sep("\\s+"); str = line.section(sep, 2, 2); // str == "surname" str = line.section(sep, -3, -2); // str == "middlename surname"
警告: Using this QRegularExpression version is much more expensive than the overloaded string and character versions.
该函数在 Qt 5.0 引入。
另请参阅 split () 和 simplified ().
Sets the string to the printed value of n 以指定 base , and returns a reference to the string.
The base is 10 by default and must be between 2 and 36. For bases other than 10, n is treated as an unsigned integer.
QString str; str.setNum(1234); // str == "1234"
格式始终使用 QLocale::C , i.e., English/UnitedStates. To get a localized string representation of a number, use QLocale::toString () with the appropriate locale.
这是重载函数。
这是重载函数。
这是重载函数。
这是重载函数。
这是重载函数。
这是重载函数。
这是重载函数。
这是重载函数。
Sets the string to the printed value of n , formatted according to the given format and precision , and returns a reference to the string.
格式始终使用 QLocale::C , i.e., English/UnitedStates. To get a localized string representation of a number, use QLocale::toString () with the appropriate locale.
这是重载函数。
Sets the string to the printed value of n , formatted according to the given format and precision , and returns a reference to the string.
format can be 'e', 'E', 'f', 'g' or 'G' (see 自变量格式 for an explanation of the formats).
格式始终使用 QLocale::C , i.e., English/UnitedStates. To get a localized string representation of a number, use QLocale::toString () with the appropriate locale.
Resets the QString to use the first size Unicode characters in the array unicode . The data in unicode is not copied. The caller must be able to guarantee that unicode will not be deleted or modified as long as the QString (or an unmodified copy of it) exists.
This function can be used instead of fromRawData () to re-use existings QString objects to save memory re-allocations.
该函数在 Qt 4.7 引入。
另请参阅 fromRawData ().
Resizes the string to size characters and copies unicode into the string.
若 unicode is 0, nothing is copied, but the string is still resized to size .
另请参阅 unicode () 和 setUtf16 ().
Resizes the string to size characters and copies unicode into the string.
若 unicode is 0, nothing is copied, but the string is still resized to size .
Note that unlike fromUtf16 (), this function does not consider BOMs and possibly differing byte ordering.
另请参阅 utf16 () 和 setUnicode ().
Returns a string that has whitespace removed from the start and the end, and that has each sequence of internal whitespace replaced with a single space.
Whitespace means any character for which
QChar::isSpace
() 返回
true
. This includes the ASCII characters '\t', '\n', '\v', '\f', '\r', and ' '.
范例:
QString str = " lots\t of\nwhitespace\r\n "; str = str.simplified(); // str == "lots of whitespace";
另请参阅 trimmed ().
Returns the number of characters in this string.
The last character in the string is at position size() - 1.
范例:
QString str = "World"; int n = str.size(); // n == 5 str.data()[0]; // returns 'W' str.data()[4]; // returns 'd'
Splits the string into substrings wherever sep occurs, and returns the list of those strings. If sep does not match anywhere in the string, split() returns a single-element list containing this string.
cs specifies whether sep should be matched case sensitively or case insensitively.
若 behavior is QString::SkipEmptyParts , empty entries don't appear in the result. By default, empty entries are kept.
范例:
QString str = "a,,b,c"; QStringList list1 = str.split(','); // list1: [ "a", "", "b", "c" ] QStringList list2 = str.split(',', QString::SkipEmptyParts); // list2: [ "a", "b", "c" ]
若 sep is empty, split() returns an empty string, followed by each of the string's characters, followed by another empty string:
QString str = "abc"; auto parts = str.split(""); // parts: {"", "a", "b", "c", ""}
To understand this behavior, recall that the empty string matches everywhere, so the above is qualitatively the same as:
QString str = "/a/b/c/"; auto parts = str.split('/'); // parts: {"", "a", "b", "c", ""}
另请参阅 QStringList::join () 和 section ().
这是重载函数。
这是重载函数。
Splits the string into substrings wherever the regular expression rx matches, and returns the list of those strings. If rx does not match anywhere in the string, split () returns a single-element list containing this string.
Here's an example where we extract the words in a sentence using one or more whitespace characters as the separator:
QString str; QStringList list; str = "Some text\n\twith strange whitespace."; list = str.split(QRegExp("\\s+")); // list: [ "Some", "text", "with", "strange", "whitespace." ]
Here's a similar example, but this time we use any sequence of non-word characters as the separator:
str = "This time, a normal English sentence."; list = str.split(QRegExp("\\W+"), QString::SkipEmptyParts); // list: [ "This", "time", "a", "normal", "English", "sentence" ]
Here's a third example where we use a zero-length assertion, \b (word boundary), to split the string into an alternating sequence of non-word and word tokens:
str = "Now: this sentence fragment."; list = str.split(QRegExp("\\b")); // list: [ "", "Now", ": ", "this", " ", "sentence", " ", "fragment", "." ]
另请参阅 QStringList::join () 和 section ().
这是重载函数。
Splits the string into substrings wherever the regular expression re matches, and returns the list of those strings. If re does not match anywhere in the string, split () returns a single-element list containing this string.
Here's an example where we extract the words in a sentence using one or more whitespace characters as the separator:
QString str; QStringList list; str = "Some text\n\twith strange whitespace."; list = str.split(QRegularExpression("\\s+")); // list: [ "Some", "text", "with", "strange", "whitespace." ]
Here's a similar example, but this time we use any sequence of non-word characters as the separator:
str = "This time, a normal English sentence."; list = str.split(QRegularExpression("\\W+"), QString::SkipEmptyParts); // list: [ "This", "time", "a", "normal", "English", "sentence" ]
Here's a third example where we use a zero-length assertion, \b (word boundary), to split the string into an alternating sequence of non-word and word tokens:
str = "Now: this sentence fragment."; list = str.split(QRegularExpression("\\b")); // list: [ "", "Now", ": ", "this", " ", "sentence", " ", "fragment", "." ]
该函数在 Qt 5.0 引入。
另请参阅 QStringList::join () 和 section ().
Splits the string into substring references wherever sep occurs, and returns the list of those strings.
见 QString::split () for how sep , behavior and cs interact to form the result.
注意: All references are valid as long this string is alive. Destroying this string will cause all references be dangling pointers.
该函数在 Qt 5.4 引入。
另请参阅 QStringRef and split ().
这是重载函数。
该函数在 Qt 5.4 引入。
这是重载函数。
Splits the string into substring references wherever the regular expression rx matches, and returns the list of those strings. If rx does not match anywhere in the string, splitRef () returns a single-element vector containing this string reference.
注意: All references are valid as long this string is alive. Destroying this string will cause all references be dangling pointers.
该函数在 Qt 5.4 引入。
另请参阅 QStringRef and split ().
这是重载函数。
Splits the string into substring references wherever the regular expression re matches, and returns the list of those strings. If re does not match anywhere in the string, splitRef () returns a single-element vector containing this string reference.
注意: All references are valid as long this string is alive. Destroying this string will cause all references be dangling pointers.
该函数在 Qt 5.4 引入。
另请参阅 split () 和 QStringRef .
Releases any memory not required to store the character data.
The sole purpose of this function is to provide a means of fine tuning QString 's memory usage. In general, you will rarely ever need to call this function.
另请参阅 reserve () 和 capacity ().
返回
true
if the string starts with
s
;否则返回
false
.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
QString str = "Bananas"; str.startsWith("Ban"); // returns true str.startsWith("Car"); // returns false
另请参阅 endsWith ().
这是重载函数。
返回
true
if the string starts with the string reference
s
;否则返回
false
.
若 cs is Qt::CaseSensitive (default), the search is case sensitive; otherwise the search is case insensitive.
该函数在 Qt 4.8 引入。
另请参阅 endsWith ().
此函数重载 startsWith ().
此函数重载 startsWith ().
返回
true
if the string starts with
c
;否则返回
false
.
Swaps string other with this string. This operation is very fast and never fails.
该函数在 Qt 4.8 引入。
Creates a CFString from a QString . The caller owns the CFString and is responsible for releasing it.
注意: this function is only available on OS X and iOS.
该函数在 Qt 5.2 引入。
Returns the case folded equivalent of the string. For most Unicode characters this is the same as toLower ().
Returns the string converted to a
double
值。
Returns 0.0 if the conversion fails.
If a conversion error occurs,
*
ok
被设为
false
;否则
*
ok
被设为
true
.
QString str = "1234.56"; double val = str.toDouble(); // val == 1234.56
警告: QString content may only contain valid numerical characters which includes the plus/minus sign, the characters g and e used in scientific notation, and the decimal point. Including the unit or additional characters leads to a conversion error.
bool ok; double d; d = QString( "1234.56e-02" ).toDouble(&ok); // ok == true, d == 12.3456
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toDouble ()
d = QString( "1234,56" ).toDouble(&ok); // ok == false d = QString( "1234.56" ).toDouble(&ok); // ok == true, d == 1234.56
For historical reasons, this function does not handle thousands group separators. If you need to convert such numbers, use QLocale::toDouble ().
d = QString( "1,234,567.89" ).toDouble(&ok); // ok == false d = QString( "1234567.89" ).toDouble(&ok); // ok == true
另请参阅 number (), QLocale::setDefault (), QLocale::toDouble (),和 trimmed ().
Returns the string converted to a
float
值。
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
. Returns 0.0 if the conversion fails.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toFloat ()
范例:
QString str1 = "1234.56"; str1.toFloat(); // returns 1234.56 bool ok; QString str2 = "R2D2"; str2.toFloat(&ok); // returns 0.0, sets ok to false
另请参阅 number (), toDouble (), toInt (),和 QLocale::toFloat ().
Converts a plain text string to an HTML string with HTML metacharacters
<
,
>
,
&
,和
"
replaced by HTML entities.
范例:
QString plain = "#include <QtCore>" QString html = plain.toHtmlEscaped(); // html == "#include <QtCore>"
该函数在 Qt 5.0 引入。
Returns the string converted to an
int
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toInt ()
范例:
QString str = "FF"; bool ok; int hex = str.toInt(&ok, 16); // hex == 255, ok == true int dec = str.toInt(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toUInt (), toDouble (),和 QLocale::toInt ().
Returns a Latin-1 representation of the string as a QByteArray .
The returned byte array is undefined if the string contains non-Latin1 characters. Those characters may be suppressed or replaced with a question mark.
另请参阅 fromLatin1 (), toUtf8 (), toLocal8Bit (),和 QTextCodec .
Returns the local 8-bit representation of the string as a QByteArray . The returned byte array is undefined if the string contains characters not supported by the local 8-bit encoding.
QTextCodec::codecForLocale () is used to perform the conversion from Unicode. If the locale encoding could not be determined, this function does the same as toLatin1 ().
If this string contains any characters that cannot be encoded in the locale, the returned byte array is undefined. Those characters may be suppressed or replaced by another.
另请参阅 fromLocal8Bit (), toLatin1 (), toUtf8 (),和 QTextCodec .
Returns the string converted to a
long
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toLongLong ()
范例:
QString str = "FF"; bool ok; long hex = str.toLong(&ok, 16); // hex == 255, ok == true long dec = str.toLong(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toULong (), toInt (),和 QLocale::toInt ().
Returns the string converted to a
long long
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toLongLong ()
范例:
QString str = "FF"; bool ok; qint64 hex = str.toLongLong(&ok, 16); // hex == 255, ok == true qint64 dec = str.toLongLong(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toULongLong (), toInt (),和 QLocale::toLongLong ().
Returns a lowercase copy of the string.
QString str = "The Qt PROJECT"; str = str.toLower(); // str == "the qt project"
The case conversion will always happen in the 'C' locale. For locale dependent case folding use QLocale::toLower ()
另请参阅 toUpper () 和 QLocale::toLower ().
Creates a NSString from a QString . The NSString is autoreleased.
注意: this function is only available on OS X and iOS.
该函数在 Qt 5.2 引入。
Returns the string converted to a
short
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toShort ()
范例:
QString str = "FF"; bool ok; short hex = str.toShort(&ok, 16); // hex == 255, ok == true short dec = str.toShort(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toUShort (), toInt (),和 QLocale::toShort ().
Returns a std::string object with the data contained in this QString . The Unicode data is converted into 8-bit characters using the toUtf8 () 函数。
This method is mostly useful to pass a QString to a function that accepts a std::string object.
另请参阅 toLatin1 (), toUtf8 (), toLocal8Bit (),和 QByteArray::toStdString ().
Returns a std::u16string object with the data contained in this QString . The Unicode data is the same as returned by the utf16 () 方法。
该函数在 Qt 5.5 引入。
另请参阅 utf16 (), toStdWString (),和 toStdU32String ().
Returns a std::u32string object with the data contained in this QString . The Unicode data is the same as returned by the toUcs4 () 方法。
该函数在 Qt 5.5 引入。
另请参阅 toUcs4 (), toStdWString (),和 toStdU16String ().
返回 std::wstring object with the data contained in this QString 。 std::wstring is encoded in utf16 on platforms where wchar_t is 2 bytes wide (e.g. windows) and in ucs4 on platforms where wchar_t is 4 bytes wide (most Unix systems).
This method is mostly useful to pass a QString to a function that accepts a std::wstring 对象。
另请参阅 utf16 (), toLatin1 (), toUtf8 (), toLocal8Bit (), toStdU16String (),和 toStdU32String ().
Returns the string converted to an
无符号 int
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toUInt ()
范例:
QString str = "FF"; bool ok; uint hex = str.toUInt(&ok, 16); // hex == 255, ok == true uint dec = str.toUInt(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toInt (),和 QLocale::toUInt ().
Returns the string converted to an
unsigned long
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toULongLong ()
范例:
QString str = "FF"; bool ok; ulong hex = str.toULong(&ok, 16); // hex == 255, ok == true ulong dec = str.toULong(&ok, 10); // dec == 0, ok == false
另请参阅 number () 和 QLocale::toUInt ().
Returns the string converted to an
unsigned long long
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toULongLong ()
范例:
QString str = "FF"; bool ok; quint64 hex = str.toULongLong(&ok, 16); // hex == 255, ok == true quint64 dec = str.toULongLong(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toLongLong (),和 QLocale::toULongLong ().
Returns the string converted to an
unsigned short
using base
base
, which is 10 by default and must be between 2 and 36, or 0. Returns 0 if the conversion fails.
If a conversion error occurs, *
ok
被设为
false
; otherwise *
ok
被设为
true
.
若 base is 0, the C language convention is used: If the string begins with "0x", base 16 is used; if the string begins with "0", base 8 is used; otherwise, base 10 is used.
The string conversion will always happen in the 'C' locale. For locale dependent conversion use QLocale::toUShort ()
范例:
QString str = "FF"; bool ok; ushort hex = str.toUShort(&ok, 16); // hex == 255, ok == true ushort dec = str.toUShort(&ok, 10); // dec == 0, ok == false
另请参阅 number (), toShort (),和 QLocale::toUShort ().
Returns a UCS-4/UTF-32 representation of the string as a QVector <uint>.
UCS-4 is a Unicode codec and therefore it is lossless. All characters from this string will be encoded in UCS-4. Any invalid sequence of code units in this string is replaced by the Unicode's replacement character (
QChar::ReplacementCharacter
, which corresponds to
U+FFFD
).
The returned vector is not NUL terminated.
该函数在 Qt 4.2 引入。
另请参阅 fromUtf8 (), toUtf8 (), toLatin1 (), toLocal8Bit (), QTextCodec , fromUcs4 (),和 toWCharArray ().
Returns an uppercase copy of the string.
QString str = "TeXt"; str = str.toUpper(); // str == "TEXT"
The case conversion will always happen in the 'C' locale. For locale dependent case folding use QLocale::toUpper ()
另请参阅 toLower () 和 QLocale::toLower ().
Returns a UTF-8 representation of the string as a QByteArray .
UTF-8 is a Unicode codec and can represent all characters in a Unicode string like QString .
另请参阅 fromUtf8 (), toLatin1 (), toLocal8Bit (),和 QTextCodec .
Fills the array with the data contained in this QString object. The array is encoded in UTF-16 on platforms where wchar_t is 2 bytes wide (e.g. windows) and in UCS-4 on platforms where wchar_t is 4 bytes wide (most Unix systems).
array has to be allocated by the caller and contain enough space to hold the complete string (allocating the array with the same length as the string is always sufficient).
This function returns the actual length of the string in array .
注意: This function does not append a null character to the array.
该函数在 Qt 4.2 引入。
另请参阅 utf16 (), toUcs4 (), toLatin1 (), toUtf8 (), toLocal8Bit (),和 toStdWString ().
Returns a string that has whitespace removed from the start and the end.
Whitespace means any character for which
QChar::isSpace
() 返回
true
. This includes the ASCII characters '\t', '\n', '\v', '\f', '\r', and ' '.
范例:
QString str = " lots\t of\nwhitespace\r\n "; str = str.trimmed(); // str == "lots\t of\nwhitespace"
不像 simplified (), trimmed() leaves internal whitespace alone.
另请参阅 simplified ().
Truncates the string at the given position index.
If the specified position index is beyond the end of the string, nothing happens.
范例:
QString str = "Vladivostok"; str.truncate(4); // str == "Vlad"
若 position is negative, it is equivalent to passing zero.
另请参阅 chop (), resize (), left (),和 QStringRef::truncate ().
Returns a Unicode representation of the string. The result remains valid until the string is modified.
注意: The returned string may not be '\0'-terminated. Use size () to determine the length of the array.
另请参阅 setUnicode (), utf16 (),和 fromRawData ().
返回 QString as a '\0'-terminated array of unsigned shorts. The result remains valid until the string is modified.
The returned string is in host byte order.
另请参阅 setUtf16 () 和 unicode ().
[static]
QString
QString::
vasprintf
(const
char
*
cformat
,
va_list
ap
)
Equivalent method to asprintf (), but takes a va_list ap instead a list of variable arguments. See the asprintf () documentation for an explanation of cformat .
This method does not call the va_end macro, the caller is responsible to call va_end on ap .
该函数在 Qt 5.5 引入。
另请参阅 asprintf ().
返回
true
if this string is not equal to parameter string
other
. Otherwise returns
false
.
This function overloads operator!=().
此函数重载 operator!= ().
other const char pointer is converted to a QString 使用 fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator!= ().
other byte array is converted to a QString 使用 fromUtf8 () function. If any NUL characters ('\0') are embedded in the byte array, they will be included in the transformation.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
追加字符串 other onto the end of this string and returns a reference to this string.
范例:
QString x = "free"; QString y = "dom"; x += y; // x == "freedom"
This operation is typically very fast ( 常量时间 ),因为 QString preallocates extra space at the end of the string data so it can grow without reallocating the entire string each time.
此函数重载 operator+= ().
追加字符 ch to the string.
此函数重载 operator+= ().
Appends the string section referenced by str 到此字符串。
此函数重载 operator+= ().
追加 Latin-1 字符串 str 到此字符串。
此函数重载 operator+= ().
追加字符串 str to this string. The const char pointer is converted to Unicode using the fromUtf8 () 函数。
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator+= ().
追加字节数组 ba to this string. The byte array is converted to Unicode using the fromUtf8 () function. If any NUL characters ('\0') are embedded in the ba byte array, they will be included in the transformation.
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator+= ().
追加字符 ch to this string. Note that the character is converted to Unicode using the fromLatin1 () function, unlike other 8-bit functions that operate on UTF-8 data.
可以禁用此函数通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
This function overloads operator<().
返回
true
if this string is lexically less than the parameter string called
other
;否则返回
false
.
返回
true
if this string is lexically less than string
other
. Otherwise returns
false
.
此函数重载 operator< ().
other const char pointer is converted to a QString 使用 fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator< ().
other byte array is converted to a QString 使用 fromUtf8 () function. If any NUL characters ('\0') are embedded in the byte array, they will be included in the transformation.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
返回
true
if this string is lexically less than or equal to parameter string
other
. Otherwise returns
false
.
This function overloads operator<=().
此函数重载 operator<= ().
other const char pointer is converted to a QString 使用 fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator<= ().
other byte array is converted to a QString 使用 fromUtf8 () function. If any NUL characters ('\0') are embedded in the byte array, they will be included in the transformation.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
赋值 other to this string and returns a reference to this string.
此函数重载 operator= ().
Sets the string to contain the single character ch .
此函数重载 operator= ().
Assigns the Latin-1 string str 到此字符串。
移动赋值 other 到此 QString 实例。
该函数在 Qt 5.2 引入。
此函数重载 operator= ().
赋值 str to this string. The const char pointer is converted to Unicode using the fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
or
QT_RESTRICTED_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator= ().
赋值 ba to this string. The byte array is converted to Unicode using the fromUtf8 () function. This function stops conversion at the first NUL character found, or the end of the ba byte array.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator= ().
Assigns character ch to this string. Note that the character is converted to Unicode using the fromLatin1 () function, unlike other 8-bit functions that operate on UTF-8 data.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
This function overloads operator==().
返回
true
if this string is equal to
other
;否则返回
false
.
此函数重载 operator== ().
other const char pointer is converted to a QString 使用 fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator== ().
other byte array is converted to a QString 使用 fromUtf8 () function. This function stops conversion at the first NUL character found, or the end of the byte array.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
返回
true
if this string is lexically equal to the parameter string
other
. Otherwise returns
false
.
This function overloads operator>().
返回
true
if this string is lexically greater than the parameter string
other
;否则返回
false
.
此函数重载 operator> ().
other const char pointer is converted to a QString 使用 fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator> ().
other byte array is converted to a QString 使用 fromUtf8 () function. If any NUL characters ('\0') are embedded in the byte array, they will be included in the transformation.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
返回
true
if this string is lexically greater than or equal to parameter string
other
. Otherwise returns
false
.
This function overloads operator>=().
此函数重载 operator>= ().
other const char pointer is converted to a QString 使用 fromUtf8 () 函数。
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
此函数重载 operator>= ().
other byte array is converted to a QString 使用 fromUtf8 () function. If any NUL characters ('\0') are embedded in the byte array, they will be included in the transformation.
可以禁用此运算符通过定义
QT_NO_CAST_FROM_ASCII
when you compile your applications. This can be useful if you want to ensure that all user-visible strings go through
QObject::tr
(), for example.
Returns the character at the specified position in the string as a modifiable reference.
范例:
QString str; if (str[0] == QChar('?')) str[0] = QChar('_');
The return value is of type QCharRef, a helper class for QString . When you get an object of type QCharRef, you can use it as if it were a QChar &. If you assign to it, the assignment will apply to the character in the QString from which you got the reference.
另请参阅 at ().
此函数重载 operator[] ().
相当于
at(position)
.
此函数重载 operator[] ().
此函数重载 operator[] ().
Returns the character at the specified position in the string as a modifiable reference.
返回
true
若字符串
s1
不等于字符串
s2
;否则返回
false
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings with localeAwareCompare().
返回
true
if
s1
不等于
s2
;否则返回
false
.
For
s1
!= 0, this is equivalent to
compare(
s1
,
s2
) != 0
. Note that no string is equal to
s1
being 0.
另请参阅 QString::compare ().
Returns a string which is the result of concatenating s1 and s2 .
Returns a string which is the result of concatenating s1 and s2 ( s2 is converted to Unicode using the QString::fromUtf8 () 函数)。
另请参阅 QString::fromUtf8 ().
Returns a string which is the result of concatenating s1 and s2 ( s1 is converted to Unicode using the QString::fromUtf8 () 函数)。
另请参阅 QString::fromUtf8 ().
Returns a string which is the result of concatenating the string s and the character ch .
Returns a string which is the result of concatenating the character ch and the string s .
返回
true
if
s1
is lexically less than
s2
;否则返回
false
。对于
s1
!= 0, this is equivalent to
compare(s1, s2) < 0
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings using the QString::localeAwareCompare () 函数。
另请参阅 QString::compare ().
写入给定 string 到指定 stream .
另请参阅 序列化 Qt 数据类型 .
返回
true
若字符串
s1
词法上小于等于字符串
s2
;否则返回
false
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings with localeAwareCompare().
返回
true
if
s1
is lexically less than or equal to
s2
;否则返回
false
。对于
s1
!= 0, this is equivalent to
compare(s1, s2) <= 0
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings with QString::localeAwareCompare ().
另请参阅 QString::compare ().
此函数重载 operator== ().
返回
true
if
s1
等于
s2
;否则返回
false
. Note that no string is equal to
s1
being 0.
相当于
s1 != 0 && compare(s1, s2) == 0
.
另请参阅 QString::compare ().
返回
true
若字符串
s1
词法上大于字符串
s2
;否则返回
false
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings with localeAwareCompare().
返回
true
if
s1
is lexically greater than
s2
;否则返回
false
. Equivalent to
compare(s1, s2) > 0
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings using the QString::localeAwareCompare () 函数。
另请参阅 QString::compare ().
返回
true
若字符串
s1
词法上大于等于字符串
s2
;否则返回
false
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings with localeAwareCompare().
返回
true
if
s1
is lexically greater than or equal to
s2
;否则返回
false
。对于
s1
!= 0, this is equivalent to
compare(s1, s2) >= 0
.
The comparison is based exclusively on the numeric Unicode values of the characters and is very fast, but is not what a human would expect. Consider sorting user-interface strings using the QString::localeAwareCompare () 函数。
Reads a string from the specified stream 进给定 string .
另请参阅 序列化 Qt 数据类型 .
宏生成数据为 QString 从字符串文字 str 在编译时。创建 QString from it is free in this case, and the generated string data is stored in the read-only segment of the compiled object file.
If you have code that looks like this:
// hasAttribute takes a QString argument if (node.hasAttribute("http-contents-length")) //...
then a temporary
QString
will be created to be passed as the
hasAttribute
function parameter. This can be quite expensive, as it involves a memory allocation and the copy/conversion of the data into
QString
's internal encoding.
This cost can be avoided by using QStringLiteral instead:
if (node.hasAttribute(QStringLiteral(u"http-contents-length"))) //...
In this case, QString 's internal data will be generated at compile time; no conversion or allocation will occur at runtime.
Using QStringLiteral instead of a double quoted plain C++ string literal can significantly speed up creation of QString 实例从编译时的已知数据。
注意: QLatin1String can still be more efficient than QStringLiteral when the string is passed to a function that has an overload taking QLatin1String and this overload avoids conversion to QString . For instance, QString::operator==() can compare to a QLatin1String 直接:
if (attribute.name() == QLatin1String("http-contents-length")) //...
注意:
Some compilers have bugs encoding strings containing characters outside the US-ASCII character set. Make sure you prefix your string with
u
in those cases. It is optional otherwise.
另请参阅 QByteArrayLiteral .
Disables automatic conversions from 8-bit strings (char *) to unicode QStrings
另请参阅 QT_NO_CAST_TO_ASCII , QT_RESTRICTED_CAST_FROM_ASCII ,和 QT_NO_CAST_FROM_BYTEARRAY .
disables automatic conversion from QString to 8-bit strings (char *)
另请参阅 QT_NO_CAST_FROM_ASCII , QT_RESTRICTED_CAST_FROM_ASCII ,和 QT_NO_CAST_FROM_BYTEARRAY .
Defining this macro disables most automatic conversions from source literals and 8-bit data to unicode QStrings, but allows the use of the
QChar(char)
and
QString(const char (&ch)[N]
constructors, and the
QString::operator=(const char (&ch)[N])
assignment operator giving most of the type-safety benefits of
QT_NO_CAST_FROM_ASCII
but does not require user code to wrap character and string literals with
QLatin1Char
,
QLatin1String
or similar.
Using this macro together with source strings outside the 7-bit range, non-literals, or literals with embedded NUL characters is undefined.
另请参阅 QT_NO_CAST_FROM_ASCII and QT_NO_CAST_TO_ASCII .