NSArray和NSMutableArray的常用方法 (转)

(2013-09-06 15:13:46)

标签:

it

分类: ios编程
初始化方法:
   1.init返回一个空数组
    2.initWithArray从已有数组初始化
    3.initWithContentsOfFile//从plist文件加载
    4.initWithContentsOfUrl//从网络地址上获取
    5.initWithObject用一个对象初始化
    6.initWithObjects从多对象初始化
  
   self.theDataArray=[[NSMutableArray alloc]initWithCapacity:5];//指定有五个元素初始化
                             
        
   
   打印第一个元素:
    NSLog(@"the object  is:%@",[theDataArray firstObjectCommonWithArray:theDataArray]);
 
   打印最后一个元素:
   NSLog(@"the object  is:%@",[theDataArray lastObject]);
  
     枚举所有元素,方法一:
      for (NSString * theStr in theDataArray) {
        NSLog(@"%@:",theStr);
       }
  
   枚举所有元素,方法二:
       for (int i=0,i<[theDataArray count],i++) {
      //NSLog(@"%@:",[theDataArray objectAtIndex:i]);
         }
    
   枚举所有元素,方法三,用枚举器:
   NSEnumerator *enumerator=[theDataArray objectEnumerator];
    id obj;
    while (obj =[enumerator nextObject]) {
       NSLog(@"%@",obj);
  }
  
   
      //添加元素
   [theDataArray addObject:@"这是新添加的元素"];//从最后开始添加
     
   
    //从指定索引插入元素
    [theDataArray insertObject:@"this is inerted object" atIndex:0];//是插入到指定 索引的前面
   
   
   
    //修改.更新元素
    [theDataArray replaceObjectAtIndex:0 withObject:@"new obj"];//指定索引修改
   
   
    //判断数组是否包含某个对象
    
   if ([theDataArray containsObject:@"selectiont"]) {
       NSLog(@"the object selection is contained in array");
   }
   else{
       NSLog(@"not contain");
   }
  
    //获取元素索引
   NSLog(@"the idx is:%i",[theDataArray indexOfObject:@"selection"]);
  
   
   //数组元素排序
    
    方法一:

     
  
  
NSArray *theTempArr=[[NSArray alloc] initWithArray:[theDataArray
sortedArrayUsingSelector:@selector(caseInsensitiveCompare:)]];
 
   //[theDataArray sortedArrayUsingSelector:@selector(caseInsensitiveCompare:)];  // or @selector(compare:)
   
  //数组元素排序
    方法二:

    
    NSLog(@"before sorted array:%@",theDataArray);
   NSCountedSet *cset=[[NSCountedSet alloc] initWithArray:theDataArray];
   
    NSArray *theTempArr=[[NSArray alloc] initWithArray:[[cset allObjects]sortedArrayUsingSelector:@selector(compare:)]];
     
   NSLog(@"after sorted array:%@",theTempArr);
     
   //对数组对象进行排序   NSSortDescriptor
   NSSortDescriptor *sortDescriptor=[[NSSortDescriptor alloc] initWithKey:@"name" ascending:YES];//@“name”是对象属性
   [theDataArray sortUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];//返回排序好的数组

//还可以用自定义方法:[theDataArray sortUsingSelector:@selector(custom Method:)];
-(NSInteger)customMethod:(someObject *)otherObj{
  NSCompareResult compareResult=[self.name compare:otherObj.name];
 if(compareResult == NSOrderedSame)  return 0;
if(compareResult == NSOrderedAscending)  return 1;
 else return -1;
}

  //对象数组过滤(NSPredicate)

NSArray  *keyArray=[[NSArray alloce]initWtihObjects:@"A",@"B",nil];
 for (NSString *key in keyArray)
    {
 //定义规则:
  
NSPredicate *apredicate=[NSPredicate predicateWithFormat:@"SELF.name
beginswith[c]  %@",key]; //SELF.name是对象属性,beginswith[c]  %@",key
表示选出name以key开头的对象
 //或者 :
NSPredicate *apredicate=[NSPredicate
predicateWithFormat:@"SELF.name contains [c]  %@",key]; //contains[c]  
%@",key 表示选出name中包含有key的对象
 //或者 :
NSInteger age=20;
NSPredicate *apredicate=[NSPredicate predicateWithFormat:@"SELF.age >  %i",age]; // 表示选出age>20的对象

//或者 :
NSString * matchStr=@"hel*";
NSPredicate *apredicate=[NSPredicate predicateWithFormat:@"SELF.name  like %@",matchStr]; // 表示选出name中包含与字符串matchStr相似的对象

NSArray *newArr=[theDataArray filteredArrayUsingPredicate:apredicate];
        [theDataDict setValue:newArr forKey:key];
      }

 //删除数组元素
NSMutableArray *tempArray=[[NSMutableArray alloc]initWithObjects:@"one",@"tow",@"threr",nil];
[tempArray removeObjectAtIndex:0];//从指定索引移除
[tempArray removeAllObjects];//移除所有元素
 [tempArray removeLastObject];//移除最后那个元素
 [tempArray removeObjectsInArray:newArray];//移除指定数组中元素
  [tempArray  removeObjectsAtIndexes: NSIndexSet *__strong)];//从所选择的索引中移除

NSArray和NSMutableArray的常用方法 (转)的更多相关文章

  1. 数组NSArray与NSMutableArray的常用方法

    数组中可以放任何类型的数据,并且一个数组中的元素类型可以不一致.只要是(id类型)对象. NSArray 1.初始化 NSArray *array = @[]; 2.初始化,最后需要以nil结尾 NS ...

  2. NSArray和NSMutableArray相互转换, 以及常用方法-备

    有时候项目中NSArray和NSMutableArray需要相互转化,下面给出相关代码1.NSArray 1.1 转化:NSMutableArray 1 NSMutableArray *mutable ...

  3. iOS阶段学习第15天笔记(NSArray与NSMutableArray 数组)

    iOS学习(OC语言)知识点整理 一.OC中的数组 1)数组:也是一个对象,数组中存放的是对象的地址,可以存放任意类型对象的地址,只能是对象不能是具体的数值,数组是有序的,      可以存放重复的元 ...

  4. IOS数组NSArray与NSMutableArray知识点

    此文是对数组NSArray与NSMutableArray知识点的总结,主要是一些常见的操作,别外一些操作见其相应的文档,下面的代码部分还运用的第三方插件BlocksKit相结合: a:Foundati ...

  5. NSArray和NSMutableArray

    //1. NSArray EOItems *eOItems = [[EOItems alloc] init]; eOItems.ID = [NSNumber numberWithInt:]; NSAr ...

  6. NSArray、NSMutableArray基本用法

    NSArray.NSMutableArray基本用法 一.基本操作 初始化方法:1.init返回一个空数组 2.initWithArray从已有数组初始化 3.initWithContentsOfFi ...

  7. 15.Object-C--浅谈Foundation框架OC数组NSArray与NSMutableArray

    昨天总结了一下NSString与NSMutableString,今天我在这里总结一下NSArray与NSMutableArray. NSArray数组是:不可变数组. nil 是数组元素结束的标记.O ...

  8. NSArray 与 NSMutableArray 的排序

    由于集合的使用过程中,经常需要对数组进行排序操作,此博客用于总结对在OC中对数组排序的几种方法 1.当数组中存放的是Foundation框架中提供的对象时,直接使用 compare:方法 如:NSSt ...

  9. NSArray、NSMutableArray和NSMutableDictionary的用法

    转自:http://www.cnblogs.com/wangpei/admin/EditPosts.aspx?opt=1 NSArray是静态的数组,就是它所指向的内容是不可改变的,它指向一段内存区域 ...

随机推荐

  1. count() 方法

    count() :方法用于统计字符串里某个字符出现的次数.可选参数为在字符串搜索的开始与结束位置. num1,num2 = input('请输入字符串:'),input('请输入要查询的子串:') p ...

  2. Python之协程函数

    Python之协程函数 什么是协程函数:如果一个函数内部yield的使用方法是表达式形式的话,如x=yield,那么该函数成为协程函数. def eater(name): print('%s star ...

  3. 用python爬取一张仓鼠图片

    一. 找到一张仓鼠图片并复制一下它的url url='http://img.go007.com/2017/08/16/c407f5b732f4e748_2.jpg' 二. 调用urllib库 impo ...

  4. 《ajax学习》之ajax+JavaScript事件验证用户名是否可注册

    当用户注册时,服务器数据库需要对用户输入的用户信息(以用户名为例子)进行验证,在不刷新页面的情况下又需要页面和服务器进行数据请求,最好的方法是用ajax异步请求. 一.实现思路: 1.用户输入信息 2 ...

  5. POJ-1988Cube Stacking/HDU-2818Building Block;

    Cube Stacking Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 23283   Accepted: 8166 Ca ...

  6. Automation 的 ReportFlow

    ReportFlow: // click the Grid icon and switch to grid page public void changeToGrid() // click the A ...

  7. noip模拟赛 入阵曲

    分析:其实很容易想到O(n^3m^3)的算法,枚举x1,x2,y1,y2,再统计一下和.求和可以用前缀和,能优化到O(n^2m^2),能得到60分.对于特殊性质的点,求一下a[i][j]与k的最小公倍 ...

  8. NIST的安全内容自动化协议(SCAP)以及SCAP中文社区简介

    https://blog.csdn.net/langkew/article/details/8795530?utm_source=tuicool&utm_medium=referral

  9. Codeforces Round #343 (Div. 2)【A,B水题】

    A. Far Relative's Birthday Cake 题意: 求在同一行.同一列的巧克力对数. 分析: 水题~样例搞明白再下笔! 代码: #include<iostream> u ...

  10. Minimum Path Sum(DFS,DP)

    Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which ...