成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

當C++遇到iOS應用開發:字符串處理篇

移動開發 iOS
X-Code提供了自動配對“[]”號的功能,但一閱讀起源代碼后依舊讓人心生厭惡。給人一種“強迫打字綜合癥”的感覺。所以我在NSMutableString基礎上用C++進行了封裝,特別是對于一些常用方法的使用,在使用時會非常方便,與C#沒太大差別。

在 Object-c中,字符串處理通常使用NSString,NSMutableString這兩個類,前者用于定長字符串,后者用于可變長度字符串的操 作。盡量其提供的方法很豐富,但一用起來后就讓人感到很難受,比如其超長的方法名稱(如 stringByReplacingPercentEscapesUsingEncoding),再加上嵌套“[]”式的調用方式,讓人很快就會產生" []"匹配綜合癥。

即使X Code提供了自動配對“[]”號的功能,但一閱讀起源代碼后依舊讓人心生厭惡。給人一種“強迫打字綜合癥”的感覺。所以我在NSMutableString基礎上用C++進行了封裝,特別是對于一些常用方法的使用,在使用時會非常方便,與C#沒太大差別。

首先看一下String類的源碼(說明:因為C++中有std::string這個類,為了與其區別,這里使用了首字母大寫)。

  1. #import "RegexKitLite.h" 
  2. #define RELEASE_SAFELY(__POINTER) { [__POINTER release]; __POINTER = nil; } 
  3. class String { 
  4. private
  5. NSMutableString *temp; 
  6. static inline NSMutableString* ToMutableString(NSString *str){ 
  7. return [[NSMutableString stringWithString:(NSString *)str] autorelease]; 
  8. public : 
  9. String(){ 
  10. temp = ToMutableString(@""); 
  11. String(NSString *str){ 
  12. temp = ToMutableString(str); 
  13. String(int value){ 
  14. temp = ToMutableString([NSString stringWithFormat:@"%d", value]); 
  15. String(float value){ 
  16. temp = ToMutableString([NSString stringWithFormat:@"%f", value]); 
  17. String(std::string str){ 
  18. temp = ToMutableString(toNSString(str)); 
  19. String(const char* str){ 
  20. temp = ToMutableString(toNSString(str)); 
  21. ~String(){ 
  22. RELEASE_SAFELY(temp); 
  23. NSString * toString(){ 
  24. return temp; 
  25. const std::string toStdString(){ 
  26. return [temp UTF8String]; 
  27. NSString * toLower(){ 
  28. return [temp lowercaseString]; 
  29. NSString* toUpper(){ 
  30. return [temp uppercaseString]; 
  31. int length(){ 
  32. return temp.length; 
  33. bool contains(NSString *search){ 
  34. return [temp rangeOfString:search].location != NSNotFound; 
  35. //不考慮大小寫 
  36. static BOOL stringEquals(NSString* str1, NSString* str2) 
  37. if ( str1 == nil || str2 == nil ) { 
  38. return NO; 
  39. return [str1 compare:str2 options:NSCaseInsensitiveSearch] == NSOrderedSame; 
  40. //區分大小寫 
  41. static BOOL caseEquals(NSString* str1, NSString* str2) 
  42. return (str1 == nil || str2 == nil) ? NO : [str1 isEqualToString:str2]; 
  43. bool operator==( NSString *str) 
  44. return caseEquals(this->toString(), str); 
  45. bool operator==( String *str) 
  46. return caseEquals(this->toString(), str->toString()); 
  47. //區分大小寫 
  48. BOOL startWith(NSString *prefix){ 
  49. if ( temp != nil && prefix != nil ){ 
  50. if ( prefix.length > temp.length ) { 
  51. return NO; 
  52. if ([temp hasPrefix:prefix]){ 
  53. return YES; 
  54. return NO; 
  55. //區分大小寫 
  56. BOOL endWith(NSString* suffix){ 
  57. if ( temp != nil && suffix != nil ){ 
  58. if ( [suffix length] > [temp length] ) { 
  59. return NO; 
  60. if ([temp hasSuffix:suffix]){ 
  61. return YES; 
  62. return NO; 
  63. String& operator=( NSString *str) 
  64. temp = ToMutableString(str); 
  65. return (*this); 
  66. String& operator=( std::string str) 
  67. temp = ToMutableString(toNSString(str)); 
  68. return (*this); 
  69. String& operator=( Json::Value value) 
  70. temp = ToMutableString(toNSString(value.asString())); 
  71. return (*this); 
  72. //不區別大小寫 
  73. BOOL isURL(){ 
  74. if ( [temp length] > 6 ) { 
  75. NSString* prefix = [temp substringToIndex:6]; 
  76. if (stringEquals(prefix, @"http:/") || stringEquals(prefix, @"https:") ) { 
  77. return YES; 
  78. else if (stringEquals(prefix, @"local:")){ 
  79. return YES; 
  80. if (startWith(@"/")){ 
  81. return YES; 
  82. return NO; 
  83. int toInt(){ 
  84. return [temp intValue]; 
  85. int toFloat(){ 
  86. return [temp floatValue]; 
  87. NSDate* toDate(NSString* fmt){ 
  88. return stringToDate(temp, fmt); 
  89. NSArray* split(NSString *schar){ 
  90. return [temp componentsSeparatedByString:schar]; 
  91. String& trim(){ 
  92. temp = ToMutableString([temp stringByTrimmingCharactersInSet:                                                          [NSCharacterSet whitespaceAndNewlineCharacterSet]]); 
  93. return (*this); 
  94. String& append(NSString *appstr){ 
  95. [temp appendString:appstr]; 
  96. return *this
  97. BOOL isEmpty(){ 
  98. return temp == nil || [temp length] == 0; 
  99. String& appendFormat(NSString* formatStr, ...){ 
  100. va_list arglist; 
  101. va_start(arglist, formatStr); 
  102. id statement = [[NSString alloc] initWithFormat:formatStr arguments:arglist]; 
  103. va_end(arglist); 
  104. [temp appendString:statement]; 
  105. [statement release]; 
  106. return *this
  107. String& replace(NSString *oldStr, NSString *newStr){ 
  108. [temp replaceOccurrencesOfString:oldStr 
  109. withString:newStr 
  110. options:0 range:NSMakeRange(0, [temp length])]; 
  111. return *this
  112. String& regexReplace(NSString *regex, NSString *newStr){ 
  113. NSString *tempstr = temp; 
  114. temp = ToMutableString([tempstr stringByReplacingOccurrencesOfRegex:regex withString:newStr]); 
  115. return *this
  116. NSArray* regexMatchs(NSString *regex){ 
  117. return [temp componentsMatchedByRegex:regex]; 
  118. NSArray* regexMatchs(NSString *regex, int capture){ 
  119. return [temp componentsMatchedByRegex:regex capture:capture]; 
  120. BOOL regexIsMatch(NSString *regex){ 
  121. return [temp isMatchedByRegex:regex]; 
  122. NSString * encodeUrl(){ 
  123. NSString *resultStr = temp; 
  124. CFStringRef originalString = (CFStringRef) temp; 
  125. CFStringRef leaveUnescaped = CFSTR(" "); 
  126. CFStringRef forceEscaped = CFSTR("!*'();:@&=+$,/?%#[]"); 
  127. CFStringRef escapedStr; 
  128. escapedStr = CFURLCreateStringByAddingPercentEscapes(kCFAllocatorDefault, 
  129. originalString, 
  130. leaveUnescaped, 
  131. forceEscaped, 
  132. kCFStringEncodingUTF8); 
  133. if(escapedStr) 
  134. NSMutableString *mutableStr = [NSMutableString stringWithString:(NSString *)escapedStr]; 
  135. CFRelease(escapedStr); 
  136. if (!mutableStr || [mutableStr isKindOfClass:[NSNull class]] || mutableStr.length <= 0) { 
  137. return resultStr; 
  138. // replace spaces with plusses 
  139. [mutableStr replaceOccurrencesOfString:@" " 
  140. withString:@"%20" 
  141. options:0 
  142. range:NSMakeRange(0, [mutableStr length])]; 
  143. resultStr = mutableStr; 
  144. return resultStr; 
  145. NSString * decodeUrl(){ 
  146. return [temp stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; 
  147. NSString * toGBK(){ 
  148. NSStringEncoding enc = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000); 
  149. NSData *data = [temp dataUsingEncoding:NSUTF8StringEncoding]; 
  150. return [[[NSString alloc] initWithData:data encoding:enc] autorelease]; 
  151. NSString * toUTF8(){ 
  152. return [DZUtils urlEncode:temp stringEncode:NSUTF8StringEncoding]; 
  153. NSData * toNSData(){ 
  154. return [temp dataUsingEncoding:NSUTF8StringEncoding]; 
  155. NSString* subString(int start/*start from 0*/int count){ 
  156. if(start + count <= temp.length) 
  157. return [temp substringWithRange:NSMakeRange(start, count)]; 
  158. return nil; 
  159. NSString* subString(int count){ 
  160. if(count <= temp.length) 
  161. return [temp substringToIndex: count]; 
  162. return nil; 
  163. static NSDate* stringToDate(NSString * string,  NSString* fmt){ 
  164. NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; 
  165. [formatter setTimeZone:[NSTimeZone defaultTimeZone]]; 
  166. NSString* format = fmt == nil ? @"yyyy-MM-dd'T'HH:mm:ss'Z'" : fmt; 
  167. [formatter setDateFormat:format]; 
  168. NSDate *date = [formatter dateFromString:string]; 
  169. [formatter release]; 
  170. return date; 
  171. static NSString* dateToString(NSDate* date, NSString* fmt){ 
  172. NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; 
  173. [formatter setTimeZone:[NSTimeZone defaultTimeZone]]; 
  174. NSString* format = fmt == nil ? @"yyyy-MM-dd'T'HH:mm:ss'Z'" : fmt; 
  175. [formatter setDateFormat:format]; 
  176. NSString* dateStr = [formatter stringFromDate:date]; 
  177. [formatter release]; 
  178. return dateStr; 
  179. static NSString* format(NSString* formatStr, ...){ 
  180. va_list arglist; 
  181. va_start(arglist, formatStr); 
  182. id statement = [[[NSString alloc]  initWithFormat:formatStr arguments:arglist] autorelease]; 
  183. va_end(arglist); 
  184. return statement; 
  185. static NSString* toNSString(std::string str){ 
  186. return toNSString(str.c_str()); 
  187. static NSString* toNSString(const char* str){ 
  188. return [NSString stringWithUTF8String:str]; 
  189. static NSString* toNSString(Json::Value value){ 
  190. return toNSString(value.asString()); 
  191. static String Create(Json::Value value){ 
  192. String str(toNSString(value)); 
  193. return str; 
  194. }; 

從源碼中可以 看出,為了支持正則式,這里使用了RegexKitLite庫,網上有不少網友問為什么使用這個H文件時,如果.m文件改成支持C++的.mm后綴之后, 會造編譯錯誤('capture Count'was not declared in this scope),導致程序運行不起來。而網友的解決方法就是不使用.MM后綴文件。但經過分析我發現是BLOCK塊語法導致編譯錯誤的,在經過不斷嘗試之 后,發現只要修改該頭文件中的如下宏定義,就可以將該頭文件包含在MM文件中了:

#if !defined(RKL_BLOCKS) && defined(NS_BLOCKS_AVAILABLE) && (NS_BLOCKS_AVAILABLE == 1)

#define RKL_BLOCKS 1   //此處需要從1改為0

#endif

另外上面的String類的實現中,方法名稱主要是參考C#中的字符串處理類的名稱。所以可以很方法的使用。

NSString *test1 = @"imgOnLoad";

NSString *test2 = @"  trim test  ";

String s(test1);

test1 = s.trim().toUpper();

比如下面將字符串轉小寫并TRIM掉首尾空格:

NSString *test1 = @"imgOnLoad";

NSString *test2 = @"  trim test  ";

String s(test1);

test1 = s.trim().toUpper();

判斷字符串是否以指定內容開始或結束時:

BOOL result = s.startWith(@"imga");

result = s.endWith(@"load");

也可以直接將NSString*賦值給String實例

s = test2;

獲取字符串長度

int i = s.length();

字符串格式化及綁定:

String s1(123);

s1 = String::format(@"%@daizhj%@", @"diaoyudao", @"123");

String ss = String::format(@"http://%@www.sina.com.cn%@/ http", @"1", @"hello");

字符串替換:

test2 = s.replace(@"http", @"ddz").replace(@"sina", @"163").toString();

以及在C#開發中學中的StringBuilder類的appendFormat方法,這里也有相關方法對應:

test2 = s.appendFormat(@"%@daizhj%@", @"diaoyudao", @"123")

.appendFormat(@"%@fffffff%@", @"dddddd", @"123")

.appendFormat(@"%@aaaa%@", @"vvvvvv", @"123").toString();

截取子串:

test2 = s.subString(2, 10);

test2 = s.subString(10);

查找字符是否存在:

BOOL search = s.contains(@"dadddd");

除此以外,還有正則替換查找,url地址的編解碼,以及String對象轉換成其它不同類型如date, int, float等。

責任編輯:閆佳明 來源: oschina
相關推薦

2013-05-02 13:06:05

C++遇到iOS應用開SQLITE

2010-02-01 16:46:07

C++格式化字符串

2010-02-02 11:27:16

C++字符串

2021-09-07 09:23:07

C++字符串算法

2017-12-07 16:08:47

數據優化HTML字符串

2014-04-14 10:21:15

開發運維DevOps

2010-11-26 09:51:54

MySQL字符串

2010-02-04 17:39:48

C++字符串類型

2021-07-30 06:22:37

C++字符型字符串

2009-09-02 15:53:27

C#判斷字符串應用

2010-02-04 17:32:43

C++中C風格字符串

2023-12-11 15:18:03

C++字符串Unicode

2016-12-30 13:32:24

字符串算法代碼

2010-02-02 18:01:47

C++字符串替換函數

2009-09-01 17:50:23

C#截取字符串

2025-02-21 12:30:00

字符串前端JavaScript

2021-08-20 06:58:31

C++Python函數

2010-02-04 10:52:36

C++字符串分割函數

2024-03-11 06:05:00

C++字符串

2024-02-22 09:46:04

C++字符串格式化開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产91av视频在线观看 | 日韩精品一区二区三区 | 亚洲国产精品成人无久久精品 | 福利社午夜影院 | 黄视频网站免费观看 | 日本久久精品视频 | 在线视频中文字幕 | 国产 欧美 日韩 一区 | 亚洲视频免费观看 | 日本亚洲一区 | 欧美一区二区三区在线观看视频 | 国产乱一区二区三区视频 | 成人亚洲网 | 免费看91 | 欧美精品三区 | 亚洲国产成人精品一区二区 | 欧美黑人又粗大 | 激情欧美一区二区三区中文字幕 | 免费av直接看 | 国产激情视频网站 | 成人在线精品视频 | 国产精品日韩欧美一区二区三区 | 爱操av | 精品国产黄色片 | 在线亚洲人成电影网站色www | 亚洲福利一区 | 日韩精品 电影一区 亚洲 | 影音先锋成人资源 | 国产不卡一区 | 日本成人中文字幕在线观看 | 久久精品国产一区二区电影 | 九九免费观看视频 | 一区二区三区福利视频 | 视频一区二区在线观看 | 日本一本在线 | 亚洲国产精品一区 | 亚洲成人免费观看 | 成人在线视频观看 | 亚洲精品一区av在线播放 | 在线观看日本高清二区 | 欧美日韩高清一区 |