NSArray 所有基础点示例
#import <Foundation/Foundation.h>
//排序算法,应用于 NSArray *arr=[arrs1 sortedArrayUsingFunction:sortByID context:nil];排序
NSInteger sortByID(id obj1, id obj2, void *context){
NSString *str1 =(NSString*) obj1;
NSString *str2 =(NSString *) obj2;
if (str1.length < str2.length) {
return NSOrderedDescending;
}
else if(str1.length == str2.length)
{
return NSOrderedSame;
}
return NSOrderedAscending;
}
int main(int argc, const char * argv[]) {
@autoreleasepool {
//数组只能存储oc对象,NSArray一旦创建不能修改
NSArray *arrs0=@[@"123",@"456",@"789"];
//初始化数组的一种奇葩
NSArray *arrs1=[NSArray arrayWithArray:arrs0];
//1.获取数组中的元素对象
id need=[arrs1 objectAtIndex:1];//取出索引位置中的对象
id nn=[arrs1 objectAtIndexedSubscript:1];
NSLog(@"need=%@",need);
//2.元素个数
int t=[arrs1 count];
//3.判断是否包含
bool isYes=[arrs1 containsObject:@"123"];
//4.取得数组中第一个和最后一个元素
need= [arrs1 firstObject];
need=[arrs1 lastObject];
//5.添加元素,返回另一个数组
arrs0=[arrs1 arrayByAddingObject:@"000"];
//6.合并两个数组
arrs0=[arrs1 arrayByAddingObjectsFromArray:arrs1];
NSLog(@"%@",arrs0);
//7.取得数组一定范围内的数据
arrs0=[arrs1 subarrayWithRange:NSMakeRange(1, 1)];
NSLog(@"%ld",[arrs0 count]);
//8.判断是否相等
isYes=[arrs0 isEqualToArray:arrs1];
//9.返回元素的位置
int tt=[arrs0 indexOfObject:@"123"];
NSLog(@"%d",tt);
tt=[arrs0 indexOfObjectIdenticalTo:@"123"];
//10.数组与字符串的转换
NSString *sss=[arrs1 componentsJoinedByString:@"-"];
//11.字符串与数组转换
NSArray *array=[sss componentsSeparatedByString:@"-"];
NSLog(@"%@",sss);
NSLog(@"%@",array);
//sortedArrayHint:不知道怎么用的
//int num=[array sortedArrayHint];
//NSLog(@"%ld",num);
//12.写入文件,写入url
[arrs1 writeToFile:@"/users/tang/desktop/array.plist" atomically:YES];
NSArray *arrfile=[NSArray arrayWithContentsOfFile:@"/users/tang/desktop/array.plist"];
NSLog(@"%@",arrfile);
//13.数组的遍历 还有两种
[arrs1 enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
NSLog(@"%d,%@",idx,obj);
if(idx==1)
{
*stop=YES;
}
}];
//14.正向遍历
NSEnumerator *dfd=[arrs1 objectEnumerator];
for (id dd in dfd) {
NSLog(@"%@",dd);
}
//15.反向遍历
dfd=[arrs1 reverseObjectEnumerator];
for (id dd in dfd) {
NSLog(@"%@",dd);
}
//16用自己写的函数实现数组的排序
NSArray *arr=[arrs1 sortedArrayUsingFunction:sortByID context:nil];
// NSLog(@"%ld",NSNotFound);
}
return 0;
}
NSArray 所有基础点示例的更多相关文章
- 【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词
一. 字符串 API 1. NSString 用法简介 (1) NSString API 介绍 NSString 功能 : -- 创建字符串 : 使用 init 开头的实例方法, 也可以使用 Stri ...
- iOS之数据持久化方案
概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) ...
- iOS的数据持久化
所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) pr ...
- iOS数据持久化
在iOS中,实现数据持久化一般分为4大种: 1.属性列表 2.对象归档 3.SQLite 4.Core Data 一.属性列表 NSUserDefaults类的使用和NSKeyedArchiver有很 ...
- 转载 -- iOS数据持久化存储
作者:@翁呀伟呀 授权本站转载 概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方 ...
- 3D touch 的 应用 --备用
在iPhone 6s和iPhone 6s Plus中Apple引入了3D Touch技术.3D Touch的触控技术,被苹果称为新一代多点触控技术.其实,就是此前在Apple Watch上采用的For ...
- 妙用valueForKeyPath
valueForKey与valueForKeyPath在KVC中同时出现,都可以使用,难免让开发者迷惑:心里知道肯定是不一样,但具体的用法你会吗?其实valueForKeyPath的功能更强大,支持深 ...
- ios持久化存储
前言 iOS中常用的持久化存储方式有好几种: 偏好设置(NSUserDefaults) plist文件存储 归档 SQLite3 Core Data 沙盒 每个iOS应用都有自己的应用沙盒(应用沙盒就 ...
- iOS中几种数据持久化方案
概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) ...
随机推荐
- Linux下Apache配置SSL支持https
参考:http://www.thinksaas.cn/group/topic/280017/ 生成证书过程如下 Step :生成服务器密钥: mkdir -p /etc/pki/test cd /et ...
- 百度和google的区别
一.百度 二.google
- Linux下安装Django
Django是基于Python开发的免费的开源网站框架,也是python web开发中重量级的web框架,可以用于快速搭建高性能并且优雅的网站! 下面以Fedora为例安装Django,最新Fedor ...
- h5页面的公共css
/*reset*/body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,button,tex ...
- 跟着 8 张思维导图学习 Javascript
学习的道路就是要不断的总结归纳,好记性不如烂笔头,so,下面将po出8张javascript相关的思维导图. 思维导图小tips:思维导图又叫心智图,是表达发射性思维的有效的图形思维工具 ,它简单却又 ...
- Maven 3.3.3 Win10环境下的使用实例(上)
Maven是一个项目管理和构建自动化工具,在使用之前,请按照Apache官网提供的指南进行环境变量配置. 完成后在PowerShell中输入如下命令来验证Maven的部署情况: mvn -v 正常的响 ...
- android入门到熟练(五)---广播
1.广播类型:标准广播和有序广播.标准广播是异步广播在广播发出之后所有接收器几乎会同一时刻接收到,没有先后顺序,效率高,但无法被截断.有序广播则是同步广播,同一时刻只能一个接收器接收这条消息,等执行完 ...
- 【leetcode】Palindrome Partitioning II(hard) ☆
Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...
- HDU 4387 Stone Game (博弈)
题目:传送门. 题意:长度为N的格子,Alice和Bob各占了最左边以及最右边K个格子,每回合每人可以选择一个棋子往对面最近的一个空格移动.最先不能移动的人获得胜利. 题解: k=1时 很容易看出,n ...
- 完美解决:Could not retrieve mirrorlist http://mirrorlist.centos.org/?release=6&arch=x
如题: 原因:没有配置resolv.conf 解决方法: 到/etc目录下配置resolv.conf加入nameserver IP,如: nameserver 8.8.8.8nameserver 8. ...