• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Qt中的QString,QByteArray,Qchar, char*

            Posted on 2011-06-01 21:42 RTY 閱讀(1328) 評論(0)  編輯 收藏 引用 所屬分類: Qt轉載隨筆
            先要說的是QString。
                  之所以把QString單獨拿出來,是因為string是很常用的一個數據結構,甚至在很多語言中,比如JavaScript,都是把string作為一種同int等一樣的基本數據結構來實現的。
                  每一個GUI程序都需要string,這些string可以用在界面上的提示語,也可以用作一般的數據結構。C++語言提供了兩種字符串的實現:C風格的 字符串,以'\0‘結尾;std::string,即標準模版庫中的類。Qt則提供了自己的字符串實現:QString。QString以16位 Uniode進行編碼。我們平常用的ASCII等一些編碼集都作為Unicode編碼的子集提供。關于編碼的問題,我們會到以后的時候再詳細說明。
            在使用QString的時候,我們不需要擔心內存分配以及關于'\0'結尾的這些注意事項。QString會把這些問題解決。通常,你可以把 QString看作是一個QChar的向量。另外,與C風格的字符串不同,QString中間是可以包含'\0'符號的,而length()函數則會返回 整個字符串的長度,而不僅僅是從開始到'\0'的長度。
                 同Java的String類類似,QString也重載的+和+=運算符。這兩個運算符可以把兩個字符串連接到一起,正像Java里面的操作一樣。QString可以自動的對占用內存空間進行擴充,這種連接操作是恨迅速的。下面是這兩個操作符的使用:
            QString str = "User: "  ;  
            str += userName + "\n"  ; 
            QString的append()函數則提供了類似的操作,例如:
            str = "User: "  ;  
            str.append(userName);  
            str.append("\n"  ); 
            C語言中有printf()函數作為格式化輸出,QString則提供了一個sprintf()函數實現了相同的功能:
            str.sprintf("%s %.1f%%"  , "perfect competition"  , 100.0); 
            這句代碼將輸出:perfect competition 100.0%,同C語言的printf()一樣。不過前面我們也見到了Qt提供的另一種格式化字符串輸出的函數arg():
            str = QString("%1 %2 (%3s-%4s)"  )  
                  .arg("permissive"  ).arg("society"  ).arg(1950).arg(1970); 
            這段代碼中,%1, %2, %3, %4作為占位符,將被后面的arg()函數中的內容依次替換,比如%1將被替換成permissive,%2將被替換成society,%3將被替換成 1950,%4將被替換曾1970,最后,這句代碼輸出為:permissive society (1950s-1970s). arg()函數比起sprintf()來是類型安全的,同時它也接受多種的數據類型作為參數,因此建議使用arg()函數而不是傳統的 sprintf()。
            使用static的函數number()可以把數字轉換成字符串。例如:
            QString str = QString::number(54.3); 
            你也可以使用非static函數setNum()來實現相同的目的:
            QString str;  
            str.setNum(54.3); 
            而一系列的to函數則可以將字符串轉換成其他基本類型,例如toInt(), toDouble(), toLong()等。這些函數都接受一個bool指針作為參數,函數結束之后將根據是否轉換成功設置為true或者false:
            bool    ok;  
            double    d = str.toDouble(&ok);  
            if   (ok)  
            {  
                // do something...   
            } else    {  
                // do something...   
            對于QString,Qt提供了很多操作函數,例如,使用mid()函數截取子串:
            QString x   = "Nine pineapples"  ;  
            QString y   = x  .mid(5, 4);            // y   == "pine"  
            QString z   = x  .mid(5);               // z   == "pineapples" 
            mid()函數接受兩個參數,第一個是起始位置,第二個是取串的長度。如果省略第二個參數,則會從起始位置截取到末尾。正如上面的例子顯示的那樣。
            函數left()和rigt()類似,都接受一個int類型的參數n,都是對字符串進行截取。不同之處在于,left()函數從左側截取n個字符,而right()從右側開始截取。下面是left()的例子:
            QString x = "Pineapple"  ;  
            QString y = x.left(4);      // y == "Pine"   
            函數indexOf()返回字符串的位置,如:
            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   
            函數startsWith()和endsWith()可以檢測字符串是不是以某個特定的串開始或結尾,例如:
            if    (url.startsWith("http:"  ) && url.endsWith(".png"  ))  
            {  
            這段代碼等價于
            if    (url.left(5) == "http:"   && url.right(4) == ".png"  )  
            {  
            不過,前者要比后者更加清楚簡潔,并且性能也更快一些。
            QString還提供了replace()函數供實現字符串的替換功能;trimmed()函數去除字符串兩側的空白字符(注意,空白字符包括空 格、Tab以及換行符,而不僅僅是空格);toLower()和toUpper()函數會將字符串轉換成小寫大寫字符串;remove()和 insert()函數提供了刪除和插入字符串的能力;simplified()函數可以將串中的所有連續的空白字符替換成一個,并且把兩端的空白字符去 除,例如"   \t   ”會返回一個空格" "。
            將const char *類型的C風格字符串轉換成QString也是很常見的需求,簡單來說,QString的+=即可完成這個功能:
            str += " (1870)"  ; 
            這里,我們將const char * 類型的字符串" (1870)"轉換成為QString類型。如果需要顯式的轉換,可以使用QString的強制轉換操作,或者是使用函數fromAscii()等。為了 將QString類型轉成const char *字符串,需要進行兩步操作,一是使用toAscii()獲得一個QByteArray類型對象,然后調用它的data()或者constData()函 數,例如:
            printf("User: %s\n"  , str.toAscii().data()); 
            為了方便使用,Qt提供了一個宏qPrintable(),這個宏等價于toAscii().constData(),例如:
            printf("User: %s\n"  , qPrintable(str)); 
            我們調用QByteArray類上面的data()或者constData()函數,將獲得QByteArray內部的一個const char*類型的字符串,因此,我們不需要擔心內存泄漏等的問題,Qt會替我們管理好內存。不過這也暗示我們,注意不要使用這個指針太長時間,因為如果 QByteArray被delete,那么這個指針也就成為野指針了。如果這個QByteArray對象沒有被放在一個變量中,那么當語句結束 后,QbyteArray對象就會被delete,這個指針也就被delete 了。
            接下來說說QString和QByteArray之間的轉換  ,這里說兩種,都是從網上搜到的。
            第一種,數據流的方式,這里只說從QByteArray轉向QString。
            QByteArray encodedString = "xxx";
            QTextCodec *codec = QTextCodec::codecForName("KOI8-R");
            QString string = codec->toUnicode(encodedString);
            [另外]
            char ch_str[10] = "搜索";
            QString str = QString::fromLocal8Bit(ch_str);
            第二種,常用的,網上看到的。
            //常用參數類型:char *字符串, QByteArray字符數組, QString字符串
            //需要轉換:char * ---轉---  QByteArray  ---需要調用QByteArray類的構造函數
            char*     --------------QByteArray(const char*)-----------> QByteArray
            char* str;
            QByteArray byte(str);
            char*     --------------QString(const char*)-------------->QString
            char* str;
            QString string(str);
            QByteArray   -------------data()-------------------->char*
            QByteArray byte;
            char* str = byte.data();
            QByteArray  ------------QString()------------------->QString
            QByteArray byte;
            QString string(byte);
            QString  --------------toAscii()--------------------> QByteArray
            QString string;
            QByteArray byte = string.toAscii();
            QString -------------qPrintable()------------------>char*
            QString string;
            char* str = qPrintable(string);
            或QString --------toLatin1()------QByteArray----------data()--------->char*
            QString string;
            QByteArray ba=string.toLatin1();
            const char* str = ba.data();
            国产精品嫩草影院久久| 很黄很污的网站久久mimi色| 777午夜精品久久av蜜臀| 久久久久久久久66精品片| 久久久亚洲欧洲日产国码是AV| 亚洲欧美成人综合久久久| 国内精品久久久久| 亚洲国产综合久久天堂| 99久久久精品免费观看国产| 国产精品永久久久久久久久久| 久久久久亚洲AV无码观看| 国产精品久久久福利| 亚洲精品国产第一综合99久久| 日韩精品久久无码中文字幕| 久久精品人妻一区二区三区| 香蕉久久夜色精品升级完成| 欧美性猛交xxxx免费看久久久| 国产精品无码久久综合| yy6080久久| 久久久久成人精品无码| 人妻少妇久久中文字幕| 亚洲国产婷婷香蕉久久久久久| 久久久综合九色合综国产| 伊人久久大香线焦AV综合影院| 久久久WWW成人免费毛片| 久久精品国产免费| 国产一区二区三区久久| 国产情侣久久久久aⅴ免费| 一本久久a久久精品vr综合| 日韩AV毛片精品久久久| 久久久久久国产精品无码下载| 精品国产福利久久久| 国产精品久久毛片完整版| 久久精品中文騷妇女内射| 中文字幕久久久久人妻| 东方aⅴ免费观看久久av| 中文字幕乱码人妻无码久久| 无码AV中文字幕久久专区| 亚洲综合熟女久久久30p| 97精品伊人久久久大香线蕉| 久久人人妻人人爽人人爽|