OC语言之NSArray的使用

2024-08-22 11:18
文章标签 oc nsarray 语言 使用

本文主要是介绍OC语言之NSArray的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

# NSArray基本概念

##1.NSArray的基本概念

- 什么是NSArray?

    +NSArray是OC中的数组类,开发中建议尽量使用NSArray替代C语言中的数组

    +C语言中数组的弊端

       * int array[4] = {10, 89, 27, 76};

       * 只能存放一种类型的数据.(类型必须一致)

       * 不能很方便地动态添加数组元素、不能很方便地动态删除数组元素(长度固定)

- NSArray的使用注意

    +只能存放任意OC对象, 并且是有顺序的

    +不能存储非OC对象, 比如int\float\double\char\enum\struct等

    +它是不可变的,一旦初始化完毕后,它里面的内容就永远是固定的, 不能删除里面的元素, 也不能再往里面添加元素

---

##2.NSArray的创建方式

- \+ (instancetype)array;

- \+(instancetype)arrayWithObject:(id)anObject;

- \+ (instancetype)arrayWithObjects:(id)firstObj,...;

- \+ (instancetype)arrayWithArray:(NSArray*)array;

 

- \+ (id)arrayWithContentsOfFile:(NSString*)path;

- \+ (id)arrayWithContentsOfURL:(NSURL*)url;

---

 

##3.NSArray 的使用注意事项

- NSArray直接使用NSLog()作为字符串输出时是小括号括起来的形式。

- NSArray中不能存储nil,因为NSArray认为nil是数组的结束(nil是数组元素结束的标记)。nil就是0。0也是基本数据类型,不能存放到NSArray中。

```

   NSArray *arr = [NSArray arrayWithObjects:@"lnj", nil,@"lmj",@"jjj", nil];

   NSLog(@"%@", arr);

输出结果:

(

   lnj

)

---

##4.NSArray的常用方法

- \- (NSUInteger)count;

    +获取集合元素个数

- \- (id)objectAtIndex:(NSUInteger)index;

    +获得index位置的元素

- \- (BOOL)containsObject:(id)anObject;

    +是否包含某一个元素

- \- (id)lastObject;

    +返回最后一个元素

- \- (id)firstObject;

    +返回最后一个元素

- \-(NSUInteger)indexOfObject:(id)anObject;

    +查找anObject元素在数组中的位置(如果找不到,返回-1)

- \- (NSUInteger)indexOfObject:(id)anObjectinRange:(NSRange)range;

    +在range范围内查找anObject元素在数组中的位置

---

##5.NSArray的简写形式

- 自从2012年开始, Xcode的编译器多了很多自动生成代码的功能, 使得OC代码更加精简

- 数组的创建

    +之前

```

[NSArrayarrayWithObjects:@"Jack", @"Rose", @"Jim", nil];

```

    +现在

```

@[@"Jack", @"Rose",@"Jim"];

```

- 数组元素的访问

    +之前

```

[array objectAtIndex:0];

```

    +现在

```

array[0];

---

# 常见的结构体

##1.NSPoint和CGPoint

- CGPoint和NSPoint是同义的

```

typedef CGPoint NSPoint;

 

CGPoint的定义

struct CGPoint {

 CGFloat x;

 CGFloat y;

};

typedef struct CGPoint CGPoint;

typedef double CGFloat;

```

- CGPoint代表的是二维平面中的一个点

    +可以使用CGPointMake和NSMakePoint函数创建CGPoint

---

##2.NSSize和CGSize

- CGSize和NSSize是同义的

```

typedef CGSize NSSize;

 

CGSize的定义

struct CGSize {

 CGFloat width;

 CGFloat height;

};

typedef struct CGSize CGSize;

```

- CGSize代表的是二维平面中的某个物体的尺寸(宽度和高度)

    +可以使用CGSizeMake和NSMakeSize函数创建CGSize

---

##3.NSRect和CGRect

- CGRect和NSRect是同义的

```

typedef CGRect NSRect;

 

CGRect的定义

struct CGRect {

 CGPoint origin;

 CGSize size;

};

typedef struct CGRect CGRect;

```

- CGRect代表的是二维平面中的某个物体的位置和尺寸

    +可以使用CGRectMake和NSMakeRect函数创建CGRect

 

##4.常见的结构体使用注意

-   苹果官方推荐使用CG开头的:

    +CGPoint

    +CGSize

    +CGRect

----

# 集合对象的内存管理

##1.集合对象的内存管理

- 当一个对象加入到集合中,那么该对象的引用计数会+1

- 当集合被销毁的时候,集合会向集合中的元素发送release消息

```

   NSMutableArray *arr = [[NSMutableArray alloc] init];

 

   Person *p = [[Person alloc] init];

   NSLog(@"retainCount = %lu", [p retainCount]);

   [arr addObject:p];

   NSLog(@"retainCount = %lu", [p retainCount]);

   [p release];

   NSLog(@"retainCount = %lu", [p retainCount]);

   [arr release];

```

- 当一个对象加入到集合中,那么该对象的引用计数会+1

- 当把一个对象从集合中移除时,会向移除的元素发送release消息

```

   NSMutableArray *arr = [[NSMutableArray alloc] init];

   Person *p = [[Person alloc] init];

   NSLog(@"retainCount = %lu", [p retainCount]);

   [arr addObject:p];

   NSLog(@"retainCount = %lu", [p retainCount]);

   [arr removeObject:p];

   NSLog(@"retainCount = %lu", [p retainCount]);

   [p release];

   [arr release];

```

##2.集合对象内存管理总结

- 1.官方内存管理原则

    +1> 当调用alloc、new、copy(mutableCopy)方法产生一个新对象的时候,就必须在最后调用一次release或者autorelease

    +2> 当调用retain方法让对象的计数器+1,就必须在最后调用一次release或者autorelease

- 2.集合的内存管理细节

    +1> 当把一个对象添加到集合中时,这个对象会做了一次retain操作,计数器会+1

    +2> 当一个集合被销毁时,会对集合里面的所有对象做一次release操作,计数器会-1

    +3> 当一个对象从集合中移除时,这个对象会一次release操作,计数器会-1

- 3.普遍规律

    +1> 如果方法名是add\insert开头,那么被添加的对象,计数器会+1

    +2> 如果方法名是remove\delete开头,那么被移除的对象,计数器-1

---

# NSArray排序

##1.NSArray排序

- Foundation自带类排序

NSArray *arr = @[@(1), @(9), @(5), @(2)];

NSArray *newArr = [arrsortedArrayUsingSelector:@selector(compare:)];

```

- 自定义类排序

   NSArray *arr = @[p1, p2, p3, p4, p5];

   //    默认按照升序排序

   NSArray *newArr = [arr sortedArrayWithOptions:NSSortConcurrentusingComparator:^NSComparisonResult(Person *obj1, Person *obj2) {

       return obj1.age > obj2.age;

   }];

NSLog(@"%@",newArr);

 

# NSArray文件读写

##1.NSArray数据写入到文件中

```

   NSArray *arr = @[@"lnj", @"lmj", @"jjj",@"xcq"];

   BOOL flag = [arrwriteToFile:@"/Users/LNJ/Desktop/persons.plist" atomically:YES];

   NSLog(@"%i", flag);

---

##2.从文件中读取数据到NSArray中

```

   NSArray *newArr = [NSArrayarrayWithContentsOfFile:@"/Users/LNJ/Desktop/persons.xml"];

   NSLog(@"%@", newArr);

```

# 自定义的类实现copy操作

##1.自定义类实现copy操作

- 让类遵守NSCopying协议

- 实现 copyWithZone:方法,在该方法中返回一个对象的副本即可。

- 在copyWithZone方法中,创建一个新的对象,并设置该对象的数据与现有对象一致, 并返回该对象.

    +>zone: 表示空间,分配对象是需要内存空间的,如果指定了zone,就可以指定新建对象对应的内存空间。但是:zone是一个非常古老的技术,为了避免在堆中出现内存碎片而使用的。在今天的开发中,zone几乎可以忽略

 

- 无父类实现

```

-(id)copyWithZone(NSZone*)zone{

  CustomMode *custom = [[[self class] copyWithZone:zone]  init];

  Custom ->_a = [_a copyWithZone:zone];

  Custom -> _c = _c;//不是对象的直接赋值

  Return custom;

}

```

- 有父类实现

    +不调用父类方法, 无法拷贝父类中继承的属性

    +不重新父类copyWithZone, 无法拷贝本来中的特有属性

```

-(id)copyWithZone(NSZone*)zone{

   CustomModel *custom = [super copyWithZone:zone];

   ….

   Return custom;

}

```

# 单例设计模式

##1.单例模式概念

- 什么是单例模式:(Singleton)

    +单例模式的意图是是的类的对象成为系统中唯一的实例,

这篇关于OC语言之NSArray的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096115

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的