// // main.m // NSString基本概念 // Foundation框架,蘋果有80多個框架,Foundation有125個頭文件。 #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { //如何創建字符串對象 /* 通過不同的方式創建字符串,字符串對象儲存的位置也不一樣 >如果是通過字符串常量創建,那么字符串對象存儲在常量區中 >如果是通過alloc initWithFormat/stringWithFormat創建,那么字符串對象存儲在堆區中 而且需要注意: >>alloc,不同的平台存儲的方式也不一樣,如果是Mac平台系統會自動對字符串對象進行優化,但是如果是iOS平台就是兩個對象。 >>alloc,不同的編譯器存儲的方式也不一樣,如果是Xcode6以下並且是在iOS平台,那么每次alloc都會創建一個新的對象,如果是在Xcode6以上那么alloc多次指向同一塊存儲空間。 */ //1.通過字符串常量創建,在常量區 //注意:如果是通過字符串常量創建對象,並且字符串常量的內容一致,那么如果創建多個字符串對象,多個對象指向同一塊存儲空間 NSString *str1 = @"lnj"; NSString *str11 = @"lnj"; NSLog(@"str1 = %p, str11 = %p", str1 ,str11);//str1 = 0x100004238, str11 = 0x100004238 //2.通過alloc init創建,只要調用alloc就會在堆內存中開辟一塊存儲空間 NSString *str2 = [[NSString alloc]initWithFormat:@"lnj"]; NSString *str22 = [[NSString alloc]initWithFormat:@"lnj"]; NSLog(@"str2 = %p, str22 = %p", str2, str22);//str2 = 0x6a6e6c35, str22 = 0x6a6e6c35 //3.通過類工廠方法創建/ stringWithFormat //內部其實就是封裝了alloc init NSString *str3 = [NSString stringWithFormat:@"zs"]; NSString *str33= [NSString stringWithFormat:@"zs"]; /* 注意:一般情況下,只要是通過alloc或者類工廠方法創建的對象,每次都會在堆內存中開辟一塊新的存儲空間 但是如果是通過alloc的initWithString方法除外,因為這個方法是通過copy返回一個字符串對象給我們 而copy又分為深拷貝和淺拷貝,如果是深拷貝會創建一個新的對象,如果是淺拷貝不會創建一個新的對象,而是直接返回被拷貝的對象的地址給我們 */ NSString *str4 = [[NSString alloc]initWithString:@"ls"]; NSString *str44 = [[NSString alloc]initWithString:@"ls"]; NSLog(@"str4 = %p, str44 = %p", str4, str44);//str4 = 0x1000042b8, str44 = 0x1000042b8 return 0; }
// main.m // 字符串文件讀寫 #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { /* file: 文件路徑, encoding: 編碼英文 iOS-5988-1 中文 GBK GBK2312 , 一般情況填寫UTF-8 error: 如果讀取錯誤, 會將錯誤信息保存到error中 ,如果讀取正確, 就沒有error = nil 注意: 以后在OC方法中但凡看到XXXofFile的方法, 傳遞的一定是全路徑(絕對路徑) */ NSString *path = @"/Users/mctc/Desktop/快捷鍵.txt"; NSError *error = nil; // 從文件中讀取字符串 NSString *str1 = [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:&error]; if (error == nil) { NSLog(@"str = %@", str1); }else { NSLog(@"error = %@", [error localizedDescription]);//錯誤的真正原因 } // 將字符串寫入到文件中 NSString *str = @"iOS0601基礎班"; // atomically 如果傳入YES, 字符串寫入文件的過程中如果沒有寫完, 那么不會生成文件 // 如果傳入NO, 字符串寫入文件的過程中如果沒有寫完, 會生成文件 NSString *path2 = @"/Users/mctc/Desktop/e.txt"; BOOL flag = [str writeToFile:path2 atomically:YES encoding:NSUTF8StringEncoding error:nil]; NSLog(@"flag = %i", flag); return 0; }
// // main.m // 字符串讀寫2 #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { //1.文件讀取 //1.創建URL //協議頭 + 主機地址 + 文件路徑 // NSString *path = @"file://192.168.199.199/Users/NJ-Lee/Desktop/lnj.txt"; file表示是本機的文件。ftp是文本傳輸協議。 // NSString *path = @"http://www.baidu.com"; //注意:如果加載的資源是本機上的資源,那么URL中的主機地址可以省略 //雖然主機地址可以省略,但是需要注意,文件路勁中最前面的/不能省略,文件路徑最前面的/代表根路徑 // NSString *path = @"file:///Users/NJ-Lee/Desktop/lnj.txt"; // NSURL *url = [NSURL URLWithString:path]; // NSString *path = @"file:///Users/NJ-Lee/Desktop/lnj.txt"; //注意:如果是通過NSURL的fileURLWithPath:方法創建URL,那么系統會自動給我們傳入的字符串添加協議頭(file://),所以字符串中不需要再寫file:// // 注意:開發中一 般情況下,如果是訪問本機的資源,創建URL的時候,建議使用fileURLWithPath方法創建 //因為url不支持中文,如果URL中包含中文,那么無法訪問;但是如果是通過fileURLWithString方法創建URL,哪怕URL中包含中文也可以進行訪問,系統內部會自動對URL中包含的中文進行處理 // NSURL *url = [NSURL fileURLWithPath:path]; NSString *path = @"file:///Users/NJ-Lee/Desktop/未命名文件夾/lnj.txt"; //如果URL中包含中文,又非不通過fileURLWithPath創建,也可以破 //如果想破就必須在創建URL之前先對字符串中的中文進行處理,進行百分號編碼 NSLog(@"處理前:%@", path); path = [path stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; NSLog(@"處理后:%@", path); NSURL *url = [NSURL URLWithString:path]; NSLog(@"url = %@", url); //2.根據URL加載文件中的字符串 NSString *str = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:nil]; NSLog(@"str = %@", str); //2.文件寫入 NSString *str1 = @"lnj"; // NSString *path = @"file:///Users/NJ-Lee/Desktop/未命名文件夾/abc.txt"; // path = [path stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; // NSURL *url = [NSURL URLWithString:path]; NSString *path1 = @"/Users/NJ-Lee/Desktop/未命名文件夾/abc.txt"; NSURL *url1 = [NSURL fileURLWithPath:path1]; [str1 writeToURL:url1 atomically:YES encoding:NSUTF8StringEncoding error:nil]; //注意點:如果多次往同一個文件中寫入內容,那么后一次的會覆蓋前一次的 NSString *str22 = @"xxoo"; [str22 writeToURL:url atomically:YES encoding:NSUTF8StringEncoding error:nil]; return 0; }
// // main.m // 字符串比較 #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { NSString *str1 = @"abc"; NSString *str2 = @"ABC"; // 比較兩個字符串的"內容"是否相同 BOOL flag = [str1 isEqualToString:str2]; NSLog(@"flag = %i", flag); // 下面這個方法, 是比較兩個字符串的"地址"是否相同 flag = (str1 == str2); NSLog(@"flag = %i", flag); // 比較字符串的大小 // NSOrderedAscending 前面的小於后面的 // NSOrderedSame, 兩個字符串相等 // NSOrderedDescending 前面的大於后面的 switch ([str1 compare:str2]) { case NSOrderedAscending: NSLog(@"str1小於str2"); break; case NSOrderedSame: NSLog(@"str1等於str2"); break; case NSOrderedDescending: NSLog(@"str1大於str2"); break; default: break; } // 忽略大小寫進行比較 switch ([str1 caseInsensitiveCompare:str2]) { case NSOrderedAscending: NSLog(@"str1小於str2"); break; case NSOrderedSame: NSLog(@"str1等於str2"); break; case NSOrderedDescending: NSLog(@"str1大於str2"); break; default: break; } return 0; }
// // main.m // 字符串搜索 #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { NSString *str = @"http://www.520it.com/img/lnj.gif"; // 1.判斷是否以什么開頭 // 本質就是從字符串的第一個字符開始匹配, 只要不匹配就返回NO if ([str hasPrefix:@"http://"]) { NSLog(@"是一個URL"); }else { NSLog(@"不是一個URL"); } // 2.判斷是否以什么結尾 // 本質就是從字符串的最后一個字符開始匹配, 只要不匹配就返回NO if ([str hasSuffix:@".gif"]) { NSLog(@"動態圖片"); }else{ NSLog(@"不是動態圖片"); } // 3.判斷字符串中是否包含520it.com NSString *str = @"abcd"; // 只要str中包含該字符串, 那么就會返回該字符串在str中的起始位置以及該字符串的長度 // location從0開始 , length從1開始 // 如果str中沒有需要查找的字符串, 那么返回的range的length=0, location = NSNotFound NSRange range = [str rangeOfString:@"lnj"]; // if (range.location == NSNotFound) { if (range.length == 0){ NSLog(@"str中沒有需要查找的字符串"); }else{ NSLog(@"str中有需要查找的字符串"); NSLog(@"location = %lu, length = %lu", range.location, range.length); } return 0; }