下面的例子以
NSArray *array = [NSArray arrayWithObjects:@"wendy",@"andy",@"tom",@"jonery",@"stany", nil];
1、獲取數組中總共有多少個對象。
- (NSUInteger)count;
NSLog(@"%d",[array count]); 2
2、獲取數組中下標對應的元素對象.(下標是從0開始) - (id)objectAtIndex:(NSUInteger)index;
3、在當前數據中追加一個新的對象,并且返回一個新的數據對象(新的數組對象和被追加的對象,是兩個不同的數組對象)。
- (NSArray *)arrayByAddingObject:(id)anObject;
4、在當前的數組中追加一個新的數據,并且返回一個新的數組對象。 - (NSArray *)arrayByAddingObjectsFromArray:(NSArray *)otherArray;
5、使用當前的數組生成一個字符串,新生成的字符串使用提供的separator 字符進行分割。 - (NSString *)componentsJoinedByString:(NSString *)separator;
[array compontsJoinedByString:@","];
運行結果: wendy,andy,tom,jonery,stany
6、檢測數據中是否包含指定的對象元素 - (BOOL)containsObject:(id)anObject;
[array containsObject:@"tom"]; YES
7、使用當前的數組生成字符串。可以重寫description 改變生成的字符串。相當于java 中的toString 方法。 - (NSString *)description;
運行結果
(
wendy,
andy,
tom,
jonery,
stany
)
8、根據設置的locale 進行連接數組 - (NSString *)descriptionWithLocale:(id)locale;
- (NSString *)descriptionWithLocale:(id)locale indent:(NSUInteger)level;
9、兩個數組的第一個元素是否相同,如果相同,則返回 數組中,第一個元素的字符串,反之,返回null 對象
- (id)firstObjectCommonWithArray:(NSArray *)otherArray;
10、 從數組中獲取 NSRange 對象的數據存放到objects 中,NSRange 的數據標示從location,開始后面length 個數據 - (void)getObjects:(id__unsafe_unretained [])objects range:(NSRange)range;
NSArray *array = [NSArray arrayWithObjects:@"wendy",@"andy",@"tom",@"jonery",@"stany",@"張山名稱",@"asdta", nil];
NSRange range = NSMakeRange(1, 5);
id *objects;
objects = malloc(sizeof(id) * range.length);
[array getObjects:objects range:range];
for(int i = 0; i < range.length; i++){
NSLog(@"%@",objects[i]);
}
free(objects);
運行的結果
andy
tom
jonery
stany
11、 判斷制定的anObject 對象是否存在數組中如果存在返回,對象所在的下標
- (NSUInteger)indexOfObject:(id)anObject;
如果不存在,返回的NSUInteger 與 NSNotFund 相同
NSUIndex index = [array indexOfObject:@"stan"];
if(index == NSNotFound)
{
對象不在數組中
}
11-1、 判斷制定的元素,是否在數組中,數組查詢的位置,是從range.location 的位置開始,到range.length 的長度結束。
- (NSUInteger)indexOfObject:(id)anObject inRange:(NSRange)range;
如果數據存在,返回指定的下標,如果不存在,則返回NSNotFund 。
實質是使用isEqual 進行比較
12、
同上面兩個方法一項,測試指定的對象是否在數組中不同的是,這里使用指針進行比較
- (NSUInteger)indexOfObjectIdenticalTo:(id)anObject;
如果數據存在,返回指定的下標,如果不存在,則返回NSNotFund 。 - (NSUInteger)indexOfObjectIdenticalTo:(id)anObject inRange:(NSRange)range;
13、比較兩個數組是否相同 ,數組長度相同,并且相同位置上的元素也相同。
(BOOL)isEqualToArray:(NSArray *)otherArray;
14、返回最有一個元素,如果一個數組的長度為0 返回的對象為nil(id)lastObject;
15、使用數組返回一個 NSEnumerator 對象,這個對象類似與一個指針,可以用來遍歷 整個數組 指針從前向后遍歷-
(NSEnumerator *)objectEnumerator;
示例如下
NSEnumerator *enu = [array objectEnumerator];id *obj;
while (obj = enu.nextObject) {
NSLog(@"obj===%@==",obj);
}
16、 返回一個NSEnumerator 對象,這個對象類似一個指針,可以用來遍歷真個數據,所不同的是,這個指針,是從后向前遍歷。 (NSEnumerator *)reverseObjectEnumerator;
17、生成一個NSData 的對象,主要是用來進行數組的排序。 在下面的方法中使用這個對象(NSData *)sortedArrayHint;
18、 進行數組的排序(NSArray )sortedArrayUsingFunction:(NSInteger ()(id,id, void *))comparator context:(void *)context;
這個方法類似蘋果實現了一個簡單的 排序方法。但是實現的規則需要自己進行處理。
類似的方法如下。 首先提供一個 普通的排序算法,函數和c 的方法類似
NSInteger sortType(id st,id str,void *cha)
{
NSString *s1 = (NSString *)st;
NSString *s2 = (NSString *)str;
if(s1.length > s2.length)
{
return NSOrderedAscending;
}else if(s1.length < s2.length)
{
return NSOrderedDescending;
}
return NSOrderedSame;
}
NSArray *array = [NSArray arrayWithObjects:@"wendy",@"andy",@"tom",@"test", nil];
NSArray *a = [array sortedArrayUsingFunction:sortType context:nil];
NSLog(@"a=%@",a);
NSArray 為需要排序的數組,返回一個排序完成的數組,再執行osrtedArrayUseingFunction 方法時會,會自動調用上面的sortType 方法,并且,可以按照你
的需要調整上面的規則
19、和上面的方法類似,也是蘋果用來進行排序的。所不同的是,需要傳入一個NSData 的數據。
- (NSArray )sortedArrayUsingFunction:(NSInteger ()(id,id, void *))comparator context:(void *)context hint:(NSData *)hint;
NSData *dat = [array sortedArrayHint];
NSArray *a = [array sortedArrayUsingFunction:sortType context:nil hint:dat];
NSLog(@"a=%@",a);