IOS之NSArray 中調用的方法詳解(1)

下面的例子以
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);
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容