首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >sqlite3_close在iOS应用程序中的应用

sqlite3_close在iOS应用程序中的应用
EN

Stack Overflow用户
提问于 2016-02-10 13:40:03
回答 1查看 300关注 0票数 1

我在我的iOS游戏中使用Sqlite 3来持续/加载他们完成的每一个任务的用户分数(我完成了4k任务)。我的需求是非常基本的;我只有一个sqlite表,我在启动时将所有分数加载并缓存到内存中(在最坏的情况下,内存占用不超过130 k),然后执行一个简单的更新/插入数据库,频率为一次/5分钟。

我的问题:

  • 我是否应该为每个事务创建sqlite3_open()sqlite3_close()数据库,还是在启动时打开数据库,并在应用程序终止时才能继续关闭它?
  • 保持数据库打开是否需要很大的内存成本?
  • 如果应用程序在数据库打开时崩溃,是否有损坏数据的风险?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-10 14:12:49

  1. 当应用程序进入前台时打开数据库,当应用程序进入后台时关闭数据库(这与启动/关闭不同)。还将重新打开逻辑构建到获取数据库句柄的方法中,这样您可以随时关闭它(即内存警告),并且当您想要使用它时,它总是尝试重新打开。您似乎已经注意到,您不想为要执行的每一个查询打开/关闭数据库,因为这有点昂贵。
  2. 不完全是这样;不过,与小图像的大小相比,没有什么。一两个文件句柄,一些缓存内存。不必为那事担心了。
  3. 是。您可以使用事务来降低这种风险,但是,除非您真的担心腐败,否则这不应该是必要的。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35316839

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档