全系列文章索引:
1 【CoreData】新建记录
ios中的coredata的使用
http://blog.csdn.net/chen505358119/article/details/9334831
//插入数据
- (IBAction)addIntoDataSource:(id)sender {
User* user=(User *)[NSEntityDescription insertNewObjectForEntityForName:@"User" inManagedObjectContext:self.myAppDelegate.managedObjectContext];
[user setName:_nameText.text];
[user setAge:[NSNumber numberWithInteger:[_ageText.text integerValue]]];
[user setSex:_sexText.text];
NSError* error;
BOOL isSaveSuccess=[_myAppDelegate.managedObjectContext save:&error];
if (!isSaveSuccess) {
NSLog(@"Error:%@",error);
}else{
NSLog(@"Save successful!");
}
}
2 【CoreData】查询记录
//查询
- (IBAction)query:(id)sender {
NSFetchRequest* request=[[NSFetchRequest alloc] init];
NSEntityDescription* user=[NSEntityDescription entityForName:@"User" inManagedObjectContext:_myAppDelegate.managedObjectContext];
[request setEntity:user];
// NSSortDescriptor* sortDescriptor=[[NSSortDescriptor alloc] initWithKey:@"name" ascending:YES];
// NSArray* sortDescriptions=[[NSArray alloc] initWithObjects:sortDescriptor, nil];
// [request setSortDescriptors:sortDescriptions];
// [sortDescriptions release];
// [sortDescriptor release];
NSError* error=nil;
NSMutableArray* mutableFetchResult =[[_myAppDelegate.managedObjectContext executeFetchRequest:request error:&error] mutableCopy];
if (mutableFetchResult==nil) {
NSLog(@"Error:%@",error);
}
NSLog(@"The count of entry: %i",[mutableFetchResult count]);
for (User* user in mutableFetchResult) {
NSLog(@"name:%@----age:%@------sex:%@",user.name,user.age,user.sex);
}
[mutableFetchResult release];
[request release];
}
3 【CoreData】更新记录
//更新
- (IBAction)update:(id)sender {
NSFetchRequest* request=[[NSFetchRequest alloc] init];
NSEntityDescription* user=[NSEntityDescription entityForName:@"User" inManagedObjectContext:_myAppDelegate.managedObjectContext];
[request setEntity:user];
//查询条件
NSPredicate* predicate=[NSPredicate predicateWithFormat:@"name==%@",@"chen"];
[request setPredicate:predicate];
NSError* error=nil;
NSMutableArray* mutableFetchResult=[[_myAppDelegate.managedObjectContext executeFetchRequest:request error:&error] mutableCopy];
if (mutableFetchResult==nil) {
NSLog(@"Error:%@",error);
}
NSLog(@"The count of entry: %i",[mutableFetchResult count]);
//更新age后要进行保存,否则没更新
for (User* user in mutableFetchResult) {
[user setAge:[NSNumber numberWithInt:12]];
}
[_myAppDelegate.managedObjectContext save:&error];
[mutableFetchResult release];
[request release];
}
4 【CoreData】删除记录
//删除
- (IBAction)del:(id)sender {
NSFetchRequest* request=[[NSFetchRequest alloc] init];
NSEntityDescription* user=[NSEntityDescription entityForName:@"User" inManagedObjectContext:_myAppDelegate.managedObjectContext];
[request setEntity:user];
NSPredicate* predicate=[NSPredicate predicateWithFormat:@"name==%@",@"chen"];
[request setPredicate:predicate];
NSError* error=nil;
NSMutableArray* mutableFetchResult=[[_myAppDelegate.managedObjectContext executeFetchRequest:request error:&error] mutableCopy];
if (mutableFetchResult==nil) {
NSLog(@"Error:%@",error);
}
NSLog(@"The count of entry: %i",[mutableFetchResult count]);
for (User* user in mutableFetchResult) {
[_myAppDelegate.managedObjectContext deleteObject:user];
}
if ([_myAppDelegate.managedObjectContext save:&error]) {
NSLog(@"Error:%@,%@",error,[error userInfo]);
}
}
5 【CoreData】多条件查询
predicate = [NSPredicate
predicateWithFormat:@"(salesMan = %@) AND (customerName contains %@) AND
(customerSex = %@) AND (createdDate >= %d) AND (createdDate <=
%d)",[[NSUserDefaults standardUserDefaults]
objectForKey:kDefaultUsernameKey], custName,custSex, fromTime, toTime];
6 【CoreData】处理海量数据
Batch Updates可用于批量快速更新数据,Asynchronous Fetching可用于异步抓取海量数据,并可以通过 NSProgress 实现进度跟踪和取消。
6.1 Batch Updates
在CoreData中想要更新大量数据,我们往往要将大量修改后的NSManagedObject 加载到 NSManagedObjectContext 中并保存,这会占用大量内存,试想想在iPhone这样的内存有限的移动设备上将是个灾难,数据有可能丢失。你可能会采取批处理的方式,即一小批一小批的更新 NSManagedObject 并保存到 NSManagedObjectContext 中,但这样会花费很多时间,用户体验较差。
为了解决这个问题,苹果在 NSManagedObjectContext 加入了一个新的方法:executeRequest:error: ,它接受一个 NSPersistentStoreRequest 类型的参数,返回类型为 NSPersistentStoreResult 。
关于 NSPersistentStoreRequest 有些人可能比较熟悉,它是NSFetchRequest 、 NSSaveChangesRequest 、 NSBatchUpdateRequest和 NSAsynchronousFetchRequest 的基类。后两个类是这次iOS8新加的,也是这篇文章将要讨论的内容。
NSPersistentStoreResult 是一个新加入的类,它也是一个基类,而且是抽象类,这个类作为 executeRequest:error: 返回内容的父类,相当于一个接口,它目前有两个子类: NSPersistentStoreAsynchronousResult 和NSBatchUpdateResult 。
你大概猜到了, NSBatchUpdateResult 对应着前面的NSBatchUpdateRequest ,下面说说 NSBatchUpdateRequest 。它有点像NSFetchRequest :它允许你指定一个想要更新数据的实体;也可以指定一个affectedStores ,它存储了一个接受更新请求的 NSPersistentStore 数组。(其实它是 NSPersistentStoreRequest 的属性);它也有一个谓词属性来做更新的条件,它跟 NSFetchRequest 中的谓词一样强大和灵活,类似于SQL的where语句;它允许你指定想要更新的字段,通过 propertiesToUpdate 属性来描述字段更新,它是一个字段,key为 NSPropertyDescription 或属性名字符串,value为 NSExpression 或常量。
接着谈谈 NSBatchUpdateResult ,它有一个 result 属性和 resultType属性, result 中的内容跟 resultType 有关,可能是成功或者失败,有可能是每行被更新的ID,也可能是被更新的行数。
需要注意的是,由于 NSBatchUpdateRequest 并不会先将数据存入内存,而是直接操作数据库,所以并不会引起NSManagedObjectContext的同步更新,所以你不仅需要获取 NSBatchUpdateResult 然后刷新 NSManagedObjectContext 对应的数据和UI界面,还需要保证更新后的数据满足数据库模型上的 validation ,因为 NSManagedObjectContext 没有感知Batch Updates,一些数据验证工作就落在了程序员的身上(你需要写一段代码验证更新后的数据是合法的,用户可不希望在跑步APP上看到自己今天跑步里程是个负数)。一旦有非法数据录入数据库,下次加载并修改 NSManagedObject 的时候就会导致数据验证失败。除了上面提到的这些,还要注意Batch Updates对数据库的操作是乐观锁,也就是假定很少会发生同时存取同一块数据的情况,所以你需要制定一个合理的”merge”策略来应付因同时更新数据产生的冲突。
Batch Updates的优势在于其效率,在处理上万条数据的时候,它执行的时间跟SQL语句执行时间相当。
6.2 Asynchronous Fetching
Asynchronous Fetching的加入依然是为了解决CoreData读取海量数据所带来的问题。通过使用Asynchronous Fetching,我们可以在抓取数据的同时不阻塞占用NSManagedObjectContext ,并可以随时取消抓取行为,随时跟踪抓取数据的进度。
设想我们平时用 NSFetchRequest 抓取数据的时候,我们会先用NSManagedObjectContext 的 executeFetchRequest:error: 方法传入一个NSFetchRequest ,然后请求会被发送到 NSPersistentStore ,然后执行一段时间后返回一个数组,在 NSManagedObjectContext 更新后,这个数组被当做executeFetchRequest:error: 的返回值返回到我们这里。
而Asynchronous Fetching则不同,当我们将一个NSAsynchronousFetchRequest 对象传入 executeRequest:error: 方法后会立即返回一个“未来的” NSAsynchronousFetchResult 。NSAsynchronousFetchRequest 初始化时需要传入两个参数赋值给属性:
1. completionBlock 属性,允许我们在抓取完成后执行回调block;
2. fetchRequest 属性,类型是 NSFetchRequest 。也即是说虽然是异步抓取,其实我们用的还是以前的 NSFetchRequest ,当 NSFetchRequest 抓取结束后会更新 NSManagedObjectContext ,这也就意味着NSManagedObjectContext 的并发类型只能是NSPrivateQueueConcurrencyType 或 NSMainQueueConcurrencyType。
于是当我们用 NSAsynchronousFetchRequest 抓取数据时,我们会先用NSManagedObjectContext 的 executeRequest:error: 方法传入一个NSAsynchronousFetchRequest ,这个方法在 NSManagedObjectContext 上执行时, NSManagedObjectContext 会立即制造并返回一个NSAsynchronousFetchResult ,同时 NSAsynchronousFetchRequest 会被发送到 NSPersistentStore 。你现在可以继续编辑这个NSManagedObjectContext 中的 NSManagedObject ,等到NSPersistentStore 执行请求完毕时会将结果返回给NSAsynchronousFetchResult 的 finalResult 属性,更新NSManagedObjectContext ,执行 NSAsynchronousFetchRequest 的回调block。
举个栗子:
let request = NSFetchRequest(entityName: "MyEntity")
let async = NSAsynchronousFetchRequest(fetchRequest: request){
(id result)in
if result.finalResult {
//TODO..
}
}
Swift代码很简洁,并用了尾随闭包语法,看不懂的朋友也不用着急,知道NSAsynchronousFetchRequest 大概的用法就行。
之前提到过 NSAsynchronousFetchRequest 能在抓取数据的过程中跟踪进度,于是乎 NSProgress 登场了!一行代码顶十句话:
let request = NSFetchRequest(entityName: "MyEntity")
var asyncResult:NSPersistentStoreResult!
let async = NSAsynchronousFetchRequest(fetchRequest: request){
(id result)in
if result.finalResult {
//TODO..
}
}
let progress = NSProgress(totalUnitCount: 1) progress.becomeCurrentWithPendingUnitCount(1) managedObjectContext?.performBlock{
[unowned self]in
let error = NSErrorPointer()
asyncResult = self.managedObjectContext?.executeRequest(async, error: error)
}
progress.resignCurrent()
而取消获取数据只需要取消 NSProgress 就可以了!取消行为会沿着数的根节点蔓延到叶子。
progress.cancel()可以在 cancellationHandler 属性设置取消后执行的block,这里不再多说。
7 【NSSet】NSArray NSSet转换
NSArray *arr = @[@"12-11", @"12-11", @"12-11", @"12-12", @"12-13", @"12-14"];
NSSet *set = [NSSet setWithArray:arr];
NSLog(@"set%@\n", set);
8 【NSSet】NSSet的排序
NSArray *arr = @[@"12-11", @"12-11", @"12-11", @"12-12", @"12-13", @"12-14"];
NSSet *set = [NSSet setWithArray:arr];
NSArray *sortDesc = @[[[NSSortDescriptor alloc] initWithKey:nil ascending:YES]];
NSArray *sortSetArray = [set sortedArrayUsingDescriptors:sortDesc];
NSLog(@"set%@\nsort set%@", set, sortSetArray);
9 【JS】位运算的运算符优先级问题
在Javascript中,位运算的运算符优先级比加减号低,所以一定要注意,正确的写法是在位运算符处加上括号:
_deviceStatusData.outflowTDS.value= (body[43] << 8) + body[42];
10 【JS】Js获取当前日期时间及其它操作
varmyDate = new Date();
myDate.getYear(); //获取当前年份(2位)
myDate.getFullYear(); //获取完整的年份(4位,1970-????)
myDate.getMonth(); //获取当前月份(0-11,0代表1月)
myDate.getDate(); //获取当前日(1-31)
myDate.getDay(); //获取当前星期X(0-6,0代表星期天)
myDate.getTime(); //获取当前时间(从1970.1.1开始的毫秒数)
myDate.getHours(); //获取当前小时数(0-23)
myDate.getMinutes(); //获取当前分钟数(0-59)
myDate.getSeconds(); //获取当前秒数(0-59)
myDate.getMilliseconds(); //获取当前毫秒数(0-999)
myDate.toLocaleDateString(); //获取当前日期
var mytime=myDate.toLocaleTimeString(); //获取当前时间
myDate.toLocaleString( ); //获取日期与时间
日期时间脚本库方法列表
Date.prototype.isLeapYear判断闰年
Date.prototype.Format
日期格式化
Date.prototype.DateAdd
日期计算
Date.prototype.DateDiff
比较日期差
Date.prototype.toString
日期转字符串
Date.prototype.toArray
日期分割为数组
Date.prototype.DatePart
取日期的部分信息
Date.prototype.MaxDayOfDate
取日期所在月的最大天数
Date.prototype.WeekNumOfYear
判断日期所在年的第几周
StringToDate
字符串转日期型
IsValidDate
验证日期有效性
CheckDateTime
完整日期时间检查
daysBetween
日期天数差
js代码:
//判断闰年
Date.prototype.isLeapYear = function()
{
return(0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0)));
}
//---------------------------------------------------
//日期格式化
//格式 YYYY/yyyy/YY/yy 表示年份
// MM/M月份
// W/w星期
// dd/DD/d/D日期
// hh/HH/h/H时间
// mm/m分钟
// ss/SS/s/S秒
//---------------------------------------------------
Date.prototype.Format = function(formatStr)
{
var str = formatStr;
var Week = ['日','一','二','三','四','五','六'];
str=str.replace(/yyyy|YYYY/,this.getFullYear());
str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear()% 100).toString():'0' + (this.getYear() % 100));
str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0'+ this.getMonth());
str=str.replace(/M/g,this.getMonth());
str=str.replace(/w|W/g,Week[this.getDay()]);
str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0'+ this.getDate());
str=str.replace(/d|D/g,this.getDate());
str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0'+ this.getHours());
str=str.replace(/h|H/g,this.getHours());
str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0'+ this.getMinutes());
str=str.replace(/m/g,this.getMinutes());
str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0'+ this.getSeconds());
str=str.replace(/s|S/g,this.getSeconds());
return str;
}
//---------------------------------------------------
//求两个时间的天数差 日期格式为YYYY-MM-dd
//---------------------------------------------------
function daysBetween(DateOne,DateTwo)
{
var OneMonth = DateOne.substring(5,DateOne.lastIndexOf('-'));
var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1);
var OneYear = DateOne.substring(0,DateOne.indexOf('-'));
var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf('-'));
var TwoDay =DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1);
var TwoYear = DateTwo.substring(0,DateTwo.indexOf('-'));
var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)-Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000);
return Math.abs(cha);
}
//---------------------------------------------------
//日期计算
//---------------------------------------------------
Date.prototype.DateAdd = function(strInterval, Number) {
var dtTmp = this;
switch (strInterval) {
case 's' :return newDate(Date.parse(dtTmp) + (1000 * Number));
case 'n' :return newDate(Date.parse(dtTmp) + (60000 * Number));
case 'h' :return newDate(Date.parse(dtTmp) + (3600000 * Number));
case 'd' :return newDate(Date.parse(dtTmp) + (86400000 * Number));
case 'w' :return newDate(Date.parse(dtTmp) + ((86400000 * 7) * Number));
case 'q' :return newDate(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(),dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
case 'm' :return newDate(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(),dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
case 'y' :return newDate((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(),dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
}
}
//---------------------------------------------------
//比较日期差 dtEnd 格式为日期型或者有效日期格式字符串
//---------------------------------------------------
Date.prototype.DateDiff = function(strInterval, dtEnd) {
var dtStart = this;
if (typeof dtEnd == 'string' ) //如果是字符串转换为日期型
{
dtEnd =StringToDate(dtEnd);
}
switch (strInterval) {
case 's' :returnparseInt((dtEnd - dtStart) / 1000);
case 'n' :returnparseInt((dtEnd - dtStart) / 60000);
case 'h' :returnparseInt((dtEnd - dtStart) / 3600000);
case 'd' :returnparseInt((dtEnd - dtStart) / 86400000);
case 'w' :returnparseInt((dtEnd - dtStart) / (86400000 * 7));
case 'm' :return(dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) -(dtStart.getMonth()+1);
case 'y' :returndtEnd.getFullYear() - dtStart.getFullYear();
}
}
//---------------------------------------------------
//日期输出字符串,重载了系统的toString方法
//---------------------------------------------------
Date.prototype.toString = function(showWeek)
{
var myDate= this;
var str = myDate.toLocaleDateString();
if (showWeek)
{
var Week = ['日','一','二','三','四','五','六'];
str += '星期' + Week[myDate.getDay()];
}
return str;
}
//---------------------------------------------------
//日期合法性验证
//格式为:YYYY-MM-DD或YYYY/MM/DD
//---------------------------------------------------
function IsValidDate(DateStr)
{
var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //去两边空格;
if(sDate=='') return true;
//如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或YYYY-(/)MM-(/)D就替换为''
//数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式
var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2}[\-/]{ 1 }[\d]{ 1,2 }/g,'');
if (s=='') //说明格式满足YYYY-MM-DD或YYYY-M-DD或YYYY-M-D或YYYY-MM-D
{
var t=newDate(sDate.replace(/\-/g,'/'));
var ar = sDate.split(/[-/:]/);
if(ar[0] != t.getYear() ||ar[1] != t.getMonth()+1 || ar[2] != t.getDate())
{
//alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');
return false;
}
}
else
{
//alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');
return false;
}
return true;
}
//---------------------------------------------------
//日期时间检查
//格式为:YYYY-MM-DD HH:MM:SS
//---------------------------------------------------
function CheckDateTime(str)
{
var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2}):(\d{ 1,2 }):(\d{ 1,2 })$/;
var r = str.match(reg);
if(r==null)return false;
r[2]=r[2]-1;
var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]);
if(d.getFullYear()!=r[1]) return false;
if(d.getMonth()!=r[2]) return false;
if(d.getDate()!=r[3]) return false;
if(d.getHours()!=r[4]) return false;
if(d.getMinutes()!=r[5]) return false;
if(d.getSeconds()!=r[6]) return false;
return true;
}
//---------------------------------------------------
//把日期分割成数组
//---------------------------------------------------
Date.prototype.toArray = function()
{
var myDate = this;
var myArray = Array();
myArray[0] = myDate.getFullYear();
myArray[1] = myDate.getMonth();
myArray[2] = myDate.getDate();
myArray[3] = myDate.getHours();
myArray[4] = myDate.getMinutes();
myArray[5] = myDate.getSeconds();
return myArray;
}
//---------------------------------------------------
//取得日期数据信息
//参数 interval 表示数据类型
// y年 m月 d日 w星期 ww周 h时 n分 s秒
//---------------------------------------------------
Date.prototype.DatePart = function(interval)
{
var myDate = this;
var partStr='';
var Week = ['日','一','二','三','四','五','六'];
switch (interval)
{
case 'y' :partStr =myDate.getFullYear();break;
case 'm' :partStr =myDate.getMonth()+1;break;
case 'd' :partStr =myDate.getDate();break;
case 'w' :partStr =Week[myDate.getDay()];break;
case 'ww' :partStr =myDate.WeekNumOfYear();break;
case 'h' :partStr =myDate.getHours();break;
case 'n' :partStr =myDate.getMinutes();break;
case 's' :partStr =myDate.getSeconds();break;
}
return partStr;
}
//---------------------------------------------------
//取得当前日期所在月的最大天数
//---------------------------------------------------
Date.prototype.MaxDayOfDate = function()
{
var myDate = this;
var ary = myDate.toArray();
var date1 = (new Date(ary[0],ary[1]+1,1));
var date2 = date1.dateAdd(1,'m',1);
var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd'));
return result;
}
//---------------------------------------------------
//取得当前日期所在周是一年中的第几周
//---------------------------------------------------
Date.prototype.WeekNumOfYear = function()
{
var myDate = this;
var ary = myDate.toArray();
var year = ary[0];
var month = ary[1]+1;
var day = ary[2];
document.write('< script language=VBScript\>\n');
document.write('myDate =Datue(''+month+'-'+day+'-'+year+'') \n');
document.write('result = DatePart('ww', myDate)\n');
document.write(' \n');
return result;
}
//---------------------------------------------------
//字符串转成日期类型
//格式MM/dd/YYYY MM-dd-YYYY YYYY/MM/ddYYYY-MM-dd
//---------------------------------------------------
function StringToDate(DateStr)
{
var converted = Date.parse(DateStr);
var myDate = new Date(converted);
if (isNaN(myDate))
{
//var delimCahar =DateStr.indexOf('/')!=-1?'/':'-';
var arys=DateStr.split('-');
myDate = newDate(arys[0],--arys[1],arys[2]);
}
return myDate;
}
//若要显示:当前日期加时间(如:2009-06-1212:00)
function CurentTime()
{
var now = new Date();
var year =now.getFullYear(); //年
var month = now.getMonth() +1; //月
var day =now.getDate(); //日
var hh =now.getHours(); //时
var mm =now.getMinutes(); //分
var clock = year +"-";
if(month < 10)
clock+= "0";
clock += month + "-";
if(day < 10)
clock+= "0";
clock += day + " ";
if(hh < 10)
clock+= "0";
clock += hh + ":";
if (mm < 10) clock +='0';
clock += mm;
return(clock);
}
11 【File】iOS的四种方法读取文件内容
//第一种方法: NSFileManager实例方法读取数据
NSArray*paths = NSSearchPathForDirectoriesInDomains(NSDesktopDirectory, NSUserDomainMask, YES);
NSString*thepath = [paths lastObject];
thepath = [thepath stringByAppendingPathComponent:@"fd_list.txt"];
NSLog(@"桌面目录:%@", thepath);
NSFileManager*fm = [NSFileManager defaultManager];
NSData*data = [[NSData alloc] init];
data = [fm contentsAtPath:thepath];
NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
//第二种方法: NSData类方法读取数据
data = [NSData dataWithContentsOfFile:thepath];
NSLog(@"NSData类方法读取的内容是:%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
//第三种方法: NSString类方法读取内容
NSString*content = [NSString stringWithContentsOfFile:thepath encoding:NSUTF8StringEncoding error:nil];
NSLog(@"NSString类方法读取的内容是:\n%@",content);
//第四种方法: NSFileHandle实例方法读取内容
NSFileHandle* fh = [NSFileHandle fileHandleForReadingAtPath:thepath];
data = [fh readDataToEndOfFile];
NSLog(@"NSFileHandle实例读取的内容是:\n%@", [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
http://www.2cto.com/kf/201404/290149.html
12 【编译】Cannot define category for undefined class ‘NSString’
这个问题是由于默认没有引用Foundation.h导致
解决方案:
在代码中引用#import
13 【View】-[UITableViewController loadView] loaded the"XXX" nib but didn't get a UITableView.
'-[UITableViewController loadView] loaded the"XXX" nib but didn't get a UITableView.'
解决方法:在头文件中,将所继承的父类UITableViewController 改成 UIViewController。
uncaught exception 'NSInternalInconsistencyException,reason:[UITableViewController loadView] loaded the "Controller" nibbut didn't get a UITableView
http://www.tuicool.com/articles/67VN3m
14 【Network】使用AFNetworking2.0请求数据时出现错误Requestfailed:unacceptablecontent-type:text/html解决方法
使用AFNetworking 2.0请求数据时出现错误 Request failed: unacceptable content-type: text/html 解决方法:
添加一行
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObject:@"text/html"];
http://www.haogongju.net/art/2407859
15 【JS】Js常用调试的方法
http://www.cnblogs.com/Look_Sun/archive/2010/08/06/1793643.html
16 【JS】Safari调试工具
在Enable - SafariPrefernces --> Advanced最下面的选项勾选, 然后你就可以在右键菜单上看到Inspect Element选项了 - 跟Chrome一模一样
17 【地理位置】APP获取本地地理位置时注意
APP中获取本地地理位置时,要注意打开APP的地理位置授权,位置在设置—>隐私—>定位服务
不然获取不到位置信息,而且没有提示,而且APP一旦移除重新安装,需要重新设置。
18 【mac ox】mac命令行下怎么切换到root用户
可以使用sudo -i然后输入密码即可
19 【js】遍历js对象并获取某一个成员对象
for(var app in callbackData)
{
var appObj = callbackData[app];
if(appObj != null && appObj.applianceId != undefined &&appObj.applianceId == curAppID)
{
_userApplianceInfo = appObj;
break;
}
}
20 Objective-C自定义NSLog宏
/*
XCode LLVM XXX - Preprocessing中Debug会添加 DEBUG=1 标志
*/
#ifdef DEBUG
#define NSLog(FORMAT, ...) fprintf(stderr,"%s:%d\t%s\n",[[[NSString stringWithUTF8String:__FILE__] lastPathComponent] UTF8String], __LINE__, [[NSString stringWithFormat:FORMAT, ##__VA_ARGS__] UTF8String]);
#else
#define NSLog(FORMAT, ...) nil
#endif
21 【兼容性】IOS8中,CLLocationManagerDelegate不调用didUpdateLocations
CLLocationManagerDelegate不调用didUpdateLocations
http://www.cocoachina.com/bbs/read.php?tid=259171
iOS8下的开发变化
http://www.cocoachina.com/bbs/read.php?tid=217107
需要在使用CoreLocation前调用方法 requestWhenInUseAuthorization()或者requestAlwaysAuthorization(),并在Info.plist中加入两个缺省没有的字段NSLocationAlwaysUsageDescription、NSLocationWhenInUseUsageDescription