IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> future异步调用方法 -> 正文阅读

[开发工具]future异步调用方法

ListenableFutureTask<List<T>> task = ListenableFutureTask.create(new Callable<List<T>>() {
	@Override
	public List<T> call() throws Exception{
		List<ListenableFuture<List<T>>> = new ArrayList<>();
		futures.add(function);
		List<T> result = new List<T>;
		result.addAll(future.get());
		return result;
	}
});
service.execute(task);

public ListenableFuture<List<T>> funtion(param, values){
	PreparedStatement preStmt;
	Statement stmt = preStmt.bind(param, values);//Statement可以设置query时的一致性 setConsistencyLevel
	return Futures.transform(query(session, statement, new Semaphore(readAsyncNum)), 
	rows -> {
		Result<T> mapResults = mapper.get(rows);
		List<T> results = new ArrayList<>();
		for(T t : mapResults){
			//getAvailableWithoutFetching将返回结果集中的行数,isFullyFetched返回结果集是否从数据库中取尽
			if(result.getAvailableWithoutFetching() == int && !result.isFullyFetched()){
				mapResults.fetchMoreResults();
			}
			t.setColumnValue();
			...
			results.add(t);
		}
		return results;
	}, executor); //executoe可以是线程池,MoreExecutors
}

ResultSetFuture query(Session session, Statement statement, Semaphore semaphore){
	semaphore.acquireUninterruptibly();//设置线程不可抢断
	ResultSetFuture future = session.executeAsync(statement);
	Futures.addCallback(future, new FutureCallBack<ResultSet>() {
		@Override
		public void onSuccess(ResultSet rows) {semaphore.release();}
		
		@Override
		public void onFailure(Throwable throwable) {semaphore.release();}
	}, MoreExecutors.directExecutor());
	return future;
}

Statement

Statement 是 Java 执行数据库操作的一个重要接口,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句。
有三种 Statement 对象,它们都作为在给定连接上执行 SQL 语句的包容器:Statement、PreparedStatement(它从 Statement 继承而来)和 CallableStatement(它从 PreparedStatement 继承而来)。它们都专用于发送特定类型的 SQL 语句: Statement 对象用于执行不带参数的简单 SQL 语句;PreparedStatement 对象用于执行带或不带 IN 参数的预编译 SQL 语句;CallableStatement 对象用于执行对数据库已存在的存储过程的调用。
简单来收,Statement 接口提供了执行语句和获取结果的基本方法。PreparedStatement 接口添加了处理 IN 参数的方法;而 CallableStatement 添加了处理 OUT 参数的方法。
在默认情况下,同一时间每个 Statement 对象在只能打开一个 ResultSet 对象。因此,如果读取一个 ResultSet 对象与读取另一个交叉,则这两个对象必须是由不同的 Statement 对象生成的。

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:45:36  更:2022-03-08 22:47:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/19 21:31:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码