C语言剖析OC的rangeOfString方法

C语言剖析OC的rangeOfString方法在OC中,我们选择-(NSRange)rangeOfString:方法来判断字符串是否存在。该方法返回的是一个NSRange类型的结构体,成员变量包括location、length。需要注意的是:当这个字符串不存在时,返回的location不仅仅是NSNotFound,并且length的值也是0.

在OC中,我们选择- (NSRange)rangeOfString:方法来判断字符串是否存在。该方法返回的是一个NSRange 类型的结构体,成员变量包括location、length。
需要注意的是:当这个字符串不存在时,返回的location不仅仅是NSNotFound,并且length的值也是0.
这里写图片描述
str1 里不包括字符串str2,调用rangeOfString方法后,打印出str2的长度值,仍然为0
这里写图片描述

我们通过C语言来模拟这个方法,使大家更加清晰的认识到OC的本质

首先通过一个匿名结构体,我们声明一个类型NSRange(模仿OC),它具有两个成员变量
这里写图片描述

为了便于大家理解,我们声明两个字符串数组,要求判断字符串str1中是否出现了str2,如果出现了str2,将其删除
这里写图片描述

我们的思路是:
1.首先判断字符串1是否包含字符串2
2.若包含,返回字符串2的长度length,并且在字符串1中标记首次出现的位置
3.从标记位置开始,将length范围之内的每个字符变成 ‘\0’
4.通过比较,将 ‘\0’ 移动到字符串末尾
5.再次比较字符串1是否包含字串串2

在这里我们主要说一下如何判断字符串1包含字符串2的函数体,我们通过指针来说明:
这里写图片描述

思路:
1.我们定义2个指针,分别指向两个字符串,str1 = “ccatat” str2 = “cat”
2.通过str1我们获得该字符串的第一个值,将其与str2的首个字符进行比较,并且str2每移动一次,我们统计一下次数

I:返回相等
步骤1:str1+1,指向下一个位置,str2+1指向下一个位置,继续判断是否相等
步骤2:若相等,继续执行步骤1;若不相等首先将str2指针归为原来的初始位置,重新判断str1此时指向的字符是否与str2的首个字符相等。另外需要讲str2移动的次数归0,因为若不归零我们会得到一个比真实数据大很多的值
步骤3: 当str2指针指向了 ‘\0’,就说明str1中肯定包含str2字符串,这种情况下str2指针的移动次数就是它的长度值

II:返回不相等
1. str1指针指向下一个位置
2. str2指针不变

我们发现,要想统计出str2的长度,str2指针必须从头到尾走一遍,且不能被打断,也就是当str1包含str2的时候我才能获得该值。否则就永远是0
另外,若字符串1种包含多个字符串2,我们只是拿到了它首次出现的位置。

因此OC中若想删除一个子字符串,需要调用一个循环,不然只会删除首个出现的子字符串
这里写图片描述

将str1中出现的“cat”删除之后的结果是:
这里写图片描述

今天的文章C语言剖析OC的rangeOfString方法分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/33454.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注