NSString详解

2024-08-28 16:38
文章标签 详解 nsstring

本文主要是介绍NSString详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、Foundation框架中几个重要的类:
NSString、NSArray、NSSet、NSDictionary、NSDate、NSObject
其中NSString有子类NSMutableString,NSArray有子类NSMutableArray,NSSet有子类NSMutableSet,NSDictionary有子类NSMutableDictionary
2、NSString:不可变字符串
子类NSMutableString:可变字符串
3、字符串的创建方式:
(1)直接赋值创建  NSString *s1=@“Jack”;
(2)NSString *s2=[[NSString alloc] initWithString:@“jack”];
(3)创建对象调用格式化对象方法创建
NSString *s3=[[NSString alloc] initWithFormat:@“age is %d”,10];
(4)也可以调用类方法按一定格式创建:
NSString *s=[NSString stringWithFormat:@“Now is %@”,[NSDate date]];
(5)也可以将两个字符串拼接出一个新的字符串(不改变原来的东西)举例如下:将str2连接在str1后面生成新的字符串str3
NSString *str3=[str1 stringAppendingString:str2];
(6)创建对象调用将c字符串装换为OC字符串的对象方法
NSString *s4=[[NSString alloc] initWithUTF8String:”Jim”];
(注意:是c语言字符串,不是OC字符串,不可加@)就是说此方法可以把C语言字符串转化为OC字符串。
(7)将OC字符串对象装换为C字符串
const char *cs=[s4 UTF8String];此方法将OC字符串转化为C语言字符串。
(8)将文件中内容转为字符串,可用如下对象方法:
NSString *s=[[NSString alloc] initWithContentsOfFile:(NSString *) encoding:(NSStringEncoding) error:(NSError **)];
第一个参数为要读取文件的绝对路径,第二个为文件编码:如果要读取为中文的话都一律设为NSUTF8StringEncoding  最后一个参数统统先设为nil值,举例如下所示:
NSString *s5=[[NSString alloc] initWithContentsOfFile:@“/Users/apple/Desktop/1.txt”encoding:NSUTF8StringEncoding  error:nil];
(9)将指定资源路径的内容读取到字符串中:可用如下方法对象方法——>
NSString *s=[[NSString alloc] initWithContentsOfURL:(NSURL *) encoding:(NSStringEncoding) error:(NSError **)];
举例如下:
NSURL *url=[[NSURL alloc] initWithString:@"file:///Users/apple/Desktop/1.txt"];
        NSString *s6=[[NSString alloc] initWithContentsOfURL:url encoding:NSUTF8StringEncoding error:nil];
        NSLog(@"\n%@",s6);
注意:NSURL *是指资源的地址 格式是:协议头://路径
可以是网络资源、FTP服务器资源、也可以是本地文件资源 例如:
ftp://路径  ftp://路径  或 http://weibo.com/a.txt
encoding:编码一般读取中文都是NSUTF8StringEncoding
error:暂且赋值为nil 空值。如果URL是网址的话,就会把指定网页的标签元素给全部读取,百度网页的编码是utf8,其他网页可能不是。切记:如果为本地文件路径前面必须要有一个‘/’,跟协议头格式不同,一个‘/’都不可以少。
(10)以上NSString的对象方法均可用以下的类方法代替:
 <1>NSString *str=[NSString stringWithUTF8String:(const char *)]
<2> NSString *str1=[NSString stringWithCString:(const char *) encoding:(NSStringEncoding)];
<3>NSString *str=[NSString stringWithString:(NSString *)];
<4>NSString *str=[NSString stringWithContentsOfURL:(NSURL *) encoding:(NSStringEncoding) error:(NSError **)];
<5>NSString *str=[NSString stringWithFormat:(NSString *), ...];  等等
注意:可以看出NSString的对象方法名除了stringAppendingString方法外,基本都是以initWith开头的,而它的类方法大部分以stringWith开头。而NSNumber的对象方法都以initWith开头,而它的类方法大都以numberWith开头。同样,NSURL的对象方法以initWith开头,它的类方法都以URL开头。……
规律总结:
(一)系统提供的类方法基本都有一个功能相同的对象方法与之对应,假设一个系统提供的类为NSXxx,它的类方法都是以initWith开头的,它的对象方法基本都是以Xxx开头或xxx开头的。
(二)URL是资源的地址,必须要有协议头,协议头的格式是:协议头:// 
特别是本地资源要用协议头“file://”,如果不想手动加file://,也可以在生成URL的时候用如下方法,即:
NSURL *url=[NSURL fileURLWithPath:(NSString *)];举例如下:
NSURL *url=[NSURL fileURLWithPath:@“/Users/apple/Desktop/1.txt”];就是说用了这个URL的生成方法就会自动在前面加上表示本地资源的协议头。
4、将字符串写到一个文件中(字符串的导出):要用到如下方法:
(1)写到本地文件。[s writeToFile:(NSString *) atomically:(BOOL) encoding:(NSStringEncoding) error:(NSError **)];
 (2)写到指定的路径。[s writeToURL:(NSURL *) atomically:(BOOL) encoding:(NSStringEncoding) error:(NSError **)];
(3)举例如下: [@“Liu Xun”, writeToFile:@"/Users/apple/Desktop/1.txt" atomically:YES encoding:NSUTF8StringEncoding error:nil];
注意:atomiclly:表示是否为原子操作,如果传入YES,表示如果写入失败将不会在指定的路径创建文件,如果为NO的话无论写入是否成功都会创建文件。
另外要写进文件的字符串中如果想写进文件后想在某个位置换行,就要事先在字符串中的这个位置添加“\n”。(检测有多少行代码的原理就是看看有多少换行符即可)
写到本地指定文件地址前不加协议头,写到URL要加协议头。
5、字符串的比较:
(1)一般比较(不忽略大小写):可以用对象方法compare也可以用对象方法isEqualToString。返回结果是NSComparisonResult类型,如果左边>右边返回结果为NSOrderedDescending,如果左边小于右边返回NSOrderedAscending,如果左边等于右边则返回NSOrderedSame。如果忽略大小写进行比较就使用caseInsensitiveCompare方法。
6、不改变原先字符串基础上,从字符串中的截取字串。
subStringToIndex:返回一个字串,从首字符到下标为index-1的字符
subStringFromIndex:返回一个字串,从index位置到结尾。
subStringWithRange:返回一个Range返回的字串。例如:
NSString *newStr=[str subStringWithRange:NSRange(位置,长度)]; 或
NSString *newStr=[str subStringWithRange:range对象];
7、连接两个字符串生成一个新的字符串:用stringByAppendingString方法。例:NSString *str3=[str1 stringByAppedningString :str2];
8、字符串的查找:
(1)判断是否以某串开头,用hasPrefix 如int i=[str hasPrefix:@“1”];
(2)判断是否以某串结尾,用hasSuffix如int i=[str hasSuffix:@“.txt”];
(3)查找字符串中某个字串的范围(起始位置与长度)用rangeOfString方法返回一个Range,如果没有找到返回值的location变量为NSNotFound。例如
NSRange subRange=[str rangeOfString:@“subString”];
if(subRange.location=NotFound){  //  }
(4)查找某个下标的字符:用characterIndex方法,返回一个字符
char c=[str  characterAtIndex: i ];
9、以某标志切割字符串,存到一个新的数组中:用componentsSeparedByString方法返回一个NSArray数组类型,可以用数组的objectAtIndex进行字串的获取。例如:
NSString *str=@"1,2,3,4,5,6,7,8";
NSArray *array=[str componentsSeparatedByString:@","];
//拿到array第0个位置的字符串, array: [1,2,3,4,5,6,7]
NSString *str3 = [array objectAtIndex:0]; //输出1

代码验证,实例如下:

在main.m中编辑如下:

//
//  main.m
//  NSStringExample
//
//  Created by apple on 15/8/19.
//  Copyright (c) 2015年 liu. All rights reserved.
//#import <Foundation/Foundation.h>
void Test1(){NSLog(@"Test1验证创建字符串的一般方式=========");NSString *s1 = @"Liu Xun"; //直接创建NSString *s2 = [[NSString alloc] initWithString:@"Liuxun1993"];//以对象方式初始赋值//按指定的格式以对象方法创建NSString *s3 = [[NSString alloc] initWithFormat:@"Liuxun %d 年出生",1993];//按指定的格式以类方法创建NSString *s4 = [NSString stringWithFormat:@"I age is %d",22];//用对象方法将两个字符串拼接成一个新的字符串NSString *s5= [@"I am " stringByAppendingString:@"Liuxun"];//用对象方法将c字符串(引号前没有@即char *类型)转化为OC字符串NSString *s6 = [[NSString alloc] initWithUTF8String:"我毕业于黄淮"];//用类方法将c字符串(引号前没有@即char *类型)转化为OC字符串NSString *s7 = [NSString stringWithUTF8String:"我毕业于黄淮"];//将OC字符串转换为C语言字符串const  char *s8=[s6 UTF8String];NSLog(@"s1=%@", s1);NSLog(@"s2=%@", s2);NSLog(@"s3=%@", s3);NSLog(@"s4=%@", s4);NSLog(@"s5=%@", s5);NSLog(@"s6=%@",s6);NSLog(@"s7=%@",s7);NSLog(@"%s",s8);
}
void Test2(){ //字符串的 比较、截取、查找、切割//用compare或isEqualToString比较字符串的大小NSComparisonResult result=[@"liuxun" isEqualToString:@"liuju"];if(result == NSOrderedSame){NSLog(@"左边等于右边");}else if (result == NSOrderedAscending){NSLog(@"左边等于右边");}else if(result == NSOrderedDescending){NSLog(@"左边大于右边");}//利用substringFromIndex和substringToIndex进行字符串的截取NSString *sub1 = [@"liuxun" substringFromIndex:3];NSString *sub2 = [@"liuxun 1993" substringToIndex:5];NSLog(@"sub1= %@ sub2= %@",sub1,sub2);BOOL b = [@"liuxun" hasPrefix:@"liu"];//判断某字符串是否以另一串开头BOOL b1 = [@"liuxun" hasSuffix:@"xun"];//判断某字符串是否以另一串结尾NSLog(@"b= %d b1=%d",b,b1);//查找字符串中某个字串的范围NSRange range=[@"liuxun1993" rangeOfString:@"xun"];NSLog(@"location=%ld length= %ld",range.location,range.length);//查找某个下标的字符unichar c=[@"liuxun" characterAtIndex:4];NSLog(@"下标为四的字符是:%c",c);NSString *str=@"liu xun, liu ju,mu qin,grand parent";NSArray *array=[str componentsSeparatedByString:@","];for (int i=0; i<array.count; i++) {NSLog(@"%@",[array objectAtIndex:i]);}
}
void Test3(){ //字符串与文件有关的操作//使用对象方法将指定本地资源路径的内容读取到字符串中NSString *f1 = [[NSString alloc] initWithContentsOfFile:@"/Users/apple/Desktop/1.txt" encoding:NSUTF8StringEncoding error:nil];//使用类方法将指定本地资源路径的内容读取到字符串中NSString *f2 = [NSString stringWithContentsOfFile:@"/Users/apple/Desktop/2.txt" encoding:NSUTF8StringEncoding error:nil];//使用对象方法指定资源路径的内容读取到字符串中(带协议头的NSURL生成方法)NSURL *url1= [[NSURL alloc] initWithString:@"file:///Users/apple/Desktop/1.txt"];NSString *f3 = [[NSString alloc] initWithContentsOfURL:url1 encoding:NSUTF8StringEncoding error:nil];//使用类方法将指定资源路径的内容读取到字符串中(带协议头的NSURL生成方法)NSURL *url2 = [NSURL URLWithString:@"file:///Users/apple/Desktop/2.txt"];NSString *f4 = [NSString stringWithContentsOfURL:url2 encoding:NSUTF8StringEncoding error:nil];//使用资源对象方法将字符串写到指定的3.txt文件中(不手动带协议头的URL方法)NSString *t = @"苦心人天不负,\n卧薪尝胆,\n三千越甲可吞吴\n";NSURL *url3 = [[NSURL alloc] initFileURLWithPath:@"/Users/apple/Desktop/3.txt"];[t writeToURL:url3 atomically:YES encoding:NSUTF8StringEncoding error:nil];//使用资源类方法将字符串写到指定的4.txt文件中(不用带协议头的字符串)NSString *t1= @"咬定青山不放松,\n立根原在破岩中.\n千磨万击还坚劲...\n";[t1 writeToFile:@"/Users/apple/Desktop/4.txt" atomically:YES encoding:NSUTF8StringEncoding error:nil];NSLog(@"\n读取f1=\n%@",f1);NSLog(@"\n读取f2=\n%@",f2);NSLog(@"\n读取f3=\n%@",f3);NSLog(@"\n读取f4=\n%@",f4);/*注意:将字符串写进文件的时候,若想在文件中某个位置换行,就必须事先在字符串中的对应位置添加"\n"。*/
}
int main(int argc, const char * argv[])
{@autoreleasepool {//        Test1();//       Test2();Test3();}return 0;
}
运行前桌面不存在3.txt和4.txt 

存在1.txt和2.txt打开如下图



单独运行Test1()结果如下:


单独运行Test2()结果如下:


单独运行Test3() 结果如下:


此时桌面多了3.txt和4.txt文件,打开如下:


这篇关于NSString详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1115311

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor

LabVIEW FIFO详解

在LabVIEW的FPGA开发中,FIFO(先入先出队列)是常用的数据传输机制。通过配置FIFO的属性,工程师可以在FPGA和主机之间,或不同FPGA VIs之间进行高效的数据传输。根据具体需求,FIFO有多种类型与实现方式,包括目标范围内FIFO(Target-Scoped)、DMA FIFO以及点对点流(Peer-to-Peer)。 FIFO类型 **目标范围FIFO(Target-Sc

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

脏页的标记方式详解

脏页的标记方式 一、引言 在数据库系统中,脏页是指那些被修改过但还未写入磁盘的数据页。为了有效地管理这些脏页并确保数据的一致性,数据库需要对脏页进行标记。了解脏页的标记方式对于理解数据库的内部工作机制和优化性能至关重要。 二、脏页产生的过程 当数据库中的数据被修改时,这些修改首先会在内存中的缓冲池(Buffer Pool)中进行。例如,执行一条 UPDATE 语句修改了某一行数据,对应的缓

OmniGlue论文详解(特征匹配)

OmniGlue论文详解(特征匹配) 摘要1. 引言2. 相关工作2.1. 广义局部特征匹配2.2. 稀疏可学习匹配2.3. 半稠密可学习匹配2.4. 与其他图像表示匹配 3. OmniGlue3.1. 模型概述3.2. OmniGlue 细节3.2.1. 特征提取3.2.2. 利用DINOv2构建图形。3.2.3. 信息传播与新的指导3.2.4. 匹配层和损失函数3.2.5. 与Super

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹