Chinaunix首页 | 论坛 | 博客
  • 博客访问: 75134
  • 博文数量: 48
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 340
  • 用 户 组: 普通用户
  • 注册时间: 2013-12-30 14:22
文章分类

全部博文(48)

文章存档

2014年(47)

2013年(1)

我的朋友

分类: Android平台

2014-01-02 15:26:27


      今天跟大家一起分享下开发中比较难的一个环节,可能很多人看到这个标题就会感觉头很大,的确如果没有良好的编码能力和逻辑思维。

  什么是多线程下载?

  多线程下载其实就是迅雷,BT一些下载原理,通过多个线程同时和服务器连接,那么你就可以榨取到较高的带宽了,大致做法是将文件切割成N块,每块交给单独一个线程去下载,各自下载完成后将文件块组合成一个文件,程序上要完成做切割和组装的小算法。下面我们开始分析程序:

  package cn.demo.DBHelper;

  import android.content.Context;

  import android.database.sqlite.SQLiteDatabase;

  import android.database.sqlite.SQLiteOpenHelper;

  /**

  * 建立一个数据库帮助类

  */

  public class DBHelper extends SQLiteOpenHelper {

  //download.db-->数据库名

  public DBHelper(Context context) {

  super(context, "download.db", null, 1);

  }

  /**

  * 在download.db数据库下创建一个download_info表存储下载信息

  */

  @Override

  public void onCreate(SQLiteDatabase db) {

  db.execSQL("create table download_info(_id integer PRIMARY KEY AUTOINCREMENT, thread_id integer, "

  + "start_pos integer, end_pos integer, compelete_size integer,url char)");

  }

  @Override

  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

  }

  }

  数据库操作要借助单例和同步,来保证线程的执行顺序,以免多个线程争相抢用sqlite资源导致异常出现

  import android.content.Context;

  import android.database.sqlite.SQLiteDatabase;

  import android.database.sqlite.SQLiteOpenHelper;

  /**

  * 建立一个数据库帮助类

  */

  public class DBHelper extends SQLiteOpenHelper {

  //download.db-->数据库名

  public DBHelper(Context context) {

  super(context, "download.db", null, 1);

  }

  /**

  * 在download.db数据库下创建一个download_info表存储下载信息

  */

  @Override

  public void onCreate(SQLiteDatabase db) {

  db.execSQL("create table download_info(_id integer PRIMARY KEY AUTOINCREMENT, thread_id integer, "

  + "start_pos integer, end_pos integer, compelete_size integer,url char)");

  }

  @Override

  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

  }

  }

  想要了解更多有关android 源码的详情可以查询天地会。 


阅读(264) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~