苏州培训网 > 苏州JAVA培训机构 > 苏州其然软件开发培训
首页 培训网 最新资讯 热门问答

苏州其然软件开发培训

免费试听

您当前的位置: 资讯首页 > JAVA培训资讯 > 常熟Java培训机构哪家好_常熟JAVA培训

常熟Java培训机构哪家好_常熟JAVA培训

来源:教育联展网    编辑:佚名    发布时间:2018-10-29

常熟Java培训机构哪家好
其然IT 教育环境

常熟Java培训机构哪家好

常熟Java培训机构哪家好

自学java与java培训该如何选择

常熟Java培训机构哪家好

从事IT培训行业这些年,身边经常有朋友来咨询,问现在是否可以加入这个高薪行业,Java学习难不难,需要哪些条件?

在软件开发设计行业当中,使用**多的编程语言就属Java软件开发了,很多人都想在Java编程开发领域寻求一份工作。

Java是当前世界上比较流行的计算机编程语言,Java彻底改变了人们的生活,国内的开发人才需求量仍然在不断的增长,主要原因还是在于移动互联网的快速发展,衍生出一大批的新生企业,创业公司,预计在未来5年内Java软件开发人才的需求将会远大于供给,其中java程序员、java工程师**为缺乏。

自学java与java培训是两个绕不开的话题,两者的区别,前者知识是自己搜寻的,买书看或者网上找视频看,而后者,技术知识是老师教的,作为一个普通大学生实际上任何人都能够自学,只不过聪明程度和坚持的时间长短不同,花费的时间长一点短一点而已。

学习关乎到时间和金钱,没有效果和质量的培训,其实是没有任何意义的。Java培训班有哪些呢?市面上的Java培训良莠不齐,选择时应该慎重些。Java致力于打造符合企业需求的全能型人才。课程定位定位中高级JAVA开发工程师,课程内容涉及面广,内容深。课程涵盖了Java、Web,数据库,企业流行框架,Java等企业**佳实践、云计算大数据课程、内容由浅入深,剖析原理,让学员掌握实用技术,做企业和社会需要的稀缺人才。

此外,Java培训将为你提供就业保障,开设有就业指导课,设有专门的就业指导老师,在毕业前期,毕业之际,就业老师会为你做专门的就业指导,更有职业素养课程,不仅将你打造成Java开发技术达人,更是一位懂得职场之道的合格就业者。还有丰富的Java学习视频免费为你提供学习。

java工程师课程


常熟Java培训机构哪家好

课程大纲

一阶段 二阶段 三阶段
  • 语言基础、Java基础

  • Java多线程

  • Java网络编程

  • 程序调试/单元测试

  • XML

  • 数据库

  • 数据结构与算法

  • Html/Css/Javascript

  • Html5开发

  • CSS3

  • CSS命名规范、优化 、使用技巧

  • JSP、Servlet、Ajax 、数据库缓冲池、Tomcat

  • 项目开发流程及管理 、CMMI

  • 云计算

  • 大数据

  • 设计模式

  • MyBatis

  • Redis

  • Spring

  • SpringBoot

  • JMS

  • SpringCloud

  • Docker

  • Java前沿技术 常用 企业解决方案

  • UML/OOD/OOP

断点后台**


>

首先看效果图:

实现思路:使用HttpURLConnection和AsyncTask(便于及时取消任务,实现暂停**的功能)实现断点**,将**进度保存到数据库中,每次打开程序时遍历数据库,设置进度调的初始状态。

数据库操作:

DownloadContract类,包含表名,字段名

public class DownloadContract { // 为了防止有人意外地实例化合同类,使构造函数私有。 PRivate DownloadContract() { } /* 内部类定义表的内容 */ public static class DownloadEntry implements BaseColumns { public static final String TABLE_NAME = "downloadentry"; public static final String COLUMN_NAME_TID = "tid"; public static final String COLUMN_NAME_JINDU = "jindu"; public static final String COLUMN_NAME_YIXIAZAI = "yixiazai"; public static final String COLUMN_NAME_PATH = "path"; } }

SQLTool类,包含创建,删除表的语句

public class SQLTool { private static final String TEXT_TYPE = " TEXT"; private static final String INTEGER_TYPE = " INTEGER"; private static final String COMMA_SEP = ","; public static final String SQL_CREATE_ENTRIES = "CREATE TABLE " DownloadContract.DownloadEntry.TABLE_NAME " (" DownloadContract.DownloadEntry._ID " INTEGER PRIMARY KEY," DownloadContract.DownloadEntry.COLUMN_NAME_TID INTEGER_TYPE COMMA_SEP DownloadContract.DownloadEntry.COLUMN_NAME_JINDU INTEGER_TYPE COMMA_SEP DownloadContract.DownloadEntry.COLUMN_NAME_YIXIAZAI INTEGER_TYPE COMMA_SEP DownloadContract.DownloadEntry.COLUMN_NAME_PATH TEXT_TYPE " )"; public static final String SQL_DELETE_ENTRIES = "DROP TABLE IF EXISTS " DownloadContract.DownloadEntry.TABLE_NAME; }

DownloadDbHelper类,继承SQLiteOpenHelper

public class DownloadDbHelper extends SQLiteOpenHelper { // 如果更改数据库模式,则必须增加数据库版本。 public static final int DATABASE_VERSION = 1; public static final String DATABASE_NAME = "dl.db"; public DownloadDbHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase sqLiteDatabase) { sqLiteDatabase.execSQL(SQL_CREATE_ENTRIES); } @Override public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) { // 这个数据库只是一个用于在线数据的缓存,因此其升级策略是简单地丢弃数据并重新开始 sqLiteDatabase.execSQL(SQL_DELETE_ENTRIES); onCreate(sqLiteDatabase); } @Override public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) { onUpgrade(db, oldVersion, newVersion); } }

DAOHelper类,包含增删改查操作

public class DAOHelper { private DownloadDbHelper downloadDbHelper; public DAOHelper(Context context) { downloadDbHelper = new DownloadDbHelper(context); } public long add(Download download) { // 以写入模式获取数据存储库 SQLiteDatabase db = downloadDbHelper.getWritableDatabase(); //创建一个新的值映射,其中列名称是键 ContentValues values = new ContentValues(); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_TID, download.gettId()); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_JINDU, download.getJindu()); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_YIXIAZAI, download.getYixiazai()); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_PATH, download.getPath()); // 插入新行,返回新行的主键值,-1表示插入失败 long newRowId = db.insert(DownloadContract.DownloadEntry.TABLE_NAME, null, values); return newRowId; } public void delete(int tID) { SQLiteDatabase db = downloadDbHelper.getWritableDatabase(); // 定义查询的“where”部分。 String selection = DownloadContract.DownloadEntry.COLUMN_NAME_TID " LIKE ?"; // 在占位符顺序中指定参数。 String[] selectionArgs = {tID ""}; // 发出SQL语句。 db.delete(DownloadContract.DownloadEntry.TABLE_NAME, selection, selectionArgs); } public int update(Download download) { SQLiteDatabase db = downloadDbHelper.getReadableDatabase(); ContentValues values = new ContentValues(); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_JINDU, download.getJindu()); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_YIXIAZAI, download.getYixiazai()); values.put(DownloadContract.DownloadEntry.COLUMN_NAME_PATH, download.getPath()); // 要更新的行 String selection = DownloadContract.DownloadEntry.COLUMN_NAME_TID " LIKE ?"; String[] selectionArgs = {download.gettId() ""}; // 得到受影响的行数 int count = db.update( DownloadContract.DownloadEntry.TABLE_NAME, values, selection, selectionArgs); return count; } public boolean select(int tID) { SQLiteDatabase db = downloadDbHelper.getReadableDatabase(); String[] projection = { DownloadContract.DownloadEntry.COLUMN_NAME_TID, DownloadContract.DownloadEntry.COLUMN_NAME_JINDU, DownloadContract.DownloadEntry.COLUMN_NAME_YIXIAZAI, DownloadContract.DownloadEntry.COLUMN_NAME_PATH }; String selection = DownloadContract.DownloadEntry.COLUMN_NAME_TID " = ?"; String[] selectionArgs = {tID ""}; String sortOrder = DownloadContract.DownloadEntry.COLUMN_NAME_TID " DESC"; Cursor c = db.query( DownloadContract.DownloadEntry.TABLE_NAME, projection, selection, selectionArgs, null, null, sortOrder ); if (c.moveToFirst()) { return true; } else { return false; } } public List<Download> selectAll() { List<Download> dataList = new ArrayList<Download>(); SQLiteDatabase db = downloadDbHelper.getReadableDatabase(); Cursor c = db.query( DownloadContract.DownloadEntry.TABLE_NAME, null, null, null, null, null, null ); while (c.moveToNext()) { Log.d("dl", "添加"); Download download = new Download(); download.settId(c.getInt(c.getColumnIndexOrThrow(DownloadContract.DownloadEntry.COLUMN_NAME_TID))); download.setJindu(c.getInt(c.getColumnIndexOrThrow(DownloadContract.DownloadEntry.COLUMN_NAME_JINDU))); download.setYixiazai(c.getInt(c.getColumnIndexOrThrow(DownloadContract.DownloadEntry.COLUMN_NAME_YIXIAZAI))); download.setPath(c.getString(c.getColumnIndexOrThrow(DownloadContract.DownloadEntry.COLUMN_NAME_PATH))); dataList.add(download); } return dataList; } }

Download实体类

public class Download { private int tId; private int jindu; private int yixiazai; private String path; public int gettId() { return tId; } public void settId(int tId) { this.tId = tId; } public int getJindu() { return jindu; } public void setJindu(int jindu) { this.jindu = jindu; } public int getYixiazai() { return yixiazai; } public void setYixiazai(int yixiazai) { this.yixiazai = yixiazai; } public String getPath() { return path; } public void setPath(String path) { this.path = path; } @Override public String toString() { return "Download{" "tId=" tId ", jindu=" jindu ", yixiazai=" yixiazai ", path= " path \ } ; } }

Service

DownloadSerivce类

public class DownloadSerivce extends Service { private int jindu; private File dlFile, file; private DownloadTask downloadTask; private long alreadySize; private Timer timer; private DAOHelper daoHelper; private final IBinder mBinder = new DLBinder(); Handler handler = new Handler() { @Override public void handleMessage(Message msg) { super.handleMessage(msg); switch (msg.what) { case 1000: NotificationCompat.Builder builder = new NotificationCompat.Builder(getapplicationContext()); builder.setSmallIcon(R.mipmap.ic_launcher); builder.setContentTitle("自定义点击事件"); RemoteViews remoteViews = new RemoteViews(getPackageName(), R.layout.remoteview); remoteViews.setProgressBar(R.id.progressBar, 100, jindu, false); remoteViews.setTextViewText(R.id.textView, jindu "%"); builder.setContent(remoteViews); NotificationManager notificationManager = (NotificationManager) getSystemService(TIFICATION_SERVICE); startForeground(1, builder.build()); break; } } }; public class DLBinder extends Binder { public DownloadSerivce getService() { return DownloadSerivce.this; } } @Override public void onCreate() { daoHelper = new DAOHelper(this); file = getTemporaryStorageDir(getApplicationContext(), "apk"); Log.d("dl", "path = " file.getAbsolutePath()); super.onCreate(); } @Override public int onStartCommand(Intent intent, int flags, int startId) { NotificationCompat.Builder builder = new NotificationCompat.Builder(getApplicationContext()); builder.setSmallIcon(R.mipmap.ic_launcher); builder.setContentTitle("自定义点击事件"); RemoteViews remoteViews = new RemoteViews(getPackageName(), R.layout.remoteview); remoteViews.setProgressBar(R.id.progressBar, 100, jindu, false); remoteViews.setTextViewText(R.id.textView, jindu "%"); builder.setContent(remoteViews); NotificationManager notificationManager = (NotificationManager) getSystemService(TIFICATION_SERVICE); startForeground(1, builder.build()); return super.onStartCommand(intent, flags, startId); } @Nullable @Override public IBinder onBind(Intent intent) { return mBinder; } @Override public void onDestroy() { super.onDestroy(); } // 开始** public void startDL(int tID) { if (downloadTask == null) { downloadTask = new DownloadSerivce.DownloadTask(); downloadTask.execute("http://msoftdl.360.cn/mobilesafe/shouji360/360safe/6002520/360MobileSafe.apk"); if (timer != null) { timer.cancel(); } timer = new Timer(); timer.schedule(new TimerTask() { public void run() { Message msg = new Message(); msg.what = 1000; handler.sendMessage(msg); } }, 0, 1000); } } // 暂停** public void pauseDL(int tID) { if (downloadTask != null) { downloadTask.cancel(true); downloadTask = null; } if (timer != null) { timer.cancel(); } Download download = new Download(); download.settId(1); download.setJindu(jindu); download.setYixiazai((int) alreadySize); download.setPath(file.getAbsolutePath() "/360.apk"); int i = daoHelper.update(download); Log.d("dl", "updateline = " i); List<Download> list = new ArrayList<Download>(); list = daoHelper.selectAll(); Log.d("dl", "list = " list.toString()); } public File getTemporaryStorageDir(Context context, String albumName) { // 获取临时文件夹 dlFile = new File(context.getExternalFilesDir( Environment.DIRECTORY_DOWNLOADS), albumName); if (dlFile.mkdirs() || dlFile.isDirectory()) { Log.d("dl", "文件夹已存在"); } else { Log.d("dl", "文件夹创建失败"); } return dlFile; } // 获取**进度 public int getJindu(int tID) { Log.d("dl", "jindu = " jindu); return jindu; } public class DownloadTask extends AsyncTask<String, Integer, String> { @Override protected void onPreExecute() { super.onPreExecute(); } @Override protected String doInBackground(String... strings) { try { //创建URL对象 URL url = new URL(strings[0]); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET"); //已经**的字节数 alreadySize = 0; //将文件写到指定目录中 File file = new File(dlFile.getAbsolutePath(), "123.apk"); if (file.exists()) { //如果文件存在,就获取当前文件的大小 alreadySize = file.length(); } conn.addRequestProperty("range", "bytes=" alreadySize "-"); conn.connect(); // 获得返回结果 int code = conn.getResponseCode(); // 响应成功返回206 if (code == 206) { // 获取未**的文件的大小 long unfinishedSize = conn.getContentLength(); // 文件的大小 long size = alreadySize unfinishedSize; Log.d("dl", "size = " size); // 获取输入流 InputStream in = conn.getInputStream(); // 获取输出对象,在原文件后追加 OutputStream out = new BufferedOutputStream(new FileOutputStream(file, true)); // 开始** byte[] buff = new byte[2048]; int len; StringBuilder sb = new StringBuilder(); while ((len = in.read(buff)) != -1) { out.write(buff, 0, len); // 累加已**的大小 alreadySize = len; // 更新进度 publishProgress((int) (alreadySize * 1.0 / size * 100)); } out.close(); } else { Toast.makeText(DownloadSerivce.this, "**失败", Toast.LENGTH_SHORT).show(); } conn.disconnect(); } catch (Exception e) { e.printStackTrace(); } return null; } @Override protected void onProgressUpdate(Integer... values) { super.onProgressUpdate(values); jindu = (values[0]); } } }

以上是准备工作。 下面是具体的使用代码: 布局文件

remoteview.xml

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="50dp" android:gravity="center_vertical" android:orientation="horizontal"> <ProgressBar android:id="@ id/progressBar" style="?android:attr/progressBarStyleHorizontal" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.9" /> <TextView android:id="@ id/textView" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.1" /> </LinearLayout>

activity_main.xml

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@ id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="com.jqk.backgrounddownload.MainActivity"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_vertical" android:orientation="horizontal"> <ProgressBar android:id="@ id/progressBar1" style="?android:attr/progressBarStyleHorizontal" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.7" android:max="100" /> <TextView android:id="@ id/jindu" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.1" /> <Button android:id="@ id/start" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.1" android:text="开始" /> <Button android:id="@ id/pause" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.1" android:text="暂停" /> </LinearLayout> </LinearLayout>

Activity

MainActivity.java

public class MainActivity extends AppCompatActivity { private Button start, pause; private ProgressBar progressBar; private File dlFile, file; private TextView tvJindu; private List<Download> all; private DAOHelper daoHelper; private DownloadSerivce mService; private boolean mBound = false; // 定时任务,更新**进度 private Timer timer; private ServiceConnection mConnection = new ServiceConnection() { @Override public void onServiceConnected(ComponentName className, IBinder service) { DownloadSerivce.DLBinder binder = (DownloadSerivce.DLBinder) service; mService = binder.getService(); mBound = true; } @Override public void onServiceDisconnected(ComponentName arg0) { mBound = false; } }; private Handler handler = new Handler() { @Override public void handleMessage(Message msg) { super.handleMessage(msg); switch (msg.what) { case 1000: int jindu = mService.getJindu(1); setData(jindu); break; } } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); start = (Button) findViewById(R.id.start); pause = (Button) findViewById(R.id.pause); progressBar = (ProgressBar) findViewById(R.id.progressBar1); tvJindu = (TextView) findViewById(R.id.jindu); file = getTemporaryStorageDir(getApplicationContext(), "apk"); Log.d("dl", "path = " file.getAbsolutePath()); daoHelper = new DAOHelper(this); if (!daoHelper.select(1)) { Download download = new Download(); download.settId(1); download.setJindu(0); download.setYixiazai(0); download.setPath(file.getAbsolutePath() "/123.apk"); long i = daoHelper.add(download); if (i != -1) { Toast.makeText(this, "插入成功", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(this, "插入失败", Toast.LENGTH_SHORT).show(); } } else { Toast.makeText(this, "数据已存在", Toast.LENGTH_SHORT).show(); } initData(); // 启动服务 Intent intent = new Intent(this, DownloadSerivce.class); startService(intent); // 绑定服务 bindService(intent, mConnection, Context.BIND_AUTO_CREATE); start.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { mService.startDL(1); timer = new Timer(); timer.schedule(new TimerTask() { public void run() { Message msg = new Message(); msg.what = 1000; handler.sendMessage(msg); } }, 0, 200); } }); pause.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { mService.pauseDL(1); if (timer != null) { timer.cancel(); } } }); } public void initData() { all = new ArrayList<Download>(); all = daoHelper.selectAll(); Download download = all.get(0); tvJindu.setText(download.getJindu() "%"); progressBar.setProgress(download.getJindu()); } public void setData(int jindu) { if (jindu != 0) { tvJindu.setText(jindu "%"); progressBar.setProgress(jindu); } } public File getTemporaryStorageDir(Context context, String albumName) { dlFile = new File(context.getExternalFilesDir( Environment.DIRECTORY_DOWNLOADS), albumName); if (dlFile.mkdirs() || dlFile.isDirectory()) { Log.d("dl", "文件夹已存在"); } else { Log.d("dl", "文件夹创建失败"); } return dlFile; } @Override protected void onDestroy() { super.onDestroy(); unbindService(mConnection); Intent intent = new Intent(this, DownloadSerivce.class); stopService(intent); } }

**后别忘了添加权限,声明Service

<uses-permission android:name="android.permission.INTERNET"></uses-permission> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <service android:name=".DownloadSerivce"></service>


相关推荐:


苏州JAVA培训   苏州JAVA培训班   苏州JAVA培训机构

上一篇:太仓Java开发学习哪里有_太仓JAVA培训 下一篇:常熟Java开发培训班价格_常熟JAVA培训
苏州JAVA

免费体验课开班倒计时

11: 41: 09

稍后会有专业老师给您回电,请保持电话畅通

咨询电话:
推荐机构 全国分站 更多课程

今日已有25人申请,本月限额500

申请试听名额

已有10254人申请免费试听

01电话咨询 |

QQ:
加盟合作:0755-83654572