1. 基本概念

    • NSString是以UTF-16 code uint的序列。所有的长度、字符、范围都是以16比特platform-endian(大端序小段序基于平台)的形式表示的。
      所以,一个英文字母的长度是1,一个汉字的长度也是1,而emoji表情的长度可能是2,3,4等等。
    • NSString可以从c缓冲区、NSdata对象以及NSUrl的内容中生成,也可以转化为这些内容。可以在ASCII、UTF-8、UTF-16、UTF-32以及其他编码格式之间转换。
  2. 关于字符
    • NSString的两个基本方法是- (unichar)characterAtIndex:(NSUInteger)index@property(readonly) NSUInteger length
    • 对于字符串的比较、查找等等都是以字符为基础的。也就是说比较时,是挨个字符(character)比较的。
    • unichar是UTF-16编码单位。typealias unichar = UInt16
  3. 解析UTF-16数据
    当解析UTF-16数据(也就是比特数组按照UTF-16的格式解析),如果没有BOM(byte-order mark)指定端序,那么默认是大端序。
  4. 子类、object composition与category
    • 实现NSString的子类,需要实现NSString的backing store(可以是静态数组、动态分配的数组或者其他的数据形式)、length方法与charAtIndex方法。
    • 另一个选择是声明一个类,将NSString作为一个属性,并将需要的其它的metadata也作为属性存储在类中。并实现需要用到的NSString的方法(其实就是调用这个类NSString属性的方法)及其他方法。
    • category。 对所有的NSString对象都会起作用,有时会有导致意想不到的效果。不过可以增加NSString的功能。
  5. 生成NSString的方法
    • 从比特数组中生成
      - (instancetype)initWithBytes:(const void *)bytes length:(NSUInteger)len encoding:(NSStringEncoding)encoding;
      从指定长度的比特数组中以指定的编码格式解析得到NSString。当len比比特数组的长度还长时,返回nil。
    • unichar数组中生成。
      - (instancetype)initWithCharacters:(const unichar *)characters length:(NSUInteger)length;
    • 从C字符串中的生成
      - (instancetype)initWithCString:(const char *)nullTerminatedCString encoding:(NSStringEncoding)encoding;
      由于C字符串是以NULL终结的,所以字符串中不能有NULL。所以编码格式只能是8比特为基础的,因为比8比特宽的字符格式(比如UTF-16),一个编码单位可能有NULL比特。
    • 从参数创建
      - (instancetype)initWithFormat:(NSString *)format locale:(id)locale arguments:(va_list)argList;
    • 从NSData创建
      - (instancetype)initWithData:(NSData *)data encoding:(NSStringEncoding)encoding;
      data中,按照encoding解析,得到UTF-16的code unit序列。
    • 从文件中创建
      • 以指定编码格式创建
        - (instancetype)initWithContentsOfFile:(NSString *)path encoding:(NSStringEncoding)enc error:(NSError * _Nullable *)error;
        如果文件打不开或者编码错误,返回nil。
      • 从文件中创建,并返回解析用的编码格式
        - (instancetype)initWithContentsOfFile:(NSString *)path usedEncoding:(NSStringEncoding *)enc error:(NSError * _Nullable *)error;
        编码格式以指针方式返回。
    • 从URL中创建
      • 以指定编码格式创建
        - (instancetype)initWithContentsOfURL:(NSURL *)url encoding:(NSStringEncoding)enc error:(NSError * _Nullable *)error;
      • 返回解析用的编码格式
        - (instancetype)initWithContentsOfURL:(NSURL *)url usedEncoding:(NSStringEncoding *)enc error:(NSError * _Nullable *)error;
  6. 写到文件或URL中

    • 写到文件中
      - (BOOL)writeToFile:(NSString *)path atomically:(BOOL)useAuxiliaryFile encoding:(NSStringEncoding)enc error:(NSError * _Nullable *)error;
      如果useAuxiliaryFileYES,那么会生成一个临时的文件,把String写到这个文件中,然后将这个文件重命名为目标文件。这保证了及时系统crash,也不会导致已存在的文件(如果存在)会损坏。
      这个方法把编码信息存储在文件的扩展属性中,名字是com.apple.TextEncodin,值是编码的IANA名字+分号+编码格式的CFStringEncoding值。从文件里生成字符串时,也是用这些个信息来决定编码格式的。例如

      • MACINTOSH;0
      • UTF-8;134217984
      • UTF-8;
      • ;3071
    dd = @"d";
    NSString *file = [NSHomeDirectory() stringByAppendingPathComponent:@"test"];
    NSError *error = nil;
    [dd writeToFile:file atomically:YES encoding:NSUTF8StringEncoding error:&error];
    if (nil == error)
    {
    NSLog(@"write success");
    } NSDictionary *attrbuteDict = [[NSFileManager defaultManager] attributesOfItemAtPath:file error:&error];
    NSDictionary *extendAtt = [attrbuteDict objectForKey:@"NSFileExtendedAttributes"]; NSData *attrData = [extendAtt objectForKey:@"com.apple.TextEncoding"];
    NSString *attrStr = [[NSString alloc] initWithData:attrData encoding:NSUTF8StringEncoding];


    - 写到URL中去

    - (BOOL)writeToURL:(NSURL *)url atomically:(BOOL)useAuxiliaryFile encoding:(NSStringEncoding)enc error:(NSError * _Nullable *)error;

  7. 获取长度

    • 获取UTF-16 code unit长度
      @property(readonly) NSUInteger length。不是打印出来字符的长度。
    • 使用某种编码格式编码,比特数组的长度。
      - (NSUInteger)lengthOfBytesUsingEncoding:(NSStringEncoding)enc; 时间复杂度O(n)
    • 使用某种格式编码,比特数组的不精确上界。
      - (NSUInteger)maximumLengthOfBytesUsingEncoding:(NSStringEncoding)enc;。时间复杂度O(1).
  8. 获取UTF-16编码单位的数组

    • - (void)getCharacters:(unichar *)buffer range:(NSRange)range;
      buffer必须足够大。
    • - (BOOL)getBytes:(void *)buffer maxLength:(NSUInteger)maxBufferCount usedLength:(NSUInteger *)usedBufferCount encoding:(NSStringEncoding)encoding options:(NSStringEncodingConversionOptions)options range:(NSRange)range remainingRange:(NSRangePointer)leftover;
      这个方法不会crash。
  9. 获取C字符串(以NULL结尾的字符串)
    调用之前先使用- (BOOL)canBeConvertedToEncoding:(NSStringEncoding)encoding;方法确定是否可以无失真的编码。

    这些方法都不要调用UTF-16,UTF-32编码格式,因为这些包括NULL字节。

    • - (const char *)cStringUsingEncoding:(NSStringEncoding)encoding;
      这个字符串会在调用者被dealloc之前有效,delloc之后无效。
    • - (BOOL)getCString:(char *)buffer maxLength:(NSUInteger)maxBufferCount encoding:(NSStringEncoding)encoding;
      buffer需要自己分配内存,因此生命周期自己控制。
  10. 字符串的比较

    • - (NSComparisonResult)compare:(NSString *)string options:(NSStringCompareOptions)mask range:(NSRange)rangeOfReceiverToCompare locale:(id)locale;
      比较字符串时的选项

      • NSCaseInsensitiveSearch
      • NSLiteralSearch
      • NSBackwardsSearch
      • NSAnchoredSearch
      • NSNumericSearch
      • NSDiacriticInsensitiveSearch
      • NSWidthInsensitiveSearch
      • NSForcedOrderingSearch
      • NSRegularExpressionSearch
    • 前缀后缀
      • - (BOOL)hasSuffix:(NSString *)str;
      • - (BOOL)hasSuffix:(NSString *)str;
    • 是否相同
      - (BOOL)isEqualToString:(NSString *)aString;
      这个方法比isEqual:方法要快一些。
  11. 组合字符串

    • stringByAppendingFormat:
    • - (NSString *)stringByPaddingToLength:(NSUInteger)newLength withString:(NSString *)padString startingAtIndex:(NSUInteger)padIndex;
      padStringpadIndex开始填充。

      • [@"abc" stringByPaddingToLength: 9 withString: @"." startingAtIndex:0];
        // Results in "abc......"
      • [@"abc" stringByPaddingToLength: 2 withString: @"." startingAtIndex:0];
        // Results in "ab"
      • [@"abc" stringByPaddingToLength: 9 withString: @". " startingAtIndex:1];
        // Results in "abc . . ."
        // Notice that the first character in the padding is " "。因为@". "的charAtIndex:1是" "。
  12. 分隔字符串

    • 根据分隔符生成数组。

      • - (NSArray<NSString *> *)componentsSeparatedByString:(NSString *)separator;
      • - (NSArray<NSString *> *)componentsSeparatedByCharactersInSet:(NSCharacterSet *)separator;
    • 去掉字符串前后的指定字符
      • - (NSString *)stringByTrimmingCharactersInSet:(NSCharacterSet *)set;
    • 取字符串的一部分
      - (NSString *)substring***类的方法
  13. 查找字符串

    • 字符查找
      - (NSRange)rangeOfCharacterFromSet:(NSCharacterSet *)searchSet options:(NSStringCompareOptions)mask range:(NSRange)rangeOfReceiverToSearch;
    • 字符串查找
      - (NSRange)rangeOfString:(NSString *)searchString options:(NSStringCompareOptions)mask range:(NSRange)rangeOfReceiverToSearch locale:(NSLocale *)locale;
    • 按行枚举
      - (void)enumerateLinesUsingBlock:(void (^)(NSString *line, BOOL *stop))block;
    • 按照NSStringEnumerationOptions枚举
      - (void)enumerateSubstringsInRange:(NSRange)range options:(NSStringEnumerationOptions)opts usingBlock:(void (^)(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop))block;
      常见的NSStringEnumerationOptions

      • NSStringEnumerationByLines
      • NSStringEnumerationByParagraphs(段落分隔符是什么)
      • NSStringEnumerationByComposedCharacterSequences
        一个emoji表情包括若干UTF6 code unit,这个可以按照emoji表情来枚举。
      • NSStringEnumerationByWords
      • NSStringEnumerationBySentences
      • NSStringEnumerationReverse(反向)
      • NSStringEnumerationSubstringNotRequired(不会有substring传入到block中,出于性能考虑)
      • NSStringEnumerationLocalized
  14. 字符串替换

    • `- (NSString *)stringByReplacingOccurrencesOfString:(NSString *)target withString:(NSString *)replacement options:(NSStringCompareOptions)options range:(NSRange)searchRange;
  15. 分行和分页

    • 分行符

      • U+000A Unicode Character 'LINE FEED (LF)' (\n)
      • U+000D Unicode Character 'CARRIAGE RETURN (CR)' (\r)
      • U+0085 Unicode Character 'NEXT LINE (NEL)'
      • U+2028 Unicode Character 'LINE SEPARATOR'
      • U+2029 Unicode Character 'PARAGRAPH SEPARATOR'\r\n, in that order (also known as CRLF)
    • 分段符
      • ?????
  16. ComposedCharacter

    我理解就是由多个UTF16 code unit表示的字符。为了避免被截断,需要确定包含指定index的完整的ComposedCharacter。
    - (NSRange)rangeOfComposedCharacterSequenceAtIndex:(NSUInteger)index;

  17. 确定String在屏幕上的大小

    - (CGSize)sizeWithAttributes:(NSDictionary<NSString *,id> *)attrs;

    这个函数返回的包括小数,因此需要对返回值调用ceil函数。

  18. stringByFoldingWithOptions:locale????

  19. 找到共同的前缀

    - (NSString *)commonPrefixWithString:(NSString *)str options:(NSStringCompareOptions)mask;

  20. 编码相关

    • 是否可以以某种形式无失真编码
      - (BOOL)canBeConvertedToEncoding:(NSStringEncoding)encoding;
    • 根据NSData来探测这个NSData的编码格式
      + (NSStringEncoding)stringEncodingForData:(NSData *)data encodingOptions:(NSDictionary<NSStringEncodingDetectionOptionsKey,id> *)opts convertedString:(NSString * _Nullable *)string usedLossyConversion:(BOOL *)usedLossyConversion;
      探测编码格式时的选项String Encoding Detection Options

      • suggestedEncodingsKey
        建议探测的编码格式。是NSSNumebr的数组。会优先考虑这些编码格式。
      • disallowedEncodingsKey
        不允许的编码格式。是NSNumber的数组。
      • useOnlySuggestedEncodingsKey
        是否只允许探测建议的编码格式。
      • allowLossyKey
        是否允许失真解码。
      • fromWindowsKey
        是否考虑Windows编码格式
      • lossySubstitutionKey
        失真解码下,不支持的字符被什么替代。是一个NSString对象,默认是U+FFFD
      • likelyLanguageKey
        NSdata可能来来源语言。two-letter ISO 639-1 language code,NSString对象。
    • 转化为NSData
      - (NSData *)dataUsingEncoding:(NSStringEncoding)encoding allowLossyConversion:(BOOL)lossy;
    • 无失真编码下的最快编码格式
      @property(readonly) NSStringEncoding fastestEncoding;
    • 无失真编码格式下占用空间最小的格式
      @property(readonly) NSStringEncoding smallestEncoding
  21. URL相关

    • URL编码
      - (NSString *)stringByAddingPercentEncodingWithAllowedCharacters:(NSCharacterSet *)allowedCharacters;
    • 去除URL编码
      @property(readonly, copy) NSString *stringByRemovingPercentEncoding;
  22. 文件路径相关

    • 把字符串用路径分隔符连接起来
      class func path(withComponents components: [String]) -> String
    • 把路径用分隔符分隔,得到数组
      var pathComponents: [String] { get }
    • 把路径表示成系统形式的c字符串

      @property(readonly) const char *fileSystemRepresentation;

      char filenameBuffer[13];
      BOOL success;
      success = [@"/mach_kernel" getFileSystemRepresentation:filenameBuffer maxLength:12];
      // success == NO
      // Changing the length to include the NULL character does work
      success = [@"/mach_kernel" getFileSystemRepresentation:filenameBuffer maxLength:13];
      // success == YES
    • 获取最后一个路径名字

      @property(readonly, copy) NSString *lastPathComponent;

    • 路径扩展名

      @property(readonly, copy) NSString *pathExtension;

    • 处理~

      • ~扩展为绝对路径
        @property(readonly, copy) NSString*stringByExpandingTildeInPath;
      • 绝对路径缩写~
        @property(readonly, copy) NSString *stringByAbbreviatingWithTildeInPath;
    • 在路径名后加子路径

      - (NSString *)stringByAppendingPathComponent:(NSString *)str;

    • 路径后加后缀

      - (NSString *)stringByAppendingPathExtension:(NSString *)str;

    • 删除最后一段路径

      @property(readonly, copy) NSString *stringByDeletingLastPathComponent;

    • 删除路径后缀

      @property(readonly, copy) NSString *stringByDeletingPathExtension;

    • 解析符号链接(快捷方式)

      @property(readonly, copy) NSString *stringByResolvingSymlinksInPath;

    • 标准化路径

      @property(readonly, copy) NSString *stringByStandardizingPath;

      • 扩展~号为绝对路径
      • 如果可以,移除起始的“/private/var/automount”, “/var/automount”“/private”
      • 处理///./
      • 移除最后一个路径段的尾斜线
      • 处理符号链接如../
  23. 更多知识

NSString学习的更多相关文章

  1. iOS阶段学习第14天笔记(NSString与NSMutableString)

    iOS学习(OC语言)知识点整理 一.OC字符串的操作 1)OC中字符串分为两种: 1.不可变字符串NSString:不能修改对象内容,但是可以改变对象的指针. 2.可变字符串NSMutableStr ...

  2. NSString字符串类型-学习总结

    1.字符串的创建 (1)创建常量字符串 NSString *str = @"This is a String"; //str是变量名 (2)创建空的字符串,给字符串赋值 NSStr ...

  3. OC本学习笔记Foundation框架NSString与NSMutableString

       一.NSString与NSMutableString         相信大家对NSString类都不陌生.它是OC中提供的字符串类.它的对象中的字符串都是不可变的,而它的子类NSMutable ...

  4. Object C学习笔记8-字符串NSString之二

    5. 字符串是否包含 hasPrefix 判断字符串是否以某个字符串开头 hasSuffix 判断字符串是否以某个字符串结尾 NSString *str1=@"Object C学习正在进行中 ...

  5. OC之NSString、NSMutableString学习笔记 常用方法

    NSString篇: 1.字符串连接 NSString *beijing = @"北京"; NSString *welcome = [beijing stringByAppendi ...

  6. iOS学习13之OC NSString类

    C语言中,字符串是有char(ASC||码)字符组成. OC中,字符串是由unichar(Unicode)字符组成. 1.字符串(NSString) NSString:不可变字符串,即:创建以后,内容 ...

  7. (转载)OC学习篇之---Foundation框架中的NSString对象和NSMutableString对象

    在之前的一篇文章中我们说到了Foundation框架中的NSObject对象,那么今天在在来继续看一下Foundation框架中的常用对象:NSString和NSMutableString. 在OC中 ...

  8. Objective-C学习篇06—NSString与NSMutableString

    NSString OC提供了定义字符串对象的方法,也就是将想要表达的字符串用一对双引号引起来,并在开头加上@.@是OC中的指令符,它告诉编译器@以后的内容为OC中的语法.比如@”Harbingwang ...

  9. iOS学习 NSString常用技巧

    字符串是程序设计最常用的数据类型之一了.在Mac/iPhone编程中,苹果为我们提供了一个不同的字符串类型NSString.有别与普通的String为数据类型,NSString其实是一个对象类型.NS ...

随机推荐

  1. 百度统计接口demo中错误

    百度统计接口中的demo(PHP版本)下载下来配置后运行出错,应该是编写demo时用的php版本比较低吧,作如下几处修改就好了 一:把CURLOPT_SSL_VERIFYHOST的值改为2,因为1版本 ...

  2. QQ JS_SDk相关功能接口

    一.实现QQ登录功能 <!DOCTYPE html><html lang="zh-cn">   <head>      <meta htt ...

  3. 网络编程之socket新解

    由于工作并不是很忙,闲暇之余就读了下tomcat的源代码.我是从事java服务器开发工作的,大体的一些服务器线程模型我都是了解的.其大部分都是由一个线程调用监听端口等待客户端的链接,建立连接后再交由其 ...

  4. 开源服务专题之--------mysql的编译安装

    为什么选择MySQL 1:mysql性能卓越,服务稳定,很少出现异常宕机 2:mysql开源免费,无版权制约,自主性及使用成本低 3:产品耦合度,mysql支持多种操作系统,支持多开发语言,特别是ph ...

  5. mysql 二进制日志后缀数字最大为多少

    之前看到mysql二进制日志后面会加一个以数字递增为结尾的后缀,一直在想当尾数到达999999后会发生什么情况,先查了一下官网,对后缀有这样一句介绍:The server creates binary ...

  6. Redis使用总结(3):实现简单的消息队列

    参考Redis实现简单消息队列 Redis提供了两种方式来作消息队列.一个是使用生产者消费模式模式,另外一个方法就是发布订阅者模式.前者会让一个或者多个客户端监听消息队列,一旦消息到达,消费者马上消费 ...

  7. C#--访问修饰符

  8. chm转换为html的超简单方法

    在Windows下chm转换为html的超简单方法(反编译CHM文件的方法) 通过调用Windows命令,将chm 文件转换为html 文件. 方法: 命令行(cmd),输入hh -decompile ...

  9. 如何在Winform界面中设计图文并茂的界面

    在Winform里面,很多控件元素都是标准的,如图标.按钮.工具栏等等,所以一般设计标准的Winform界面比较快捷,但是往往这样的界面相对单调一些,特别在界面控件比较少的情况下,我们往往需要加入一些 ...

  10. 一些C#实用的方法汇总

    代码如下: /// <summary> /// 过滤字符串方法,用于将单引号等特殊符号转化成中文符号 /// </summary> /// <param name=&qu ...