- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想做一个带有地址簿的应用程序,需要添加搜索功能。我希望搜索功能可以支持字符串匹配,我在NSString
类中找到了[NSString containString:]
这个函数。为了高效,我想使用一个很好的字符串匹配算法来实现它,如KMP。所以想知道这个函数用的是什么算法。在哪里可以查看NSString
函数的源代码?
谢谢。
最佳答案
程序集如下:
Foundation`-[NSString containsString:]:
-> 0x10a128954 <+0>: pushq %rbp
0x10a128955 <+1>: movq %rsp, %rbp
0x10a128958 <+4>: pushq %r15
0x10a12895a <+6>: pushq %r14
0x10a12895c <+8>: pushq %rbx
0x10a12895d <+9>: pushq %rax
0x10a12895e <+10>: movq %rdx, %r14
0x10a128961 <+13>: movq %rdi, %rbx
0x10a128964 <+16>: movq 0x1836d5(%rip), %rsi ; "length"
0x10a12896b <+23>: movq 0x19ddee(%rip), %r15 ; (void *)0x000000010a4bb800: objc_msgSend
0x10a128972 <+30>: callq *%r15
0x10a128975 <+33>: movq 0x185dc4(%rip), %rsi ; "rangeOfString:options:range:locale:"
0x10a12897c <+40>: movq $0x0, (%rsp)
0x10a128984 <+48>: xorl %ecx, %ecx
0x10a128986 <+50>: xorl %r8d, %r8d
0x10a128989 <+53>: movq %rbx, %rdi
0x10a12898c <+56>: movq %r14, %rdx
0x10a12898f <+59>: movq %rax, %r9
0x10a128992 <+62>: callq *%r15
0x10a128995 <+65>: movabsq $0x7fffffffffffffff, %rcx ; imm = 0x7FFFFFFFFFFFFFFF
0x10a12899f <+75>: cmpq %rcx, %rax
0x10a1289a2 <+78>: setne %al
0x10a1289a5 <+81>: addq $0x8, %rsp
0x10a1289a9 <+85>: popq %rbx
0x10a1289aa <+86>: popq %r14
0x10a1289ac <+88>: popq %r15
0x10a1289ae <+90>: popq %rbp
0x10a1289af <+91>: retq
本质上就是下面的算法:
- (bool)containsString:(NSString *)stringToFind {
if (stringToFind && stringToFind.length < self) {
return (typeof(NSNotFound))[self rangeOfString:stringToFind options:NSLiteralSearch range:NSMakeRange(0, self.length) locale:nil].location != NSNotFound;
}
return false;
}
附言它不检查字符串是否为 nil 或检查其长度。它确实:
- (bool)containsString:(NSString *)stringToFind {
return (typeof(NSNotFound))[self rangeOfString:stringToFind options:NSLiteralSearch range:NSMakeRange(0, self.length) locale:nil].location != NSNotFound;
}
没有安全检查。我不知道为什么我决定添加支票但是 w/e..
Range of String 有以下组件:
Foundation`-[NSString rangeOfString:options:range:locale:]:
-> 0x10a031cfd <+0>: pushq %rbp
0x10a031cfe <+1>: movq %rsp, %rbp
0x10a031d01 <+4>: pushq %r15
0x10a031d03 <+6>: pushq %r14
0x10a031d05 <+8>: pushq %r13
0x10a031d07 <+10>: pushq %r12
0x10a031d09 <+12>: pushq %rbx
0x10a031d0a <+13>: subq $0x48, %rsp
0x10a031d0e <+17>: movq %r9, %r15
0x10a031d11 <+20>: movq %r8, %r14
0x10a031d14 <+23>: movq %rcx, -0x40(%rbp)
0x10a031d18 <+27>: movq %rdx, %r13
0x10a031d1b <+30>: movq %rsi, -0x48(%rbp)
0x10a031d1f <+34>: movq %rdi, %r12
0x10a031d22 <+37>: movq 0x27a317(%rip), %rsi ; "length"
0x10a031d29 <+44>: movq 0x294a30(%rip), %rbx ; (void *)0x000000010a4bb800: objc_msgSend
0x10a031d30 <+51>: movq %r13, %rdi
0x10a031d33 <+54>: callq *%rbx
0x10a031d35 <+56>: movq %rax, -0x50(%rbp)
0x10a031d39 <+60>: movq 0x27a300(%rip), %rsi ; "length"
0x10a031d40 <+67>: movq %r12, %rdi
0x10a031d43 <+70>: callq *%rbx
0x10a031d45 <+72>: movq %rax, %rbx
0x10a031d48 <+75>: subq %r15, %rax
0x10a031d4b <+78>: jb 0x10a031d56 ; <+89>
0x10a031d4d <+80>: cmpq %r14, %rax
0x10a031d50 <+83>: jae 0x10a031e07 ; <+266>
0x10a031d56 <+89>: callq 0x10a239912 ; symbol stub for: __CFStringNoteErrors
0x10a031d5b <+94>: testb %al, %al
0x10a031d5d <+96>: je 0x10a031e07 ; <+266>
0x10a031d63 <+102>: movl $0x6, %edi
0x10a031d68 <+107>: callq 0x10a2396b4 ; symbol stub for: _CFExecutableLinkedOnOrAfter
0x10a031d6d <+112>: testb %al, %al
0x10a031d6f <+114>: je 0x10a031dc5 ; <+200>
0x10a031d71 <+116>: movq 0x281420(%rip), %rax ; (void *)0x000000010ac5a358: NSException
0x10a031d78 <+123>: movq %rax, -0x58(%rbp)
0x10a031d7c <+127>: movq 0x294325(%rip), %rax ; (void *)0x000000010ac74b38: NSRangeException
0x10a031d83 <+134>: movq (%rax), %rax
0x10a031d86 <+137>: movq %rax, -0x60(%rbp)
0x10a031d8a <+141>: movq %r12, %rdi
0x10a031d8d <+144>: movq -0x48(%rbp), %rsi
0x10a031d91 <+148>: callq 0x10a11f7e0 ; _NSMethodExceptionProem
0x10a031d96 <+153>: movq %rax, %r8
0x10a031d99 <+156>: movq 0x27a288(%rip), %rsi ; "raise:format:"
0x10a031da0 <+163>: movq %rbx, 0x8(%rsp)
0x10a031da5 <+168>: movq %r15, (%rsp)
0x10a031da9 <+172>: leaq 0x2a4e40(%rip), %rcx ; @"%@: Range {%lu, %lu} out of bounds; string length %lu"
0x10a031db0 <+179>: xorl %eax, %eax
0x10a031db2 <+181>: movq -0x58(%rbp), %rdi
0x10a031db6 <+185>: movq -0x60(%rbp), %rdx
0x10a031dba <+189>: movq %r14, %r9
0x10a031dbd <+192>: callq *0x29499d(%rip) ; (void *)0x000000010a4bb800: objc_msgSend
0x10a031dc3 <+198>: jmp 0x10a031e07 ; <+266>
0x10a031dc5 <+200>: movb 0x29326d(%rip), %al ; rangeOfString:options:range:locale:.warnonce
0x10a031dcb <+206>: testb %al, %al
0x10a031dcd <+208>: jne 0x10a031e07 ; <+266>
0x10a031dcf <+210>: movb $0x1, 0x293262(%rip) ; compare:options:range:locale:.localeClass + 7
0x10a031dd6 <+217>: movq %r12, %rdi
0x10a031dd9 <+220>: movq -0x48(%rbp), %rsi
0x10a031ddd <+224>: callq 0x10a11f7e0 ; _NSMethodExceptionProem
0x10a031de2 <+229>: movq %rax, %rbx
0x10a031de5 <+232>: movq %r14, %rdi
0x10a031de8 <+235>: movq %r15, %rsi
0x10a031deb <+238>: callq 0x10a1212f0 ; NSStringFromRange
0x10a031df0 <+243>: movq %rax, %rcx
0x10a031df3 <+246>: leaq 0x2a4e36(%rip), %rdi ; @"*** %@: Invalid range %@; this will become an exception for apps linked on SnowLeopard. Warning shown once per app execution."
0x10a031dfa <+253>: xorl %eax, %eax
0x10a031dfc <+255>: movq %rbx, %rsi
0x10a031dff <+258>: movq %rcx, %rdx
0x10a031e02 <+261>: callq 0x10a06c78a ; NSLog
0x10a031e07 <+266>: testq %r13, %r13
0x10a031e0a <+269>: jne 0x10a031e5e ; <+353>
0x10a031e0c <+271>: callq 0x10a239912 ; symbol stub for: __CFStringNoteErrors
0x10a031e11 <+276>: testb %al, %al
0x10a031e13 <+278>: je 0x10a031e5e ; <+353>
0x10a031e15 <+280>: movq 0x28137c(%rip), %rax ; (void *)0x000000010ac5a358: NSException
0x10a031e1c <+287>: movq %rax, -0x58(%rbp)
0x10a031e20 <+291>: movq 0x294241(%rip), %rax ; (void *)0x000000010ac74b40: NSInvalidArgumentException
0x10a031e27 <+298>: movq (%rax), %rax
0x10a031e2a <+301>: movq %rax, -0x60(%rbp)
0x10a031e2e <+305>: movq %r12, %rdi
0x10a031e31 <+308>: movq -0x48(%rbp), %rsi
0x10a031e35 <+312>: callq 0x10a11f7e0 ; _NSMethodExceptionProem
0x10a031e3a <+317>: movq %rax, %rbx
0x10a031e3d <+320>: movq 0x27a1e4(%rip), %rsi ; "raise:format:"
0x10a031e44 <+327>: leaq 0x2a4dc5(%rip), %rcx ; @"%@: nil argument"
0x10a031e4b <+334>: xorl %eax, %eax
0x10a031e4d <+336>: movq -0x58(%rbp), %rdi
0x10a031e51 <+340>: movq -0x60(%rbp), %rdx
0x10a031e55 <+344>: movq %rbx, %r8
0x10a031e58 <+347>: callq *0x294902(%rip) ; (void *)0x000000010a4bb800: objc_msgSend
0x10a031e5e <+353>: movq 0x10(%rbp), %r9
0x10a031e62 <+357>: movq -0x40(%rbp), %rcx
0x10a031e66 <+361>: testb $0x4, %ch
0x10a031e69 <+364>: jne 0x10a031ebe ; <+449>
0x10a031e6b <+366>: movabsq $0x7fffffffffffffff, %rbx ; imm = 0x7FFFFFFFFFFFFFFF
0x10a031e75 <+376>: xorl %edx, %edx
0x10a031e77 <+378>: testq %r15, %r15
0x10a031e7a <+381>: je 0x10a031ede ; <+481>
0x10a031e7c <+383>: cmpq $0x0, -0x50(%rbp)
0x10a031e81 <+388>: je 0x10a031ede ; <+481>
0x10a031e83 <+390>: leaq (,%rcx,8), %r8
0x10a031e8b <+398>: notl %r8d
0x10a031e8e <+401>: andq $0x10, %r8
0x10a031e92 <+405>: orq %rcx, %r8
0x10a031e95 <+408>: leaq -0x38(%rbp), %rax
0x10a031e99 <+412>: movq %rax, (%rsp)
0x10a031e9d <+416>: movq %r12, %rdi
0x10a031ea0 <+419>: movq %r13, %rsi
0x10a031ea3 <+422>: movq %r14, %rdx
0x10a031ea6 <+425>: movq %r15, %rcx
0x10a031ea9 <+428>: callq 0x10a239354 ; symbol stub for: CFStringFindWithOptionsAndLocale
0x10a031eae <+433>: xorl %edx, %edx
0x10a031eb0 <+435>: testb %al, %al
0x10a031eb2 <+437>: je 0x10a031ede ; <+481>
0x10a031eb4 <+439>: movq -0x38(%rbp), %rbx
0x10a031eb8 <+443>: movq -0x30(%rbp), %rdx
0x10a031ebc <+447>: jmp 0x10a031ede ; <+481>
0x10a031ebe <+449>: movq 0x27c873(%rip), %rsi ; "_rangeOfRegularExpressionPattern:options:range:locale:"
0x10a031ec5 <+456>: movq %r9, (%rsp)
0x10a031ec9 <+460>: movq %r12, %rdi
0x10a031ecc <+463>: movq %r13, %rdx
0x10a031ecf <+466>: movq %r14, %r8
0x10a031ed2 <+469>: movq %r15, %r9
0x10a031ed5 <+472>: callq *0x294885(%rip) ; (void *)0x000000010a4bb800: objc_msgSend
0x10a031edb <+478>: movq %rax, %rbx
0x10a031ede <+481>: movq %rbx, %rax
0x10a031ee1 <+484>: addq $0x48, %rsp
0x10a031ee5 <+488>: popq %rbx
0x10a031ee6 <+489>: popq %r12
0x10a031ee8 <+491>: popq %r13
0x10a031eea <+493>: popq %r14
0x10a031eec <+495>: popq %r15
0x10a031eee <+497>: popq %rbp
0x10a031eef <+498>: retq
它运行一个正则表达式来检查一个字符串是否有另一个字符串并且它有安全检查..
关于ios - [NSString containString :] this function in ObjC? 使用了什么算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38636057/
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!