日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

基于Java线程池读取数据库中数据(学习+运用)

發(fā)布時間:2024/1/23 java 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 基于Java线程池读取数据库中数据(学习+运用) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

基于Java線程池讀取數(shù)據(jù)庫中數(shù)據(jù)(學習+運用)

以下是學習內容

Main.java

import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit;public class Main {private static final int CORE_POOL_SIZE = 5;//核心線程數(shù)為5private static final int MAX_POOL_SIZE = 15;//最大線程數(shù)15private static final int QUEUE_CAPACITY = 5;//任務隊列容量為200private static final Long KEEP_ALIVE_TIME = 200L;//等待時間為1Lpublic static void main(String[] args) {//使用阿里巴巴推薦的創(chuàng)建線程池的方式//通過ThreadPoolExecutor構造函數(shù)自定義參數(shù)創(chuàng)建ThreadPoolExecutor executor = new ThreadPoolExecutor(CORE_POOL_SIZE, MAX_POOL_SIZE, KEEP_ALIVE_TIME, TimeUnit.MILLISECONDS,new ArrayBlockingQueue<Runnable>(QUEUE_CAPACITY),new ThreadPoolExecutor.CallerRunsPolicy()); //最后是拒絕策略long start = System.currentTimeMillis();System.out.println("activeCountMain1 : " + Thread.activeCount());for (int i = 1; i <= 10; i++) {MySQL mysql = new MySQL(i);executor.execute(mysql);System.out.println("線程池中線程數(shù)目:" + executor.getPoolSize() + ",隊列中等待執(zhí)行的任務數(shù)目:" + executor.getQueue().size() + ",已執(zhí)行玩別的任務數(shù)目:" + executor.getCompletedTaskCount());}executor.shutdown();while (true) {if (executor.getActiveCount() == 0)break;}System.out.println("activeCountMain2 : " + Thread.activeCount());long end = System.currentTimeMillis();System.out.println("平均每秒可輸出: " + 100000 / (end - start) + " 條");} }

MySQL.java

import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException;import com.mysql.jdbc.Statement;/** * @author 作者 侯麗娟: * @version 創(chuàng)建時間:2021年10月7日 下午1:37:14 * 類說明 */class MySQL implements Runnable{private Connection con = null;private static String driver = "com.mysql.jdbc.Driver";private static String url = "jdbc:mysql://localhost:3306/loan";private static String username = "root";private static String password = "root";private static Statement NULL = null;private final int taskNum;public MySQL(int taskNum) {this.taskNum = taskNum;}public static void main(String[] args) { // MySQL mySQL = new MySQL(1); // Statement state = mySQL.MysqlOpen(); // System.out.println(state); // mySQL.readMySQL();}public Statement MysqlOpen() {try {Class.forName(driver); //加載驅動類con = DriverManager.getConnection(url, username, password); //連接數(shù)據(jù)庫if (!con.isClosed())System.out.println("***數(shù)據(jù)庫成功連接***");Statement state = (Statement) con.createStatement();return state;} catch (ClassNotFoundException e) {System.out.println("找不到驅動程序類,加載驅動失敗");e.printStackTrace();} catch (SQLException e) {System.out.println("數(shù)據(jù)庫連接失敗");e.printStackTrace();}return NULL;}@Overridepublic void run() {readMySQL();}public void readMySQL() {synchronized(MySQL.class){ResultSet sql = null;Statement state = MysqlOpen();try {sql = state.executeQuery("select * from jd_area_info where AreaID between "+ ((taskNum - 1) * 10) + " and " + (taskNum * 10));System.out.println("---------task " + taskNum + "正在執(zhí)行---------");while (sql.next()) {int id = sql.getInt(1);String areaname = sql.getString(3);String areaname2 = sql.getString(5);System.out.println(id + "\t" + areaname + "\t" + areaname2);}} catch (SQLException e) {e.printStackTrace();} finally {try {sql.close();state.close();con.close();} catch (Exception e) {e.printStackTrace();}}System.out.println("---------task " + taskNum + "執(zhí)行完畢---------");}} }

運行結果如下圖所示:

【參考】https://www.jb51.net/article/168823.htm

以下是實際運用

這是Controller中原本取數(shù)據(jù)的方法:

@RequestMapping(value = "/getSensorData", method = RequestMethod.GET)@ApiOperation(value = "通過sensorid獲取所有數(shù)據(jù)")public Result<datashow> getSensorData(HttpServletRequest request){long startTime = System.currentTimeMillis();String startDate = request.getParameter("startDate");String endDate = request.getParameter("endDate");String sid = request.getParameter("sid");System.out.println(sid+":開始時間加結束時間:"+startDate+" "+endDate+"傳感器編號:"+sid);List<SensorWindPressure> list = iSensorWindPressureService.getSensorData(sid,startDate,endDate);log.info("數(shù)據(jù)量大小"+list.size());SensorInfo sensorInfo = iSensorWindPressureService.getDownUpLimit(sid);String uplimit = sensorInfo.getUpLimit();String downlimit = sensorInfo.getDownLimit();long endTime = System.currentTimeMillis();datashow datashow = new datashow();List<String> xdata = new LinkedList<>();List<String> ydata = new LinkedList<>();for (SensorWindPressure sensorWindPressure : list) {xdata.add(sdf.format(sensorWindPressure.getCreateTime()));ydata.add(sensorWindPressure.getValue());}datashow.setXdata(xdata);datashow.setYdata(ydata);System.out.println("代碼運行時間:" + (endTime - startTime) + "ms");datashow.setUplimit(uplimit);datashow.setDownlimit(downlimit);return new ResultUtil<datashow>().setData(datashow); // System.out.println("開始時間加結束時間:"+startDate+" "+endDate+"上限下限:"+uplimit+","+downlimit); // return new ResultUtil<List<SensorWindPressure>>().setData(list,uplimit,downlimit);}

以下是對以上方法的改進,使用多線程進行數(shù)據(jù)讀取:

private static final int CORE_POOL_SIZE = 5;//核心線程數(shù)為5private static final int MAX_POOL_SIZE = 15;//最大線程數(shù)15private static final int QUEUE_CAPACITY = 5;//任務隊列容量為200private static final Long KEEP_ALIVE_TIME = 10L;//等待時間為10s@RequestMapping(value = "/getSensorDataByline", method = RequestMethod.GET)@ApiOperation(value = "通過sensorid獲取所有數(shù)據(jù)")public Result<datashow> getSensorDataByline(HttpServletRequest request) throws Exception{SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd");long startTime = System.currentTimeMillis();String startDate = request.getParameter("startDate");String endDate = request.getParameter("endDate");String sid = request.getParameter("sid");System.out.println(sid+":開始時間加結束時間:"+startDate+" "+endDate+"傳感器編號:"+sid);Date d1=sf.parse(startDate);Date d2=sf.parse(endDate);int len = daysBetween(d1,d2);System.out.println("相差天數(shù):"+len);//使用阿里巴巴推薦的創(chuàng)建線程池的方式//通過ThreadPoolExecutor構造函數(shù)自定義參數(shù)創(chuàng)建ThreadPoolExecutor executor = new ThreadPoolExecutor(CORE_POOL_SIZE,MAX_POOL_SIZE,KEEP_ALIVE_TIME,TimeUnit.SECONDS,new ArrayBlockingQueue<Runnable>(QUEUE_CAPACITY),new ThreadPoolExecutor.CallerRunsPolicy()); //最后是拒絕策略ArrayList<Future<List<SensorWindPressure>>> results=new ArrayList<>();for (int i = 1; i <= len; i++) { // SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();c.setTime(d1);c.add(c.DATE,i);String endDate2 = sf.format(c.getTime());System.out.println("endDate2:"+endDate2+" "+i);c.setTime(d1);c.add(c.DATE,i-1);String startDate2 = sf.format(c.getTime());System.out.println("startDate2:"+startDate2+" "+i);SmokeTask test = new SmokeTask(startDate2,endDate2,sid);Future<List<SensorWindPressure>> future = executor.submit(test);try{while (true) {if(future.isDone() && !future.isCancelled()){System.out.println(future);results.add(future);break;}else {Thread.sleep(1000);}}}catch (Exception e) {e.printStackTrace();}/*try {if(future.isDone()){System.out.println("以下是future:");System.out.println(future);System.out.println(future.get());}} catch (Exception e) {e.printStackTrace();}*/System.out.println("線程池中線程數(shù)目:" + executor.getPoolSize() + ",隊列中等待執(zhí)行的任務數(shù)目:" + executor.getQueue().size()+ ",已執(zhí)行玩別的任務數(shù)目:" + executor.getCompletedTaskCount());} // List<SensorWindPressure> list = iSensorWindPressureService.getSensorData(sid,startDate,endDate);List<SensorWindPressure> list = new ArrayList<>();for (Future<List<SensorWindPressure>> future: results) {try {System.out.println(future);System.out.println(future.get());list.addAll(future.get()); // System.out.println(future.get());} catch (Exception e) {e.printStackTrace();}finally{executor.shutdown();}}System.out.println(list.size());list.sort(Comparator.comparing(SensorWindPressure::getCreateTime)); // log.info("數(shù)據(jù)量大小"+list.size());SensorInfo sensorInfo = iSensorWindPressureService.getDownUpLimit(sid);String uplimit = sensorInfo.getUpLimit();String downlimit = sensorInfo.getDownLimit();long endTime = System.currentTimeMillis();datashow datashow = new datashow();List<String> xdata = new LinkedList<>();List<String> ydata = new LinkedList<>();SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");for (SensorWindPressure sensorWindPressure : list) {xdata.add(sdf.format(sensorWindPressure.getCreateTime()));ydata.add(sensorWindPressure.getValue());}datashow.setXdata(xdata);datashow.setYdata(ydata); // System.out.println("代碼運行時間:" + (endTime - startTime) + "ms");datashow.setUplimit(uplimit);datashow.setDownlimit(downlimit);return new ResultUtil<datashow>().setData(datashow);/*List<SensorWindPressure> list=new ArrayList<>(); //原來寫的,僅供參考String startDate = request.getParameter("startDate");String endDate = request.getParameter("endDate");String sid = request.getParameter("sid");String daybetween = request.getParameter("daybetween");System.out.println(sid+":開始時間加結束時間:"+startDate+" "+endDate+" "+daybetween);SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd");Date date = sf.parse(startDate);Calendar c = Calendar.getInstance();c.setTime(date);c.add(c.DATE,5);date=c.getTime();String startDate1 = sf.format(date);System.out.println(startDate1);/* BlockingQueue<Runnable> queue = new ArrayBlockingQueue<>(10);ThreadPoolExecutor pool = new ThreadPoolExecutor(3, 5, 60, TimeUnit.MICROSECONDS, queue);for(int i=0;i<pool.getPoolSize();i++){Callable task = new SmokeTask(startDate,endDate,sid);Future<List<SensorWindPressure>> f1 = pool.submit(task);System.out.println(f1.get());}pool.shutdown();*/SensorInfo sensorInfo = iSensorWindPressureService.getDownUpLimit(sid);String uplimit = sensorInfo.getUpLimit();String downlimit = sensorInfo.getDownLimit();System.out.println(sid+":開始時間加結束時間:"+startDate+" "+endDate+"上限下限:"+uplimit+","+downlimit);return new ResultUtil<List<SensorWindPressure>>().setData(list,uplimit,downlimit);*/ // return null;}

取數(shù)據(jù)單獨提取出來了:

package cn.exrick.xboot.modules.your.bim.controller;import cn.exrick.xboot.modules.your.bim.entity.SensorWindPressure; import com.mysql.jdbc.Connection; import com.mysql.jdbc.Statement;import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.Date; import java.util.List; import java.util.concurrent.Callable;public class SmokeTask implements Callable<List<SensorWindPressure>> {private Connection con = null;private static String driver = "com.mysql.jdbc.Driver";private static String url = "jdbc:mysql://localhost:3306/shannan";private static String username = "root";private static String password = "root";private static Statement NULL = null;private String startDate;private String endDate;private String sid;public SmokeTask(String startDate,String endDate,String sid){this.startDate = startDate;this.endDate = endDate;this.sid = sid;}// @Autowired // private ISensorWindPressureService iSensorWindPressureService;public Statement MysqlOpen() {try {Class.forName(driver); //加載驅動類con = (Connection) DriverManager.getConnection(url, username, password); //連接數(shù)據(jù)庫if (!con.isClosed())System.out.println("***數(shù)據(jù)庫成功連接***");Statement state = (Statement) con.createStatement();return state;} catch (ClassNotFoundException e) {System.out.println("找不到驅動程序類,加載驅動失敗");e.printStackTrace();} catch (SQLException e) {System.out.println("數(shù)據(jù)庫連接失敗");e.printStackTrace();}return NULL;}@Overridepublic List<SensorWindPressure> call() throws Exception { // List<SensorWindPressure> list = iSensorWindPressureService.getSensorData(sid,startDate,endDate);synchronized (SmokeTask.class){List<SensorWindPressure> list = new ArrayList<>();ResultSet result = null;Statement state = MysqlOpen();try {String sql = "select create_time,value from sensor_wind_pressure where sensor_id = \""+sid+"\" and create_time between \""+startDate+"\" and \""+endDate+"\" order by create_time ASC";result = state.executeQuery(sql);while (result.next()) {Date date = result.getTimestamp(1);String value = result.getString(2); // System.out.println(date + "\t" + value);SensorWindPressure s=new SensorWindPressure();s.setCreateTime(date);s.setValue(value);list.add(s);}} catch (SQLException e) {e.printStackTrace();} finally {try {result.close();state.close();con.close();} catch (Exception e) {e.printStackTrace();}}System.out.println("---------task " + endDate + "執(zhí)行完畢---------");return list;}} }

前端展示如下:

不過這里的代碼還是有些亂,后面可重構得簡潔一些。。。
過程中有遇到Java heap space問題,可參考解釋:https://www.cnblogs.com/bolang100/p/6478537.html

獲取返回結果優(yōu)化:
1、使用ExecutorService的invokeAll函數(shù)
本方法能解決第一個弊端,即并不需要自己去維護一個存儲返回結果的容器。當我們需要獲取線程池所有的返回結果時,只需調用invokeAll函數(shù)即可。
但是,這種方式需要你自己去維護一個用于存儲任務的容器。

// 創(chuàng)建一個線程池 ExecutorService executorService = Executors.newFixedThreadPool(10);// 創(chuàng)建存儲任務的容器 List<Callable<String>> tasks = new ArrayList<Callable<String>>();// 提交10個任務 for ( int i=0; i<10; i++ ) {Callable<String> task = new Callable<String>(){public String call(){int sleepTime = new Random().nextInt(1000);Thread.sleep(sleepTime);return "線程"+i+"睡了"+sleepTime+"秒";}};executorService.submit( task );// 將task添加進任務隊列tasks.add( task ); }// 獲取10個任務的返回結果 List<Future<String>> results = executorService.invokeAll( tasks );// 輸出結果 for ( int i=0; i<10; i++ ) {// 獲取包含返回結果的future對象Future<String> future = results.get(i);// 從future中取出執(zhí)行結果(若尚未返回結果,則get方法被阻塞,直到結果被返回為止)String result = future.get();System.out.println(result); }

2、 使用CompletionService
CompletionService內部維護了一個阻塞隊列,只有執(zhí)行完成的任務結果才會被放入該隊列,這樣就確保執(zhí)行時間較短的任務率先被存入阻塞隊列中。

ExecutorService exec = Executors.newFixedThreadPool(10);final BlockingQueue<Future<Integer>> queue = new LinkedBlockingDeque<Future<Integer>>( 10); //實例化CompletionService final CompletionService<Integer> completionService = new ExecutorCompletionService<Integer>( exec, queue); // 提交10個任務 for ( int i=0; i<10; i++ ) {executorService.submit( new Callable<String>(){public String call(){int sleepTime = new Random().nextInt(1000);Thread.sleep(sleepTime);return "線程"+i+"睡了"+sleepTime+"秒";}} ); }// 輸出結果 for ( int i=0; i<10; i++ ) {// 獲取包含返回結果的future對象(若整個阻塞隊列中還沒有一條線程返回結果,那么調用take將會被阻塞,當然你可以調用poll,不會被阻塞,若沒有結果會返回null,poll和take返回正確的結果后會將該結果從隊列中刪除)Future<String> future = completionService.take();// 從future中取出執(zhí)行結果,這里存儲的future已經擁有執(zhí)行結果,get不會被阻塞String result = future.get();System.out.println(result); }

【參考】https://blog.csdn.net/lijingjingchn/article/details/104491862

總結

以上是生活随笔為你收集整理的基于Java线程池读取数据库中数据(学习+运用)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产成人高清av | 91视频啊啊啊 | 一级片免费观看 | 99热这里精品 | 欧美日韩精品在线观看 | 亚洲区色 | 波多野结衣视频一区 | 国产精品美女免费 | 亚洲国产精品免费 | 欧美色图88| 欧美影院久久 | 亚洲高清激情 | 久久久久久久久久久久久久免费看 | 国产永久免费高清在线观看视频 | 久久午夜羞羞影院 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 国产在线免费观看 | 九九九九九国产 | 成人国产精品一区 | 精品五月天 | 亚洲最大av在线播放 | 成年人视频在线免费观看 | 香蕉视频免费在线播放 | 国产伦精品一区二区三区高清 | 91麻豆精品国产自产在线游戏 | 久久黄色免费 | 亚洲视频第一页 | 九九热国产视频 | 欧美日韩中文国产 | 97超级碰碰 | 亚洲电影影音先锋 | 国产又粗又猛又色又黄网站 | 久久天堂精品视频 | 免费在线观看av不卡 | 免费欧美精品 | 99视频在线精品国自产拍免费观看 | 在线观看成人网 | av成人免费在线 | 国产丝袜网站 | 久久久精品国产免费观看同学 | 成人app在线播放 | 国产成人久久av977小说 | 97视频免费看 | 日韩中文字幕91 | 久久久999 | 亚洲精品www久久久久久 | 欧美精品中文在线免费观看 | 国产视频在线观看一区 | 久久精品精品电影网 | 国产一区二区在线影院 | 久久99国产精品自在自在app | 香蕉视频免费在线播放 | 日日操日日 | 免费69视频| 最新中文字幕在线资源 | 国产婷婷视频在线 | 国产69精品久久久久99 | 蜜桃视频在线观看一区 | 国产伦精品一区二区三区在线 | 久久全国免费视频 | 麻豆小视频在线观看 | 欧美日韩国产综合网 | 精品av在线播放 | 色婷婷免费视频 | 在线视频观看国产 | 日韩中文在线观看 | 欧美韩日在线 | 美女黄网久久 | 91久久奴性调教 | 久久九九影视 | 婷婷综合五月天 | 99久热在线精品视频成人一区 | 婷婷综合亚洲 | 日韩有码欧美 | 久久国产乱 | 麻豆视频免费播放 | 久久综合九色综合久久久精品综合 | www.精选视频.com | 天天草天天摸 | 五月婷在线播放 | 99性视频 | 天天色天天操天天爽 | 免费av视屏 | 麻豆一区在线观看 | 蜜桃视频在线观看一区 | 在线国产欧美 | 国产精品第52页 | 夜夜夜夜爽 | 亚洲爱爱视频 | 亚洲网久久 | 亚洲视频,欧洲视频 | 麻豆影视在线免费观看 | 日韩精品久久久久久 | 亚洲精品一区二区三区高潮 | 色伊人网 | 右手影院亚洲欧美 | 四虎影视成人永久免费观看视频 | 在线亚洲成人 | 99电影| 美女视频黄是免费的 | 最近中文字幕免费av | 中文字幕在线观看你懂的 | 午夜精品视频福利 | 伊甸园永久入口www 99热 精品在线 | 999久久久久久久久6666 | 色 免费观看 | 成人精品国产 | 久久久 激情 | 成人国产综合 | 日韩二级毛片 | 在线激情影院一区 | 日韩欧美一区二区在线播放 | 日韩在线中文字幕视频 | 9999在线视频| 久艹视频在线观看 | 狠狠色丁香婷婷综合最新地址 | 最新中文字幕在线播放 | 欧美色操 | 久久久久久久久久久久久国产精品 | 92av视频| 婷婷亚洲最大 | 国内精品在线一区 | 最近中文字幕大全 | av爱干 | 久久免费观看视频 | 久久国产精品色婷婷 | 日日干天天射 | 国产亚洲资源 | 国产精品久久久久久欧美 | 中文字幕av最新更新 | 国内精品久久天天躁人人爽 | 天天天天天天干 | 精品视频免费久久久看 | 热久久国产精品 | 97在线观看视频国产 | 成人av中文字幕 | 久久久精品一区二区三区 | 99久久婷婷国产综合亚洲 | 国产一级在线视频 | 欧美一级久久久 | 高清精品久久 | 91探花在线视频 | 国产精品自在欧美一区 | 丰满少妇麻豆av | 日韩影视精品 | 久久久国产精品亚洲一区 | 欧美日韩国产一区 | 日韩性xxxx| 国产福利一区在线观看 | 久久久久免费观看 | 亚洲区另类春色综合小说 | 亚洲国产免费网站 | 91在线日韩 | 婷婷午夜激情 | 国产无套精品久久久久久 | 91黄色小网站 | www.日日日.com | 99热精品在线 | 国产黄色理论片 | 9999精品免费视频 | 国产福利av在线 | 久久综合久久综合这里只有精品 | 午夜精品麻豆 | 三级免费黄色 | 99久久精品一区二区成人 | 久久视频在线看 | 狠狠干中文字幕 | 91入口在线观看 | 国产精品亚洲综合久久 | 国产视频日本 | 99中文字幕视频 | 免费热情视频 | 日韩理论片中文字幕 | 久久激情五月婷婷 | 99热在线精品观看 | 成人免费电影 | 中文字幕永久 | 国产麻豆精品一区二区 | 天天综合导航 | 热久久免费视频精品 | 色综合天天狠天天透天天伊人 | 免费视频91蜜桃 | 91亚洲精| 波多野结衣一区二区 | 福利视频第一页 | 国产高清视频在线免费观看 | 99热在线这里只有精品 | 国产精品青草综合久久久久99 | 国产精品麻豆91 | 日韩欧美一区二区在线观看 | 97电影院在线观看 | 亚洲综合涩 | 色5月婷婷| 最新久久久 | 成人免费在线观看电影 | 欧美一进一出抽搐大尺度视频 | v片在线播放| 一区二区三区四区精品视频 | 日韩动漫免费观看高清完整版在线观看 | 97品白浆高清久久久久久 | 色在线网| 亚洲人人爱 | 成人国产精品免费观看 | 99久国产| 天堂资源在线观看视频 | 亚洲成av人片在线观看www | 日韩在观看线 | 国产黄影院色大全免费 | 在线国产视频 | 99精品黄色片免费大全 | 美女一二三区 | 天天色播 | 激情狠狠干 | 97色综合 | 日韩视频图片 | 日本视频久久久 | 成在线播放 | 天堂视频一区 | 午夜精品一区二区三区在线播放 | 91免费视频网站在线观看 | 青春草免费在线视频 | 国产高清在线观看av | 色多多污污在线观看 | 亚洲乱亚洲乱妇 | 九九免费在线看完整版 | 欧美精品第一 | 国产精品观看视频 | 国产在线a | 看v片| av不卡免费看 | 中文字幕一区二区三区在线播放 | 成人在线观看资源 | 一区二区三区四区五区六区 | 国产精品美女在线观看 | 高清av不卡 | av电影不卡 | 国产免费又爽又刺激在线观看 | 午夜精品久久久久久久99热影院 | 91自拍视频在线观看 | 日韩一区二区三区高清免费看看 | 99精品在线免费视频 | 粉嫩av一区二区三区四区在线观看 | 人九九精品 | 九九九热精品 | 91福利视频免费观看 | av中文字幕网址 | 久久久精品国产免费观看同学 | 免费精品国产va自在自线 | japanesefreesex中国少妇 | 欧美精品v国产精品v日韩精品 | 欧美日韩三区二区 | 久久久久久久久亚洲精品 | 一区二区三区播放 | 日韩精品短视频 | 久久一视频 | 亚洲日韩精品欧美一区二区 | 国产又粗又猛又色 | 91精品一区二区三区久久久久久 | 久久精品高清视频 | 天天搞天天干天天色 | 992tv又爽又黄的免费视频 | 欧美成人视 | av高清免费在线 | 玖玖在线免费视频 | 精品国产网址 | 四川妇女搡bbbb搡bbbb搡 | 国产色婷婷在线 | 久草在线免费看视频 | 欧美aa级| 欧美激情精品久久久久久免费印度 | 国产精品自产拍在线观看中文 | 亚洲成人av在线 | 国产成人亚洲精品自产在线 | 中文字幕在线播放第一页 | 在线观看亚洲精品 | 亚洲精品日韩av | 亚洲黄色av网址 | 麻豆果冻剧传媒在线播放 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 亚洲天堂网在线观看视频 | 久草在线中文视频 | 成人国产精品久久久春色 | 精品国产aⅴ一区二区三区 在线直播av | 黄色资源在线观看 | 狠狠操操操 | 婷婷色综| 4p变态网欧美系列 | 中文在线字幕免 | 欧美一区二区三区在线看 | 91香蕉久久 | 国产精品视频久久久 | 五月天久久 | 91丨九色丨国产在线 | 色婷婷激情电影 | 色偷偷网站视频 | av大片免费看 | 国产第一页在线观看 | 欧美极度另类性三渗透 | 成人黄色免费观看 | 精品免费一区二区三区 | 欧美日韩精品电影 | 国产裸体bbb视频 | 欧美aa一级 | av性网站 | a√天堂中文在线 | 日韩精品你懂的 | 日韩免费一级a毛片在线播放一级 | 在线看片a| 五月天堂色 | 日韩一片 | 最近乱久中文字幕 | 国产一二三精品 | 日本视频精品 | 成人黄色在线 | 日韩免费一区二区三区 | 99视频在线免费看 | 人人舔人人干 | 亚洲午夜久久久影院 | 五月天婷亚洲天综合网鲁鲁鲁 | 99热精品免费观看 | 国产视频91在线 | 婷婷伊人综合 | 久久久天堂 | 久久爱导航 | 日本精品视频一区二区 | 日韩av在线影视 | 婷婷精品国产一区二区三区日韩 | 亚洲精品乱码久久久久久蜜桃欧美 | 丁香激情网 | 91精品视频在线观看免费 | 91成人网在线 | 国产情侣一区 | 5月丁香婷婷综合 | 国产 欧美 日产久久 | 日韩中文在线播放 | 9在线观看免费高清完整版 玖玖爱免费视频 | 中文字幕日韩精品有码视频 | 99麻豆久久久国产精品免费 | 久久草网站 | 美女黄视频免费看 | 二区三区精品 | 国产精品一区电影 | 韩国一区二区三区在线观看 | 国产高清av在线播放 | 丰满少妇一级片 | 美女av电影 | 日韩精品视频免费在线观看 | 亚洲精品福利在线观看 | 日韩欧美一区二区三区视频 | 久草视频在线免费 | 人人干狠狠操 | 欧美91精品国产自产 | 亚洲视频观看 | 91亚洲精品久久久中文字幕 | 国产伦精品一区二区三区… | 国产又粗又猛又黄视频 | 亚洲高清视频一区二区三区 | 亚洲高清资源 | 91污在线| 国产亚洲免费观看 | 国产一区二区电影在线观看 | 久久精品国产一区二区电影 | 国外成人在线视频网站 | 国产精品美女毛片真酒店 | 欧美日韩xx | 91aaa在线观看 | 最近中文字幕视频网 | 伊人五月婷 | 人人揉人人揉人人揉人人揉97 | 久久综合九九 | 婷婷在线免费 | 在线观看中文字幕av | 久久艹人人 | 国产精品欧美一区二区三区不卡 | 在线观看完整版免费 | 中中文字幕av在线 | 国产成人免费观看 | 国产五月婷 | 91精品在线观看入口 | 日韩午夜电影网 | 在线视频 91 | 狠狠干夜夜操 | 国内精品在线看 | 成人午夜电影网站 | 91精品国产综合久久婷婷香蕉 | 久久人人爽人人爽人人片av免费 | 久久久久久免费视频 | 亚洲五月激情 | 日日天天狠狠 | 久久天天草| 97视频免费观看2区 亚洲视屏 | 99亚洲天堂 | 精品一区二区在线免费观看 | 午夜免费电影院 | 96国产精品视频 | 国产精品一区二区三区在线看 | 国产视频黄 | 欧美日韩久久久 | 色视频成人在线观看免 | 天天躁日日 | 国产成人性色生活片 | 一区二区三区日韩在线 | 97精品国自产拍在线观看 | 97超碰超碰| 国产精品美女久久久久久 | 久久久久久免费毛片精品 | 久久影视精品 | 色婷婷啪啪免费在线电影观看 | 亚洲欧洲一区二区在线观看 | 97视频人人澡人人爽 | 美国av大片| 狠狠色丁香久久综合网 | 国产香蕉久久精品综合网 | 首页中文字幕 | 开心激情网五月天 | 久久九精品 | 日韩免费视频网站 | 成人午夜电影免费在线观看 | 亚洲精品综合一区二区 | 日韩视频一区二区 | 久久久久亚洲精品成人网小说 | 国产高清日韩 | 日日夜夜精品视频天天综合网 | 国产成人在线看 | 韩国一区在线 | 欧美日韩国产一区二 | 日韩欧美国产免费播放 | 毛片1000部免费看 | 日韩大陆欧美高清视频区 | 午夜少妇av| av不卡免费看 | 国产精品完整版 | 国产精品免费在线播放 | 久久久久久久久久久久久9999 | 久草久草久草久草 | 成人免费在线电影 | 欧美日韩中文字幕在线视频 | 日韩精品你懂的 | 国产在线观看a | 天天色天天艹 | 韩国精品福利一区二区三区 | 丁香婷婷激情啪啪 | 久久精品综合视频 | 麻豆免费观看视频 | 精品国产一区二 | 日本韩国精品在线 | 婷婷成人亚洲综合国产xv88 | 亚洲成人av片在线观看 | 91污在线| 亚洲aⅴ一区二区三区 | 成人国产精品免费 | 国模视频一区二区三区 | 亚洲精品午夜一区人人爽 | 久久色亚洲 | 一区二区三区四区五区在线视频 | 狠狠干婷婷色 | 人人澡人人添人人爽一区二区 | 免费观看第二部31集 | 成人国产精品 | 精品国产免费一区二区三区五区 | 黄网站a | 久久免费视频观看 | 精品二区久久 | 国产原创中文在线 | 欧美日韩久久 | 精品视频免费久久久看 | 精品v亚洲v欧美v高清v | 中文字幕免费 | 国产福利免费在线观看 | 热久久免费国产视频 | 国产69熟| 99热精品在线 | 激情婷婷亚洲 | 中文字幕精 | www五月天| 中文字幕在线观看免费观看 | 麻豆91在线观看 | 国产精品大片免费观看 | 日韩福利在线观看 | 中文字幕 国产视频 | 日韩精品久久久久久久电影竹菊 | 国产日韩av在线 | 精品国产一区二区三区日日嗨 | 亚洲精品视频在线观看免费视频 | 日韩av中文| 久久久国产精品网站 | 亚洲激情av | 日韩视频一区二区三区在线播放免费观看 | 一级免费看 | 狠狠色狠狠色综合日日92 | 国产探花视频在线播放 | 久久国产美女视频 | 久久久久国产成人免费精品免费 | 国产 日韩 在线 亚洲 字幕 中文 | 久久久影视 | 国产又粗又猛又爽又黄的视频先 | 毛片基地黄久久久久久天堂 | 黄色在线看网站 | 永久精品视频 | 黄色三级免费看 | 人人看97 | 91成人在线看 | 日韩高清一区在线 | 99视频+国产日韩欧美 | 欧美国产视频在线 | 国产视频精品免费播放 | www夜夜| 日韩专区在线观看 | 天天做天天爱天天综合网 | 久久乐九色婷婷综合色狠狠182 | 99999精品视频 | 69精品久久久| 亚洲黄网址 | 亚洲高清视频在线观看免费 | 国产一区欧美日韩 | 久久五月情影视 | 国产男女免费完整视频 | 1024在线看片 | 日韩欧美精品免费 | 天天干天天搞天天射 | 欧洲色综合 | 一区二区久久久久 | 久久五月天综合 | 久久公开免费视频 | 久久国产精品免费观看 | 波多野结衣电影一区二区三区 | 99热这里| 国产视频日韩 | 偷拍精偷拍精品欧洲亚洲网站 | 日日躁天天躁 | 久久久黄色免费网站 | 国产一级不卡视频 | 欧美在线91 | 激情综合色综合久久综合 | 精品亚洲在线 | www.五月天婷婷.com | 亚洲成aⅴ人在线观看 | 亚洲视频每日更新 | 国产精品久久免费看 | 日韩电影一区二区在线 | 国产女人18毛片水真多18精品 | 九九久久久| 91看片在线免费观看 | 在线视频观看成人 | 特级西西444www高清大视频 | 国产99一区 | 久久精品视频播放 | 黄色一级大片在线观看 | 亚洲人久久久 | av片在线观看免费 | 国产精品免费观看久久 | 亚洲人xxx| 国产亚洲综合性久久久影院 | 粉嫩av一区二区三区四区五区 | 国产精品久久亚洲 | 黄网站色成年免费观看 | 国产日产精品一区二区三区四区的观看方式 | 国产一级a毛片视频爆浆 | av电影中文 | 日韩超碰 | 欧美久久久久久久久久久久久 | 97影视| 亚洲欧洲国产视频 | 91av在线视频播放 | 成人黄在线观看 | 国产高清区 | 91久草视频 | 人人干人人干人人干 | 国产高清在线 | 激情婷婷综合 | 精品人妖videos欧美人妖 | 国产日产高清dvd碟片 | 美女视频黄免费 | 91麻豆精品国产自产 | 五月激情久久 | 亚洲精品免费在线观看视频 | 亚洲成人中文在线 | 91视频a | 九九免费观看全部免费视频 | 日韩高清在线观看 | 久99久视频| 免费观看黄 | 天天色天天艹 | 在线观看的av| 99热99热 | 亚洲精品在线观看免费 | 欧美极品在线播放 | 欧美黄网站 | 香蕉视频在线免费看 | 插综合网 | 2023天天干| 中文字幕不卡在线88 | 亚洲一区av | 国产精品资源 | 国产高清在线看 | 久久视频免费在线 | 久久一区二区三区日韩 | 国产玖玖精品视频 | 久久久久久欧美二区电影网 | 午夜免费电影院 | 奇米网在线观看 | 久久国产欧美日韩精品 | 久久久久久国产一区二区三区 | 国产精品一区在线观看 | 激情综合色播五月 | 青草视频免费观看 | av在线播放中文字幕 | 午夜av不卡 | 天天射天天艹 | 碰超在线 | 欧美一级在线看 | 一级黄毛片| 亚洲视频 中文字幕 | 天天操天天干天天操天天干 | 免费在线观看黄网站 | 亚洲精品在线播放视频 | 亚洲综合视频在线播放 | 日韩av在线网站 | 国产99在线播放 | 亚洲天天综合网 | 天天爽人人爽夜夜爽 | 三级黄色在线观看 | 午夜精品久久久久久久99婷婷 | 欧美日韩高清在线一区 | 国产色视频| 在线观看一区二区视频 | 久久艹久久 | 国产在线精品一区二区三区 | 久草在线这里只有精品 | 国产香蕉视频在线播放 | 久久爱www. | 中文字幕五区 | 免费久久视频 | 国产成人一区二区在线观看 | 国产视频美女 | 日韩免费成人av | 国产手机在线观看视频 | 日本h在线播放 | 人人射人人澡 | 国产精品视频线看 | 久草在线观看 | 91福利视频一区 | 色偷偷男人的天堂av | 日韩在线观看视频一区二区三区 | 麻豆果冻剧传媒在线播放 | 中文字幕九九 | 狠狠干狠狠久久 | 色国产精品 | 亚洲欧洲精品视频 | 丁香在线观看完整电影视频 | 午夜精品视频福利 | 在线看欧美| 在线欧美日韩 | 欧美与欧洲交xxxx免费观看 | 亚洲精选国产 | 丁香免费视频 | 91香蕉视频色版 | 国产区久久 | 韩日电影在线观看 | 欧美综合在线视频 | 2019天天干天天色 | 久久99九九99精品 | 中文字幕在线观看视频一区二区三区 | 999成人免费视频 | 91在线公开视频 | 波多野结衣视频在线 | 日本在线观看视频一区 | 久久99久国产精品黄毛片入口 | 国产成人免费网站 | 精品免费一区 | 国产在线理论片 | 中文字幕在线观看的网站 | 日韩欧美精品在线视频 | 狠狠躁日日躁夜夜躁av | 国产在线观看免 | 91精品国| 午夜久久久久久久久久久 | 日韩中文字幕一区 | 91网免费观看 | 亚洲国产成人av网 | 亚洲成年片 | 最近中文字幕在线中文高清版 | 大型av综合网站 | 在线精品在线 | 狠狠综合久久 | 久久伊99综合婷婷久久伊 | 久久香蕉影视 | av在线电影网站 | 亚洲三级性片 | 女人高潮特级毛片 | 美女国产精品 | 五月天久久久 | 国产精品美乳一区二区免费 | 亚洲网站在线 | 日韩欧美视频 | 国产成人高清在线 | 国产精品久久久久久久久费观看 | 精品人妖videos欧美人妖 | 日韩电影一区二区在线 | 人人射人人爽 | 日韩美一区二区三区 | 人人看人人爱 | 在线免费亚洲 | 狠狠综合| 欧美在线观看视频免费 | 欧美激情精品久久久久久变态 | www黄在线 | 亚洲年轻女教师毛茸茸 | 国产精品久久久久久电影 | 免费麻豆网站 | 久久精品免费播放 | 国产一级片在线播放 | 在线之家免费在线观看电影 | 国产一级高清视频 | 亚洲不卡av一区二区三区 | 久久久九色精品国产一区二区三区 | 韩国一区视频 | 丁香六月久久综合狠狠色 | 91在线看视频免费 | 91麻豆精品一区二区三区 | 婷婷网站天天婷婷网站 | 97成人资源站 | 久久99国产精品视频 | 欧美日bb | av电影在线免费观看 | 欧美a级成人淫片免费看 | 激情网五月 | 国产精品毛片一区视频播不卡 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 99久久99久久精品国产片果冰 | 日韩视频中文字幕在线观看 | 中文字幕永久免费 | 免费三级大片 | 国产福利精品视频 | www成人精品 | 欧美视频日韩视频 | 黄色片视频免费 | 日本精品在线 | 麻豆视频免费播放 | 国产 日韩 欧美 中文 在线播放 | 四虎亚洲精品 | 亚洲精品美女视频 | 99欧美视频 | 亚洲国产欧美在线看片xxoo | 国产玖玖视频 | 黄色av播放 | 六月丁香婷婷久久 | 久久国产区 | 国产在线看一区 | 成人av影视在线 | 日日夜夜操操操操 | 337p西西人体大胆瓣开下部 | 成片免费观看视频大全 | 在线视频 成人 | 91精品国产九九九久久久亚洲 | 成人av中文字幕在线观看 | 久久久91精品国产一区二区三区 | 91精品国产自产在线观看 | 五月香视频在线观看 | 国产专区精品视频 | 天天操福利视频 | 少妇bbw搡bbbb搡bbb| 亚洲自拍av在线 | 国产精品成人一区二区三区 | 夜夜高潮夜夜爽国产伦精品 | 97人人模人人爽人人少妇 | 亚洲女欲精品久久久久久久18 | 久久香蕉影视 | 韩日电影在线观看 | 最新国产精品亚洲 | 中文字幕免费国产精品 | 99久久久国产精品免费99 | www.久久成人 | 久久久影院一区二区三区 | 在线精品视频免费观看 | 国产精品成人一区二区 | 日韩影视大全 | 国产精品对白一区二区三区 | av福利在线| 九九热在线视频免费观看 | 免费看国产精品 | 天天天干天天天操 | 99免费在线视频 | 91精品国产亚洲 | 四虎永久精品在线 | 日韩a免费| 国产精品第一页在线 | 伊人官网| 黄色精品免费 | 国产在线观看,日本 | www最近高清中文国语在线观看 | 西西4444www大胆视频 | 色综合中文字幕 | 中文字幕观看av | 视频三区| 青青射 | 99 色| 亚洲在线资源 | 五月开心色 | 毛片视频电影 | www.久久色 | 91精品视频免费在线观看 | 久久影院午夜论 | 久久精品国产精品亚洲精品 | 日韩免费观看一区二区 | 久久视频免费在线 | 成人中心免费视频 | 少妇自拍av | 日韩黄色中文字幕 | 97超碰人人干 | 在线精品观看 | 天天操天天干天天爱 | 色综合久久天天 | 久草视频在线新免费 | 又色又爽的网站 | 亚洲欧洲xxxx | 国产亚洲免费的视频看 | 97在线观看免费高清完整版在线观看 | a视频在线观看免费 | 国产又粗又猛又色又黄视频 | 精品久久免费看 | 欧美 高跟鞋交 xxxxhd | 欧美性爽爽 | 欧美国产不卡 | 黄色小说网站在线 | 综合中文字幕 | 一区二区在线电影 | 久久男人免费视频 | 射射射综合网 | 久久五月天综合 | 激情开心 | 午夜视频日本 | 亚洲狠狠丁香婷婷综合久久久 | 国产1级毛片 | 亚洲电影图片小说 | av电影中文 | 久久久久免费观看 | 日韩性xxxx| 999久久久免费精品国产 | 欧美午夜寂寞影院 | 中文字幕视频一区二区 | 人人爱天天操 | 国产成人精品日本亚洲999 | 国产在线a| 久久久国产日韩 | 天天婷婷 | 青青网视频 | 99视频精品全国免费 | 91精品资源| www麻豆视频 | 精品视频亚洲 | 亚洲无在线 | 精品国产_亚洲人成在线 | 精品国产免费久久 | 久久这里只有精品1 | 久久一视频 | 国产亚洲精品久久久久久 | 精品91在线 | 久久精品成人欧美大片古装 | 81国产精品久久久久久久久久 | 亚洲精欧美一区二区精品 | 亚洲欧洲国产精品 | 伊人五月在线 | 九九一级片 | 中文在线中文资源 | 久久久国产影视 | 97干com| 天天操福利视频 | 亚洲精品午夜aaa久久久 | 中文字幕av一区二区三区四区 | 97人人爽人人| 中文区中文字幕免费看 | 国产免费久久av | 亚洲午夜精品久久久 | 一区二区三区四区不卡 | 日本久久久久久久久久久 | 操高跟美女 | 免费网站看v片在线a | 亚洲欧美日韩一级 | 午夜国产福利在线观看 | 欧美日韩国产一区 | 国产精品成人在线 | 国产成人三级 | 99热精品国产一区二区在线观看 | 亚洲欧美视频在线 | 国产视频18 | 啪啪免费试看 | 麻豆传媒视频观看 | 一级黄色网址 | 亚洲欧美成人 | 国产91对白在线 | 婷五月激情 | 超碰在线日本 | 丁香六月久久综合狠狠色 | 免费亚洲视频在线观看 | 国产91精品久久久久 | 西西www4444大胆在线 | 日韩精品短视频 | 日韩免费观看高清 | 在线观看成人小视频 | 国产欧美日韩视频 | 一区二区不卡视频在线观看 | 国产成人精品av | 久热爱| 五月天,com | 久久99精品热在线观看 | 亚洲精品美女久久 | 久草视频中文 | 国产精品一区二区三区久久 | 天天射天天射天天 | 西西4444www大胆视频 | av一区二区三区在线观看 | 国产香蕉97碰碰久久人人 | 中文国产字幕在线观看 | 精品久久免费 | 久久高清视频免费 | 五月婷婷毛片 | 日本成址在线观看 | 亚洲欧美国产精品 | 亚洲国产日韩欧美 | 亚洲天堂首页 | 激情久久一区二区三区 | 亚洲成人中文在线 | 99re久久精品国产 | 成人影视免费 | 亚洲国产高清在线观看视频 | 亚洲久久视频 | 久久久久久久久久久久av | 久久香蕉国产精品麻豆粉嫩av | 精品中文字幕视频 | 日韩久久在线 | 在线播放 日韩专区 | 一区二区视频在线免费观看 | 久久精品爱爱视频 | 国产成人精品综合久久久 | 免费久久视频 | 久久99精品国产99久久 | 欧美污污网站 | av一区二区三区在线观看 | 丝袜+亚洲+另类+欧美+变态 | 国产麻豆成人传媒免费观看 | 国产精品一区二区三区免费看 | 亚洲激情网站免费观看 | 女人18毛片90分钟 | 国产精品一区免费在线观看 | 国内99视频 | 欧美精品在线观看一区 | 国产香蕉97碰碰碰视频在线观看 | 亚洲一级免费电影 | 色综合 久久精品 | 色永久免费视频 | 亚洲国产午夜 | 在线成人短视频 | 国产99久久久国产精品免费看 | 美女免费视频一区 | 亚洲精品视频二区 | 久久综合给合久久狠狠色 | 日韩在线首页 | 亚洲黄色av一区 | 狠狠夜夜 | 国产乱码精品一区二区三区介绍 | 婷婷中文字幕综合 | 日本在线观看一区二区 | 亚洲国产午夜视频 | 成年人视频免费在线播放 | 永久免费毛片 | 韩国精品福利一区二区三区 | 国产在线观看免费观看 | 最新中文字幕在线资源 | 欧美91视频 | 欧美一级片在线 | 精品久久久久久电影 | 国产美女永久免费 | 欧美精品视 | 91午夜精品| 国产亚洲精品bv在线观看 | 伊人成人久久 | 黄色一级片视频 | 国产精品在线看 | 亚洲国产资源 | 免费一级黄色 | 欧美在线观看视频一区二区 | 激情欧美丁香 | 久久久久电影 | 9999在线观看 | 中文综合在线 | 在线看片成人 | 99久久毛片| 美女av在线免费 | 亚洲影院天堂 | 成人免费91| 99这里都是精品 | 久久www免费视频 | www在线观看视频 | 99精品在线观看视频 | 国产午夜三级一区二区三桃花影视 | 久久久精品国产一区二区三区 | 在线小视频你懂得 |