关于多线程访问sqlite 数据库的思考

本文总结了在多线程应用中处理SQLite数据库访问的问题,包括使用`synchronized`关键字防止数据库被锁定,以及如何通过锁机制确保数据库连接在使用期间不被意外关闭,以实现安全的多线程数据库操作。作者建议始终保持一个数据库连接并使用同步控制来避免并发问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在工作中,可能你的用户并没有那么听话,随意的去点击你的按钮,如果你的按钮时间这个时候是在访问同一个sqlite 数据库,那么这个时候你可能会考虑多线程了,这里把我自己遇到的多线程访问数据库中遇到的问题总结于此:

对于单个sqlite文件打开数据库的时候要添加 synchronized 否则会提示:wait for second beause XXXis locked

这里需要一个打开数据库的方法:

<span style="font-size:14px;">public synchronized  static SQLiteDatabase geSDCardSQLiteDatabase(){</span>
<span style="font-size:14px;">
	<span style="white-space:pre">	</span> if (db==null) {	//采用单例模式
			 Boolean tagBoolean =FileUtils.isExists(pathString);
			 db = SQLiteDatabase.openOrCreateDatabase(pathString , null);		
			 if (!tagBoolean) {//如果不存在那么需要创建表			
			  db.execSQL(CreateTable.createTable());
			
			 }				    
		 }			 
			
			 		 
		return db;
}	</span>

这里讲一下为什么要用单例模式:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值