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文件(属性列表) ...
随机推荐
- NGUI 滑动页(UIToggle和UIToggledObjects)
1.NGUI->Create->Scroll View 2.给Scroll View添加一个 UIGrid,自己设置Arragement(横向竖向) 3.给Grid添加元素 4.给元素添加 ...
- codeforces 496B. Secret Combination 解题报告
题目链接:http://codeforces.com/problemset/problem/496/B 题目意思:给出 n 位数你,有两种操作:1.将每一位数字加一(当某一位 > 9 时只保存个 ...
- dhtmlxTree介绍(转载)
dhtmlxTree 是树菜单,允许我们快速开发界面优美,基于Ajax的javascript库. 她允许在线编辑,拖拽,三种状态(全选.不选.半选),复选框等模式.同时在加载大数据量的时候,仍然 可以 ...
- 【python】入门学习(十)
#入门学习系列的内容均是在学习<Python编程入门(第3版)>时的学习笔记 统计一个文本文档的信息,并输出出现频率最高的10个单词 #text.py #保留的字符 keep = {'a' ...
- 甲鱼od19篇随笔
在一个程序里会有多个对话框,这时要准确的判断要找的对话框就比较困难了所以这里就需要借助 1:Resource Hacker工具来准确的定位涉及到的对话框 2:在od中查找指令,然后在所有找到的指令上下 ...
- Google140道面试题
FQ找来,可能历史比较悠久了,慢慢看. 原文连接:http://www.impactinterview.com/2009/10/140-google-interview-questions/ Goog ...
- 数独挑战(codevs 2924)
2924 数独挑战 时间限制: 1 s 空间限制: 1000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description “芬兰数学家因卡拉,花费3 ...
- CSS居中布局总结
居中布局 <div class="parent"> <div class="child">demo</div> </d ...
- 最简单的Web服务器
//读取浏览器发过来的内容Socket serverSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, Protoco ...
- 关于Linux环境变量
查看全局变量: printenv 查看单个环境变量的值可以用echo命令,必须在环境变量的名称前放一个$符号 如: