zoukankan      html  css  js  c++  java
  • 字符串比较说明

    NSString 比较字符串,我介绍一些常用的方法:

    NSString *value = @"1234567890";

    比较的方法:

    [value compare:(NSString *)];

    [value compare:(NSString *) options:(NSStringCompareOptions)];

    [value compare:(NSString *) options:(NSStringCompareOptions) range:(NSRange)];

    传入的参数:

    compare:(NSString *)

    传入一个需要比较的字符串。

    例如 [value compare:@"1234567890"],返回 NSOrderedSame。

    options:(NSStringCompareOptions)

    传入 NSStringCompareOptions 枚举的值

    enum{

        NSCaseInsensitiveSearch = 1,//不区分大小写比较

        NSLiteralSearch = 2,//区分大小写比较

        NSBackwardsSearch = 4,//从字符串末尾开始搜索

        NSAnchoredSearch = 8,//搜索限制范围的字符串

        NSNumbericSearch = 64//按照字符串里的数字为依据,算出顺序。例如 Foo2.txt < Foo7.txt < Foo25.txt

    //以下定义高于 mac os 10.5 或者高于 iphone 2.0 可用

        ,

        NSDiacriticInsensitiveSearch = 128,//忽略 "-" 符号的比较

        NSWidthInsensitiveSearch = 256,//忽略字符串的长度,比较出结果

        NSForcedOrderingSearch = 512//忽略不区分大小写比较的选项,并强制返回 NSOrderedAscending 或者 NSOrderedDescending

    //以下定义高于 iphone 3.2 可用

        ,

        NSRegularExpressionSearch = 1024//只能应用于 rangeOfString:..., stringByReplacingOccurrencesOfString:...和 replaceOccurrencesOfString:... 方法。使用通用兼容的比较方法,如果设置此项,可以去掉 NSCaseInsensitiveSearch 和 NSAnchoredSearch

    }

    range:(NSRange)

    比较字符串的范围

     结构变量:

    location: 需要比较的字串起始位置(以0为起始)

    length: 需要比较的字串长度

    返回值:

    typedef enum _NSComparisonResult {
         NSOrderedAscending = -1,    // < 升序
         NSOrderedSame,              // = 等于
         NSOrderedDescending   // > 降序
    } NSComparisonResult;

    例子:版本号比较

        NSString *num1 = @"5.2.0";
        NSString *num2 = @"5.3.0";
     
        if ([num1 compare:num2 options:NSNumericSearch] == NSOrderedDescending)
        {
            ULog(@"%@ is bigger",num1);
        }else
        {
            ULog(@"%@ is bigger",num2);
        }

    解释:
    NSOrderedDescending是降序,如果numb1>numb2用这个函数相比较那么就等于降序。

    转自:http://blog.sina.com.cn/s/blog_916e0cff0102uyz1.html

  • 相关阅读:
    洛谷 P6599 「EZEC-2」异或 题解
    线段树懒标记以及标记永久化的两种实现方法(模板)
    洛谷P3834 【模板】可持久化线段树 1 题解
    Codeforces 1012B Chemical table (思维+二分图)
    HDU 6386 Age of Moyu (最短路+set)
    CodeForces 739B Alyona and a tree (二分+树上差分)
    Codeforces 444C DZY Loves Colors (线段树)
    HDU 5441 Travel (离线dsu)
    Codeforces 1000E We Need More Bosses (边双连通+最长链)
    CodeForces 219D Choosing Capital for Treeland (树形DP)经典
  • 原文地址:https://www.cnblogs.com/Sucri/p/5403439.html
Copyright © 2011-2022 走看看