转载自: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;
}