Foundation框架之NSArray、NSDictionary、NSSet及其Mutable类型

目录

  • 概述——对Foundation框架集合类的理解
  • NSArray
  • NSDictionary
  • NSSet
  • NSArray、NSDictionary和NSSet的Mutable类型
  • Foundation框架中集合类的使用详见苹果官方文档
  • 集合类的实用操作

深层遍历

深层复制

  • 待研究

概述——对Foundation框架集合类的理解

NSArray

创建

NSArray *array = [NSArray arrayWithObjects:@"one",@"two",nil];

NSArray *array2 = @[@"one",@"two"];

访问NSArray中的元素(通过index)

array[index];

[array objectAtIndex:index];

返回NSArray的长度

[array count];

遍历NSArray

for(id obj in array){

  NSLog(@"%@",obj);

}

for(int i=0;i<[array count];i++){

  NSLog(@"%@",array[i]);

}

NSDictionary

创建

NSDictionary *dict = [NSDictionary dictionaryWithObjectsAndKeys:@"key1",object1,@"key2",object2,nil];

NSDictionary *dict2 = @{@"key1":object1,@"key2":object2};

注意:key和value都可以为类对象,不一定都是字符串;

访问NSDictionary中的元素(通过key值)

[dict objectForKey:key];

dict[key];

返回NSDictionary的长度

[dict count];

遍历NSDictionary(key和value都遍历)

for(id key in [dict allKeys]){

  NSLog(@"%@",key);

  NSLog(@"%@",dict[key]);

}

NSSet

创建

NSSet *set = [NSSet setWithObjects:@"1",@"2",nil];

返回NSSet的长度

[set count];

遍历NSSet

for(id obj in set){

  NSLog(@"%@",obj);

}

NSArray、NSDictionary和NSSet的Mutable类型

允许在创建对象之后对对象进行更改(插入和删除)操作

Foundation框架中集合类的使用详见苹果官方文档

集合类的实用操作

深层遍历

实现思路:增加对所包含的集合对象的处理,在此只对NSArray,NSDictionary,NSSet这三种集合类进行处理,如果有新需求可以增加新处理

+ (void)traverseDictionary:(NSDictionary *)dict{

for (id object in [dict allValues]) {

if ([object isKindOfClass:[NSArray class]]) {

[TraverseCollection traverseArray:object];

}

else if ([object isKindOfClass:[NSDictionary class]]){

[TraverseCollection traverseDictionary:object];

}

else if ([object isKindOfClass:[NSSet class]]){

[TraverseCollection traverseSet:object];

}

else{

NSLog(@"%@",object);

}

}

}

深层复制

与深层遍历类似

待研究

Foundation框架之NSArray、NSDictionary、NSSet及其Mutable类型的更多相关文章

  1. [转]一些NSArray,NSDictionary,NSSet相关的算法知识

    iOS编程当中的几个集合类:NSArray,NSDictionary,NSSet以及对应的Mutable版本,应该所有人都用过.只是简单使用的话,相信没人会用错,但要做到高效(时间复杂度)精确(业务准 ...

  2. OC学习篇之---Foundation框架中的NSDictionary类以及NSMutableDictionary类

    今天来看一下Foundation框架中的NSDictionary类,NSMutableDictionary类,这个和Java中的Map类很想,OC中叫字典,Java中叫Map,还有字典是无序的,这个和 ...

  3. [翻译] 用 ObjectiveSugar 扩展NSArray NSDictionary NSSet NSNumber

    source - https://github.com/supermarin/ObjectiveSugar Look like a girl, act like a lady, think like ...

  4. 黑马程序员——OC语言Foundation框架 (2) NSArray NSSet NSDictionary\NSMutableDictionary

    Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结) (一)NSArray 1>NSArray :不可变数组 ①创建方法 ...

  5. 一些NSArray,NSDictionary,NSSet相关的算法知识

    iOS编程当中的几个集合类:NSArray,NSDictionary,NSSet以及对应的Mutable版本,应该所有人都用过.只是简单使用的话,相信没人会用错,但要做到高效(时间复杂度)精确(业务准 ...

  6. Fouandation(NSString ,NSArray,NSDictionary,NSSet) 中常见的理解错误区

    Fouandation 中常见的理解错误区 1.NSString //快速创建(实例和类方法) 存放的地址是 常量区 NSString * string1 = [NSString alloc]init ...

  7. 遍历NSArray, NSDictionary, NSSet的方法总结

    1,for循环读取 NSArray: NSArray *array = /*…*/ ; i<array.count; i++) { id object = array[i]; // do sth ...

  8. Objective-C:Foundation框架-常用类-NSDictionary

    与NSString.NSArray一样,NSDictionary是不可变的,其对应可变类型为NSMutableDictionary.其用法如下: #import <Foundation/Foun ...

  9. [OC Foundation框架 - 8] NSArray排序

    1.派生 voidarrayNew() { NSArray*array = [NSArrayarrayWithObjects:",nil]; NSArray*array2 = [arraya ...

随机推荐

  1. select多个字段赋值给多个变量

    在存储过程中定义了变量v1 int;v2 int;v3 int;从表tab1选择3个字段f1,f2,f3赋值给这三个变量,要如何写 如果单个变量可以  select f1 into v1 from t ...

  2. The Stereo Action Dimension

    Network MIDI on iOS - Part 1   This is an app I wrote to try out some ideas for networked MIDI on iP ...

  3. AS3垃圾回收整理

    AS3垃圾回收整理 转自 http://bbs.wefdc.com/thread-2366-1-1.html 来源页面: http://www.adobe.com/devnet/actionscrip ...

  4. ajax 第一个程序

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  5. html5 canvas 像素随机百分之十显示

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  6. java线性表学习笔记(二)

    链表中的每一个元素都包含一个称为节点的结构,每向链表中增加一个元素,就会产生一个与之相关的节点,每个节点与它相邻的节点相连接(这是基础吧,不过在看c的时候没认真看,呼). 定义节点类如下(使用了泛型, ...

  7. HD1005Number Sequence

    Number Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tota ...

  8. CodeForces 7C Line

    ax+by+c=0可以转化为ax+by=-c: 可以用扩展欧几里德算法来求ax1+by1=gcd(a,b)来求出x1,y1 此时gcd(a,b)不一定等于-c,假设-c=gcd(a,b)*z,可得z= ...

  9. XML文件的生成与读取

    从数据库生成: public static void ToXML(string tablename) { //获取数据 string sql = "select * from " ...

  10. POJ3345

    http://poj.org/problem?id=3345 大意: 大意是说现在有n个城市来给你投票,你需要至少拿到m个城市的赞成票.想要获得第i个城市的赞成需要花费w[i],有个条件就是某些城市是 ...