数组

用来存贮对象的有序列表,它是不可变的

不能存数C语言的基本数据类型

只支持OC对象


#pragma mark Create a array

//Initialize NSArray

void arrayCreate(){

//Create an empty array

NSArray *array=[NSArray array];// static method create static Array no need to release

//empty can’t add boz it can’t be changed

//Create a array with one object

array=[NSArray arrayWithObject:@”123”];

//nil 代表我们元素的结束

array=[NSArray arrayWithObjects:@“a”,@”b”,@”c”,nil];

//3 elements. You can’t  add a nil element, nil represent end of the array

//All above three methods need no release.

NSArray arrar1=[[NSArray alloc]init];

[array1 release];

//Check how many elements in array

unsigned int count =[array count]; //count is a get method ==

//unsigned  int  count=array.count;

NSLog(@”%i”,count);

}


#pragma mark use the array

void arrayUse(){

//Whether contain certain element

array=[NSArray arrayWithObjects:@“a”,@”b”,@”c”,nil];

if([array containsObject:L@”a”]){

NSLog(@”Contain a”);

}

//Return last element

NSString *last=[array lastObject];

NSLog(@”last is %@”,last);

//Get element from certain position

NSLog(@” Element in postion 1 is %@”,[array objectAtIndex:1]);

//Search the position of certain object ( and with range)

NSLog(“Positon of c is %i”,[array indexOfObject:@”c”]);

NSObject *obj=[[[NSObject alloc]init]autorelease];

array1=[NSArray arrayWithObjects:@“a”,@”b”,@”c”,@”a”,obj,nil];

NSRange range=NSMakeRange(0,2);

NSLog(“Positon of a is %i”,range);

}


//put Student Object

Student.h

-(void)dealloc{

NSLog(@”%@ is destroied”,self);

[super dealloc];

}

Student.m

#import “Student.h”

// pragma mark memory management about array addition

 

void arrayMemory(){

//If u insert an Object into an array , counter will retain once

Student *stu1=[[Student dealloc]init]; //counter =1
Student *stu2=[[Student dealloc]init];

//counter =1

Student *stu3=[[Student dealloc]init];

//counter =1

NSArray array=[[NSArray alloc]initWithObjects:stu1,stu2,stu3,nil];//counter=2

NSLog(@”count=%zi”,array.count);

NSLog(@”counter of stu1 ,stu2,stu3 is %zi, %zi, %zi”,[stu1 retainCount],[stu2 reytainCount],[stu3 retainCount]);// 2

[array release];

//When an array is deroied , all object counter inside the array will be release once

[stu1 release];

[stu2 release];

[stu3 release];

}


//NSArray 的比较

-(BOOL)isEqualToArray:(NSarray *)otherArray

//比较两个数组的内容是否相同

-(id)firstObjectCommonWithArray:(NSarray *)otherArray

//return the first same Object of two Array

 


#pragma mark send message to Object in Array

//-(void)makeObjectsPerformSelector:(SEL)aSelector

//-(void)makeobjectsperformSelector:(SEL)aSelector withobject:(id)argument

//让数组里面所有元素都执行aSelector 这个方法

Student.h

@interface Student:NSobject

-(void)test;

-(void)test2:(NSString *)str;

+(id)student;

@end

Student.m

@implementation

+(id)student{

 return [[[Student alloc]init]autorelease];

}

-(void)test{

NSLog(@“%@->test”,self);

}

-(void)test2:(NSString *)str{

NSLog(@”%@->%@”,self,str);

}

-(void)dealloc{

NSLog(@”%@ is destroied”,self);

}

@end

#pragma mark  Send message to element inside array

main.m

void arrayMeaagae(){

Student *stu1=[Student student]; //+ no nee release

Student *stu2=[Student student];

Student *stu3=[Student student];

NSArray *array=[NSArray arrayWithObjects:stu1,stu2,stu3,nil];  //+

//All the object call method test

[array makeObjectsPerformSelector:@selector(test)];

//All the object call method test with a parameter

[array makeObjectsPerformormSelector:@selector(test2:)withObject:@”123”];

}


//pragma mark  traverse array

void arrayFor1(){

Student *stu1=[Student student];

NSArray *array=[NSArray arrayWithObjects:stu1,@”1”,@”2”,@”3”,nil];

//id==void *

int count=array.count;

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

id obj=[array objectAtIndex:i];

NSLog(@”%i->%@”,i,obj);

}

}

//pragma mark  traverse array2

void arrayFor2(){

Student *stu1=[Student student];

NSArray *array=[NSArray arrayWithObjects:stu1,@”1”,@”2”,@”3”,nil];

//id==void *

int i=0;

for(id obj in array){

NSLog(@”%i->%@”,i,obj);

if(i==1)

break;

i++;

}

}

//pragma mark  traverse array3 block

void arrayFor3){

Student *stu1=[Student student];

NSArray *array=[NSArray arrayWithObjects:stu1,@”1”,@”2”,@”3”,nil];

[array enumerateObkectUsingBlock:

^(id obj,NSUInteger idx,BOOL *stop){

NSLog(@”%i->%@”,idx,obj);

if(idex==1){

*stop=YES;}    //stop traverse

}

];

}

//Tips: 平时写代码dealloc方法中最好打印一下,这样可以看出对象有没有被销毁,然后可以检测有没有内存泄露。


#pragma mark NSEnumerator

//集合的迭代器,可用于遍历集合元素

//NSArray有相应的方法来可以获取迭代器

//-(NSEnumerator *)objectenumerator

//获取一个正的迭代器

//-(NSEnumerator *)reverseobjectenumerator

//获取一个反序遍历的迭代器

//常用方法

//-(id)nextobject  

//attain next object

//-(NSArray *)allobjects

//attatain all objects

 

//pragma mark  traverse array4 enumerator

void arrayFor4(){

Student *stu1=[Student student];

NSArray *array=[NSArray arrayWithObjects:stu1,@”1”,@”2”,@”3”,nil];

NSEnumerator *enumerator=[array objectEnumerator];

//NSEnumerator *enumerator=[array reverseObjectEnumerator];

id obj=nil;

while(obj=[enmurator nextObject]){

NSLog(@”obj=%@”,obj);

}

NSArray array2=[enumerator allObjects];

//Should put in frond of traverse otherwise nil

//它是取出没有被遍历过得对象

NSLog(@”array2:%@”,array2);

}

NSArray 的创建和遍历的更多相关文章

  1. [OC Foundation框架 - 7] NSArray的创建与遍历

    NSArray是不可变的,不能先创建再添加元素 NSArray可以放入任何OC对象,但不能放入基本数据类型.结构体.枚举等非OC对象 不能存储nil   A.常用方法1 创建 返回用量 是否含有某元素 ...

  2. NSArray与NSMutableArray 数组与可变数组的创建和遍历 复习

    1.NSArray 是一个父类,NSMUtableArray是其子类,他们构成了OC的数组. 2.NSArray的创建 NSArray * array = [[NSArray alloc]initWi ...

  3. C++ 创建和遍历二叉树

    一个简单的创建和遍历二叉树的C++程序,二叉树的其他操作程序待更新. #include <iostream> using namespace std; struct BiTNode{ ch ...

  4. 图的创建和遍历(BFS/DFS)

    图的表示方法主要有邻接矩阵和邻接表.其中邻接表最为常用,因此这里便以邻接表为例介绍一下图的创建及遍历方法. 创建图用到的结构有两种:顶点及弧 struct ArcNode { int vertexIn ...

  5. c/c++二叉树的创建与遍历(非递归遍历左右中,破坏树结构)

    二叉树的创建与遍历(非递归遍历左右中,破坏树结构) 创建 二叉树的递归3种遍历方式: 1,先中心,再左树,再右树 2,先左树,再中心,再右树 3,先左树,再右树,再中心 二叉树的非递归4种遍历方式: ...

  6. c/c++叉树的创建与遍历(非递归遍历左右中,不破坏树结构)

    二叉树的创建与遍历(非递归遍历左右中,不破坏树结构) 创建 二叉树的递归3种遍历方式: 1,先中心,再左树,再右树 2,先左树,再中心,再右树 3,先左树,再右树,再中心 二叉树的非递归4种遍历方式: ...

  7. python创建与遍历List二维列表

    python创建与遍历List二维列表 觉得有用的话,欢迎一起讨论相互学习~Follow Me python 创建List二维列表 lists = [[] for i in range(3)] # 创 ...

  8. JS实现图的创建和遍历

    图分为无向图和有向图 图的存储结构有邻接矩阵.邻接表.十字链表.邻接多重表这四种,最常用的是前两种 本篇主要是利用邻接矩阵实现无向图的创建和遍历(深度优先.广度优先),深度优先其实就是二叉树里的前序遍 ...

  9. [数据结构】【c语言】链表的创建和遍历

    第一次写代码的博客,一个刚刚接触的新手,来这里主要是为了记录自己,方便自己以后浏览,也欢迎大家指正.先来个简单的,动态链表的创建和遍历. #include<stdio.h> #includ ...

随机推荐

  1. MySQL5.7主从从配置

    主从从,也称为级联主从,数据流向:A(主)->B(从)->C(从从),主从从级联复制. 应用场景 在主从配置的基础上,再增加一个从库,进一步提高数据安全,容灾备份. 读写分离,从库只用于查 ...

  2. atomikos 优化JDBC性能

    JDBC performance comes for free with our pooling DataSource classes: AtomikosDataSourceBean for XA-e ...

  3. (六)Spring Boot之日志配置-logback和log4j2

    一.简介 支持日志框架:Java Util Logging, Log4J2 and Logback,默认是使用logback 配置方式: 默认配置文件配置 引用外部配置文件配置 二.默认配置文件配置( ...

  4. Spring Boot 项目集成 Alibaba Druid

    Druid 是一个非常好用的数据库连接池,但是他的好并不止体现在作为一个连接池加快数据访问性能上和连接管理上,他带有一个强大的监控工具:Druid Monitor.不仅可以监控数据源和慢查询,还可以监 ...

  5. c# 163网易发送邮件

    是4.0的,说以添加包是 代码: public class SendEmailInfo { /// <summary> /// 发送邮件 /// </summary> /// ...

  6. Flutter-现有iOS工程引入Flutter

    前言 Flutter 是一个很有潜力的框架,但是目前使用Flutter的APP并不算很多,相关资料并不丰富,介绍现有工程引入Flutter的相关文章也比较少.项目从零开始,引入Flutter操作比较简 ...

  7. Centos7下安装MongoDB4.0.10

    前言 模式自由 :可以把不同结构的文档存储在同一个数据库里 面向集合的存储:适合存储 JSON风格文件的形式 完整的索引支持:对任何属性可索引 复制和高可用性:支持服务器之间的数据复制,支持主-从模式 ...

  8. zend studio 13.6.1汉化包安装方法

    1.这里介绍的是离线汉化包的安装,在线汉化安装总是失败,还是离线的方便 2.汉化安装过程中系统可能会弹出报错,忽略就可以(反正我现在就是忽略了在用着) 下面图片中的链接就是在线安装的链接,不管是在线还 ...

  9. devops发展历程

    第一阶段:只有 Dev ,没有 Ops ,Dev 是全栈工程师 如何理解?最初的时候,产品和业务形态都处于摸索期,业务复杂度不高,访问量不大,软件能够尽快跑起来推向市场是最重要的,所以架构上不设计的很 ...

  10. JAVA遇见HTML——JSP篇(1、JAVA WEB简介)

    比如淘宝.新浪.搜狐.网易就是Web应用程序