iPhone开发笔记——NSArray 排序

转载自:http://hi.baidu.com/306996305/blog/item/6724152a9b249383033bf657.html

NSArray 不能像 stl  vector 那样排序,毕竟NSArray 里面存储的东西什么都有 都是NSObject嘛

但是NSArray 提供了很多接口用于排序..
这里介绍一种.
嗯,为什么介绍这种呢,因为很像 stl 的 sort
自己去写个compare函数就好了,排序规则什么的自己写~
//
//  main.m
//  test
//
//  Created by TXX on 11-6-9.
//  Copyright 2011年 __MyCompanyName__. All rights reserved.
//


#import <Foundation/Foundation.h>
#import <time.h>


NSInteger Compare(id num1, id num2, void *context)
{
    int value1 = [num1 intValue];
    int value2 = [num2 intValue];
    
    if (value1 < value2)
        return NSOrderedAscending;
    else  if (value1 > value2)
        return NSOrderedDescending;
    else return NSOrderedSame;
}


int main (int argc, const char * argv[])
{
    srand((unsigned int)time(NULL));
    NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];


    NSMutableArray *Arr = [[NSMutableArray alloc] init];
    for (int i=0; i<10; i++)
    {   
        int x = rand() / 32767;
        [Arr addObject:[NSNumber numberWithInt:x]];
    }
    
    for (NSNumber *i in Arr)
    {
        NSLog(@"%d", [i intValue]);
    }
    
    NSLog(@"After sort!");
    
    Arr = [Arr sortedArrayUsingFunction:Compare context:NULL];
    
    for (NSNumber *i in Arr)
    {
        NSLog(@"%d", [i intValue]);
    }
    
    [pool drain];
    return 0;
}



posted on 2012-06-12 09:59  yang3wei  阅读(210)  评论(0)    收藏  举报