OC可变字符串NSMutableString详解

2024-08-28 16:38

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

1、已知NSMutableString继承自NSString,是可变字符串。而NSString是不可变字符串。
2、NSMutableString类型字符串的创建:
因为它完全继承自NSString,所以NSString的所有方法,它都可以使用。例如:stringWithFormat方法,还有stringWithContentsOfFile,stringWithContentsOfURL等等。也可以用它自身扩展的方法stringWithString
 3、NSMutableString的常用操作(改变的是自身):
(1)在字符串末尾追加字符串:用appendingString方法
(2)删除字符串中某个范围内的子串:使用deleteCharactersInRange方法,举例如下:如果要删除可变字符串NSMutableString *s=[NSMutableString stringWithFormat:@“age is 10”];中的is,具体操作如下:
[s deleteCharactersInRange:NSMakeRange(4,2)];
(3)删除字符串中的某个子串:思路——>先用rangeOfString方法获取要删除的字串在可变字符串中的Range,即范围。然后用以上专门用来删除某个范围内字串的deleteCharactersInRange方法即可。举例如下:若想删除可变字符串t2假设为@“My age is 22”中的is。代码如下:NSRange range=[t2 rangeOfString:@“is”];
[t2 deleteCharactersInRange:range];
(4)直接修改字符串的内容:用setString方法即可
(5)在指定位置插入一个字符串:insertString方法
(6)把指定范围内的子串替换为新的子串:使用replaceCharactersInRange方法即可。
(7)在指定的范围内查找某个子串首次出现的位置:用如下方法
[mstr replaceOccurencesOfString:searchStr  withString: replaceStr options:nil range:NSMakeRange[0,mstr.length]]
mstr:当前要处理的字符串;
serachString:查找后将被替换的子串
withString:用来替换searchString的字符串
options:查找方式如果为空nil则正向查找,如果是NSBackwardSearch则反向进行查找;如果是

NSLiteralSearch则进行正向查找,如果为NSCaseInsensitiveSearch则查找替换时忽略searchString的大小写

range:在mstr中进行查找替换的范围。

代码验证,实例如下:

//
//  main.m
//  NSMutableStringExample
//
//  Created by apple on 15/8/20.
//  Copyright (c) 2015年 liu. All rights reserved.
//#import <Foundation/Foundation.h>
void Test1() //切记:NSMutableString完全拥有NSString的所有方法
{ //新建可变字符串  可以用继承NSString的方法也可以用自身扩展的方法NSMutableString *s1 = [[NSMutableString alloc] initWithString:@"aaaa"];NSMutableString *s2 = [NSMutableString stringWithString:@"Liuxun1993"];NSLog(@"s1=%@  s2=%@",s1, s2);[s1 appendString:@"bbb"];  // 在s1的末尾追加字符串@"bbb"[s1 appendFormat:@" %d 个字母",6];  // 在s1末尾追加一定格式的字符串[s2 deleteCharactersInRange:NSMakeRange(6, 4)]; // 删除s2中指定范围内的子串NSLog(@"s1=%@  s2=%@",s1,s2);NSRange range=[s1 rangeOfString:@" 6 个字母"]; // 删除s1中的指定字符串[s1 deleteCharactersInRange:range];[s2 setString:@"Liu Ju 1991"]; // 直接修改s2中的内容NSLog(@"s1=%@  s2=%@",s1,s2);[s2 insertString:@" 出生于" atIndex:6]; // 在指定的位置插入字符串//  用新串替换指定范围内的子串[s1 replaceCharactersInRange:NSMakeRange(2, 4) withString:@"dddd"];NSLog(@"s1=%@  s2=%@",s1,s2);//在指定的范围内按指定的方式查找,并用指定的新串替换查找范围内的所有指定的旧串NSMutableString *ss1 = [NSMutableString stringWithString:@"aabbccddeeffccbbccc"];NSMutableString *ss2 =[ss1 mutableCopy];NSLog(@"替换前:ss1=%@ ss2=%@",ss1,ss2);// 方式一:正向查找替换unsigned long int index1 =  [ss1 replaceOccurrencesOfString:@"cc" withString:@"XX" options:NSLiteralSearch range:NSMakeRange(0,ss1.length)];//方式二: 反向查找替换unsigned long int index2 = [ss2 replaceOccurrencesOfString:@"cc" withString:@"XX" options:NSBackwardsSearch range:NSMakeRange(0, ss2.length)];NSLog(@"正向替换后:ss=%@ 替换个数=%ld",ss1,index1);NSLog(@"反向替换后:ss2=%@ 替换个数=%ld",ss2,index2);
}
int main(int argc, const char * argv[])
{@autoreleasepool {Test1();NSMutableString *s = [NSMutableString stringWithString:@"abcdefghijkldefmn"];unsigned long i = [s replaceOccurrencesOfString:@"def" withString:@"" options:NSBackwardsSearch range:NSMakeRange(0, s.length-1)];NSLog(@"%ld %@",i,s);}return 0;
}
运行结果如下:



这篇关于OC可变字符串NSMutableString详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

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

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

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

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 语句修改了某一行数据,对应的缓

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数