swift缓存
① ios swift中的pct文件用设置路径吗
1、模拟器沙盒目录 文件都在个人用户名文件夹下的一个隐藏文件夹里,中文叫资源库,他的目录其实是Library。 因为应用是在沙箱(sandbox)中的,在文件读写权限上受到限制,只能在几个目录下读写文件: Documents:应用中用户数据可以放在这里,iTunes备份和恢复的时候会包括此目录 tmp:存放临时文件,iTunes不会备份和恢复此目录,此目录下文件可能会在应用退出后删除 Library/Caches:存放缓存文件,iTunes不会备份此目录,此目录下文件不会在应用退出删除 iTunes在与iPhone同步时,备份所有的Documents和Library文件。 iPhone在重启时,会丢弃所有的tmp文件。 查看方法: 方法1、可以设置显示隐藏文件,然后在Finder下直接打开。设置查看隐藏文件的方法如下:打开终端,输入命名 (1)显示Mac隐藏文件的命令:defaults write com.apple.finder AppleShowAllFiles -bool true (2)隐藏Mac隐藏文件的命令:defaults write com.apple.finder AppleShowAllFiles -bool false (3)输完单击Enter键,退出终端,重新启动Finder就可以了 重启Finder:鼠标单击窗口左上角的苹果标志-->强制退出-->Finder--> 现在能看到资源库文件夹了。 打开资源库后找到/Application Support/iPhone Simulator/文件夹。这里面就是模拟器的各个程序的沙盒目录了。 方法2、这种方法更方便,在Finder上点->前往->前往文件夹,输入/Users/username/Library/Application Support/iPhone Simulator/ 前往。 username这里写用户名。 代码查看目录: NSString *path = NSHomeDirectory();//主目录 NSLog(@"NSHomeDirectory:%@",path); NSString *userName = NSUserName();//与上面相同 NSString *rootPath = NSHomeDirectoryForUser(userName); NSLog(@"NSHomeDirectoryForUser:%@",rootPath); NSArray *paths = (NSDocumentDirectory, NSUserDomainMask, YES); NSString *documentsDirectory=[paths objectAtIndex:0];//Documents目录 NSLog(@"NSDocumentDirectory:%@",documentsDirectory); 结果如下: 2013-09-03 20:31:27.210 ios那啥[8383:c07] NSHomeDirectory:/Users/wmm/Library/Application Support/iPhone Simulator/6.1/Applications/D803DBD2-9CB2-4D18-9152-6E9398EFF5DB2013-09-03 20:31:27.210 ios那啥[8383:c07] NSHomeDirectoryForUser:/Users/wmm/Library/Application Support/iPhone Simulator/6.1/Applications/D803DBD2-9CB2-4D18-9152-6E9398EFF5DB2013-09-03 20:31:27.211 ios那啥[8383:c07] NSDocumentDirectory:/Users/wmm/Library/Application Support/iPhone Simulator/6.1/Applications/D803DBD2-9CB2-4D18-9152-6E9398EFF5DB/Documents 自定义类返回各目录路径: #import <Foundation/Foundation.h> @interface ICSandboxHelper : NSObject + (NSString *)homePath; // 程序主目录,可见子目录(3个):Documents、Library、tmp + (NSString *)appPath; // 程序目录,不能存任何东西 + (NSString *)docPath; // 文档目录,需要ITUNES同步备份的数据存这里,可存放用户数据 + (NSString *)libPrefPath; // 配置目录,配置文件存这里 + (NSString *)libCachePath; // 缓存目录,系统永远不会删除这里的文件,ITUNES会删除 + (NSString *)tmpPath; // 临时缓存目录,APP退出后,系统可能会删除这里的内容 + (BOOL)hasLive:(NSString *)path; //判断目录是否存在,不存在则创建 #import "ICSandboxHelper.h" @implementation ICSandboxHelper + (NSString *)homePath{ return NSHomeDirectory(); } + (NSString *)appPath { NSArray * paths = (NSApplicationDirectory, NSUserDomainMask, YES); return [paths objectAtIndex:0]; } + (NSString *)docPath { NSArray * paths = (NSDocumentDirectory, NSUserDomainMask, YES); return [paths objectAtIndex:0]; } + (NSString *)libPrefPath { NSArray * paths = (NSLibraryDirectory, NSUserDomainMask, YES); return [[paths objectAtIndex:0] stringByAppendingFormat:@"/Preference"]; } + (NSString *)libCachePath { NSArray * paths = (NSLibraryDirectory, NSUserDomainMask, YES); return [[paths objectAtIndex:0] stringByAppendingFormat:@"/Caches"]; } + (NSString *)tmpPath {return [NSHomeDirectory() stringByAppendingFormat:@"/tmp"]; } + (BOOL)hasLive:(NSString *)path { if ( NO == [[NSFileManager defaultManager] fileExistsAtPath:path] ) { return [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:NULL]; } return NO; }
② ios swift用作缓存的数据库哪个更好
他们各有优点,不能说谁更好!安卓是开源的可定制的系统,所以安卓可以换各种不同风格的桌面,图标等,进行DIY,而IOS做不到!安卓可以安装任何渠道的应用,而IOS做不到(除非越狱)安卓可以更方便在电脑上传输文件,而IOS要复杂许多!安卓可以更方便的去操作系统,限制比较少,而IOS限制比较多!IOS由于系统较为封闭,应用统一性较强,开发规范上比较好,而安卓应用开发有点随性或者说杂乱。IOS的系统由于比较封闭,安全性和稳定性更好点!
③ swift 开发 怎么获得应用所占缓存
请参考下列 Swift 程序:
// 查询当前任务基本信息
let MACH_TASK_BASIC_INFO_COUNT = (sizeof(mach_task_basic_info_data_t) / sizeof(natural_t))
// 准备参数
let name = mach_task_self_
let flavor = task_flavor_t(MACH_TASK_BASIC_INFO)
var size = mach_msg_type_number_t(MACH_TASK_BASIC_INFO_COUNT)
// 分配指针用于获取任务信息
var infoPointer = UnsafeMutablePointer<mach_task_basic_info>.alloc(1)
// 调用查询内存等状况的任务说明
let kerr = task_info(name, flavor, UnsafeMutablePointer(infoPointer), &size)
// 获得信息指针
let info = infoPointer.move()
// 释放指针
infoPointer.dealloc(1)
// 检查返回值是否成功
if kerr == KERN_SUCCESS {
println("内存占用字节数:\(info.resident_size)")
} else {
let errorString = String(CString: mach_error_string(kerr), encoding: NSASCIIStringEncoding)
println(errorString ?? "出现错误,查询失败")
}
④ swift 中三种创建UITableView的方法和之间的区别
UITableView其它一些东西在这里不多讲,这里的就是讲解UITableView的创建。
UITableView的创建有三种方法分别是纯代码、XIB、storyboard。下面就是创建的代码
1.纯代码的创建
首先实例化UITableView(我所有的创建都是在UIViewController类中完成的)
lettableView =UITableView(frame:UIScreen.mainScreen().bounds, style:UITableViewStyle.Plain)
tableView.delegate=self
tableView.dataSource=self
self.view.addSubview(tableView)
必要的几个代理方法
func numberOfSectionsInTableView(tableView:UITableView) ->Int{
return1
}
func tableView(tableView:UITableView, numberOfRowsInSection section:Int) ->Int{
return3
}
这一块是自定义cell
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) ->UITableViewCell{
letcell=TYCodeTableViewCell.codeTableViewCell(tableView)as!TYCodeTableViewCell
returncell
}
下面是具体用纯代码创建cell
class TYCodeTableViewCell:UITableViewCell{
class func codeTableViewCell(tableView :UITableView) ->AnyObject{
let ID ="cell"//设置标记
var cell = tableView.(ID)//从缓存中提取
if cell ==nil {//没有就创建cell
cell =TYCodeTableViewCell(style:UITableViewCellStyle.Default, reuseIdentifier: ID)
//在这里创建cell中的其它控件,是会出现乱序,你的逻辑最好不要在这里实现
}
return cell!//返回cell
}
override func awakeFromNib() {
super.awakeFromNib()
// Initialization code
}
override func setSelected(selected:Bool, animated:Bool) {
super.setSelected(selected, animated: animated)
// Configure the view for the selected state
}
}
以上就是纯代码的创建
XIB的创建
因为我们使用XIB所以它的创建与有点不一样
lettableView =UITableView(frame:UIScreen.mainScreen().bounds, style:UITableViewStyle.Plain)
tableView.delegate=self
tableView.dataSource=self
self.view.addSubview(tableView)
//这里是注册XIB类似纯代码中的创建cell
letnib =UINib(nibName:"TYXIBTableViewCell", bundle:nil)
tableView.registerNib(nib, forCellReuseIdentifier:id)
因为上面已经创建所以下面我只要到缓存中提取就可以了,这里也是自定义cell 为TYXIBTableViewCell
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) ->UITableViewCell{
let cell :TYXIBTableViewCell= (tableView.(id, forIndexPath: indexPath)) as!TYXIBTableViewCell
returncell
}
使用storyboard创建就更加简单了
在这里创建了TableView和cell代码中只要从缓存中提取就可以了
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) ->UITableViewCell{
letcell :TYStoryboardTableViewCell= tableView.("TYStoryboardTableViewCell", forIndexPath: indexPath) as! TYStoryboardTableViewCell
returncell
}
⑤ Taylor Swift 《Mine》空间可用链接不要缓冲慢的~谢啦
音悦台高清MV链接地址:
http://www.yinyuetai.com/video/player/71353/v.swf
,缓冲慢是因为网速慢,跟资源问题不大,这个挺快的。
⑥ swift 如何判断点击的是哪个tabbar
本月初苹果公司在WWDC大会上发布了最新编程语言Swift,Swift语言的发布对于开发者们来说无疑是一项重大的变革。Swift语言的未来发展必将一片光明,想要学习Swift语言的程序猿们赶紧看过来吧!
这套Swift语言视频教程是针对有Objective-C/iOS基础,想转成Swift开发的程序猿们而录制的,视频中从编程语言Swift的语法,结构体,面向对象,继承,闭包到Swift作为iOS开发的UI,地图,网络进行一系列讲解。
视频教程中包含了Swift语法:如何使用Swift进行UI导航控制器,TabBarController,代理设计模式,反向传值,TableView,网络,AFNetworking,图片缓存,Objective-C和Swift进行相互调用的详细讲解。
⑦ swift在tab bar controller显示之前,显示登陆页面
例子如下:把一个TabBarController拖到mainwindow.xib里,有item1和item2解决方法如下:Library里面拖一个TabBarItem进去
⑧ 求taylorswift的lovestory的空间链接
您好,很高兴为你解答问题~
您需要的音乐(歌曲)链接(可用于空间背景音乐)~
【taylorswift的lovestory】
http://qqmusic.xbdj.cn/music/9/31004392.mp3
不要点击链接,直接复制链接到空间去设置即可~
如果不能正常播放请下载使用先前清理缓存,重启下浏览器,刷新下页面~
如果我的回答对你有帮助~
请点击【我回答下】的【选为满意回答】按钮!
回答者/发件人:我们d彼此,记得不要点错(⊙o⊙)哦~
不要收到链接问题放着不处理,浪费网络资源,相互尊重请及时采纳~
相互帮助,相互支持,O(∩_∩)O谢谢~
同求资源者请鼠标放在我账号上点击→【求助知友】按钮@我们d彼此 ,向我提问~
如果收到求助会第一时间帮大家解答(*^__^*) ~
★来自知道团队【网络知道的】★
⑨ swift中struct类型怎么缓存
从速度上来说,struct会好过于class。Swift的struct比Objective-C的struct要强大许多,比如:
自定义init():虽然Swift和Objective-C一样提供默认的init (default memberwise initializer),但是你可以在Swift中定义自己的init(),如:
[objc] view plain
struct Student {
let studentId: String // studentId 和 name 必须赋值
var name: String
var birthday: NSDate? // optional
var gender = 0 // 给一个默认的值
// 自定义init()
init(sid:String) {
studentId = sid // self. 是可选的
// 但是你必须提供所有非optional,没有默认值的stored property的初始值
name = "A Name" // 没有此条会报错
}
}
当你提供了自定义的init后,Swift就不提供默认的memberwise init了。如果你需要同时保留,可以把自定义的init写在extension里面:
[objc] view plain
extension Student {
init(sid: String) {
// ...
}
}
struct可以有方法,下面为Student添加一个描述方法
[objc] view plain
func summary() -> String {
return "\(name) is born on \(birthday)"
}
struct的方法如果需要改变ivar的值,那必须添加mutating关键词
[objc] view plain
mutating func changeName(name:String) {
self.name = name // 没有mutating的话,此条报错
// 当然在这里改变 studentId 还是不可以的,因为它是let
}
struct也可以implement protocol,但是功能非常局限。大多数protocols还是class-only的。
使用struct可以优化代码的性能,因为struct是value type,而不是reference type。也就是说struct只可以有一个owner,它的值也是被而不是以reference的方式传输的。因为不是reference,也没有reference count的计算,所以性能会比class优化一些。