sqliteDataBase 到底是不是线程安全的

   数据库操作实际上就是操作数据库文件。

   在android 2.3.7之前,insertWithOnConflict方法里,在获取sqliteStatement的执行数据库的代码块前后有lock() ....  finally{... unlock()},所以对同一个DataBase,就做到了不同线程间的互斥;

   在abdroid 4.0以上,源码去掉了lock(), 对于同一个DataBase,每个线程都会持有一个sqliteStatement,每个线程都持有唯一一个sqliteSession,并且一个session也只属于一个线程,这样保证了事务并发。每个线程在dataBase这一层中都是异步的,最终在native层访做的同步控制

   

时间: 2024-12-23 20:22:07

sqliteDataBase 到底是不是线程安全的的相关文章

朴素的UNIX之-进程/线程模型

UNIX的传统倾向于将一个任务交给一个进程全权受理,但是一个任务内部也不仅仅是一个执行绪,比如一个公司的所有成员,大家都在做同一件事,每个人却只负责一部分,粒度减小之后,所有的事情便可以同时进行,不管怎样,大家还都共享着所有的资源.因此就出现了线程.线程其实就是共享资源的不同的执行绪.线程的语义和朴素的UNIX进程是不同的. 0.原始进程模型-著名的fork调用 朴素的UNIX进程依托于著名的fork调用,就是这个fork调用让UNIX进程和Windows进程截然不同,也正是因为这个fork调用

i++ 是线程安全的吗?

相信很多中高级的 Java 面试者都遇到过这个问题,很多对这个不是很清楚的肯定是一脸蒙逼.内心肯定还在质疑,i++ 居然还有线程安全问题?只能说自己了解的不够多,自己的水平有限. 先来看下面的示例来验证下 i++ 到底是不是线程安全的. 1000个线程,每个线程对共享变量 count 进行 1000 次 ++ 操作. static int count = 0; static CountDownLatch cdl = new CountDownLatch(1000); /** * 微信公众号:Ja

Kotlin 协程真的比 Java 线程更高效吗?

本文首发于 vivo互联网技术 微信公众号? 链接:https://mp.weixin.qq.com/s/-OcCDI4L5GR8vVXSYhXJ7w 作者:吴越 网上几乎全部介绍Kotlin的文章都会说Kotlin的协程是多么的高效,比线程性能好很多,然而事情的真相真是如此么? 协程的概念本身并不新鲜,使用C++加上内嵌汇编,一个基本的协程模型50行代码之内就可以完全搞出来.早在2013年国内就有团队开源了号称支持千万并发的C++协程库 libco. 最近几年协程的概念越来越深入人心,主要还是

高效解决「SQLite」数据库并发访问安全问题,只这一篇就够了

Concurrent database access 本文译自:https://dmytrodanylyk.com/articles/concurrent-database/ 对于 Android Dev 而言,有关 SQLite 的操作再经常不过了,相比你一定经历过控制台一片爆红的情况,这不禁让我们疑问:SQLite 到底是线程安全的吗? OK 废话不多说,我们 ?? 直接开始 首先,假设你已经实现了一个 SQLiteHelper 类,如下所示: public class DatabaseHe

JStack分析cpu消耗过高问题

1. top找到目标进程,记下pid 2. top –p pid, 并用shift+h打开线程模式     这样可以看到这个进程中,到底哪个线程占用大量cpu     记下threadid,tid 3. jstack查看该线程实时的stack情况     jstack [pid]|grep -A 10 [tid(16进制)] , 10表示打印stack的长度,可以选择打印更多的stack信息    比如,jstack 21125|grep -A 10 52f1 http://www.iteye.

多线程同步条件变量(转载)

最近看<UNIX环境高级编程>多线程同步,看到他举例说条件变量pthread_cond_t怎么用,愣是没有看懂,只好在网上找了份代码,跑了跑,才弄明白 [cpp] view plaincopy #include <pthread.h> #include <stdio.h> #include <stdlib.h> pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;/*初始化互斥锁*/ pthread_cond_

pthread_count_t与pthread_mutex_t的运用

#include <pthread.h> #include <stdio.h> #include <stdlib.h> pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;/*初始化互斥锁*/ pthread_cond_t cond = PTHREAD_COND_INITIALIZER;/*初始化条件变量*/ void *thread1(void *); void *thread2(void *); int i=1; in

iOS中你必须了解的多线程

多线程概念详解 什么是进程? 简单的说进程就是我们电脑上运行的一个个应用程序,每一个程序就是一个进程,并且每个进程之间是独立的,每个进程运行在其专用受保护的内存空间内(window系统可以通过任务管理器进行查看,Mac系统中可以通过活动监视器对其进行查看) 什么是线程? 通过上面的介绍我们知道了什么是进程,那么如何让进程运行起来,这个时候就要有线程了,也就是说每个应用程序想要跑起来,最少也要有一条线程存在,其实应用程序启动的时候我们的系统就会默认帮我们的应用程序开启一条线程,这条线程也叫做'主线

【腾讯Bugly干货】Android性能优化典范之多线程篇

本文涉及的内容有:多线程并发的性能问题,介绍了 AsyncTask,HandlerThread,IntentService 与 ThreadPool 分别适合的使用场景以及各自的使用注意事项,这是一篇了解 Android 多线程编程不可多得的基础文章,清楚的了解这些 Android 系统提供的多线程基础组件之间的差异以及优缺点,才能够在项目实战中做出最恰当的选择. 1. Threading Performance 在程序开发的实践当中,为了让程序表现得更加流畅,我们肯定会需要使用到多线程来提升程