Android断点续传无法实例化RandomAccessFile

代码如下:package com.download.services;

import android.content.Intent;
import android.os.Environment;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message;
import android.util.Log;
import com.download.entities.FileInfo;

import java.io.File;
import java.io.RandomAccessFile;
import java.net.HttpURLConnection;
import java.net.URL;

/**

  • Created by Administrator on 2017/10/27.
    */
    public class DownloadService extends android.app.Service {

    public static final String DOWNLOAD_PATH =
    Environment.getDownloadCacheDirectory().getAbsolutePath() +
    "/downloads/";
    public static final String ACTION_START = "ACTION_START";
    public static final String ACTION_STOP = "ACTION_STOP";
    public static final int MSG_INIT = 0;

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
    if (ACTION_START.equals(intent.getAction())) {
    FileInfo fileInfo = (FileInfo) intent.getSerializableExtra("fileInfo");
    Log.i("test", "Start:" + fileInfo);
    //启动初始化线程
    new InitThread(fileInfo).start();
    } else if (ACTION_STOP.equals(intent.getAction())) {
    FileInfo fileInfo = (FileInfo) intent.getSerializableExtra("fileInfo");
    Log.i("test", "Stop:" + fileInfo.toString());
    }
    return super.onStartCommand(intent, flags, startId);
    }

    @Override
    public IBinder onBind(Intent intent) {
    return null;
    }

    Handler mHandler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
    switch (msg.what) {
    case MSG_INIT:
    FileInfo fileInfo = (FileInfo) msg.obj;
    Log.i("test", "Init:" + fileInfo);
    break;
    }
    super.handleMessage(msg);
    }
    };

    /**

    • 初始化子线程
      */
      class InitThread extends Thread {
      private FileInfo mFileInfo = null;

      public InitThread(FileInfo mFileInfo) {
      this.mFileInfo = mFileInfo;
      }

      public void run() {
      HttpURLConnection con = null;

      try {
          //连接网络文件
          URL url = new URL(mFileInfo.getUrl());
          con = (HttpURLConnection) url.openConnection();
          con.setConnectTimeout(3000);
          con.setRequestMethod("GET");
          int length = -1;
          if (con.getResponseCode() == HttpURLConnection.HTTP_OK) {
              //获得文件长度
              length = con.getContentLength();
          }
          if (length <= 0) {
              return;
          }
          File dir = new File(DOWNLOAD_PATH);
          //文件路径是否存在
          if (!dir.exists()) {
              //创建路径
              dir.mkdir();
          }
      
          //在本地创建文件
          File file = new File(dir, mFileInfo.getFileName());
          file.createNewFile();
          RandomAccessFile raf = new RandomAccessFile(file, "r");
          //设置文件长度
          raf.setLength(length);
          mFileInfo.setLength(length);
          mHandler.obtainMessage(MSG_INIT, mFileInfo).sendToTarget();
          try {
              con.disconnect();
      

      // raf.close();
      } catch (Exception e) {
      e.printStackTrace();
      }
      } catch (Exception e) {
      e.printStackTrace();
      }
      }
      }
      }
      我是初学Android,会不会是Android虚拟机不支持外置内存卡的问题?而且使用raf.close时会报raf为初始化

1个回答

已解决
getDownloadCacheDirectory():下载缓存内容目录。
getExternalStorageDirectory():主要的外部存储目录。一些不支持外部存储的手机此方法获得的是内置存储的目录

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
用okhttp实现断点续传,网络请求进OnFailure,急急急,大神们
ProgressDownloader类 ``` public class ProgressDownloader { public static final String TAG = "TestProgressDownloader"; private ProgressResponseBody.ProgressListener progressListener; private String url; private OkHttpClient client; private File destination; private Call call; public ProgressDownloader(String url, File destination, ProgressResponseBody.ProgressListener progressListener) { this.url = url; this.destination = destination; this.progressListener = progressListener; //在下载、暂停后的继续下载中可复用同一个client对象 client = getProgressClient(); } //每次下载需要新建新的Call对象 private Call newCall(long startPoints) { Request request = new Request.Builder() .get() .url(url) .header("RANGE", "bytes=" + startPoints + "-")//断点续传要用到的,指示下载的区间 .build(); return client.newCall(request); } public OkHttpClient getProgressClient() { // 拦截器,用上ProgressResponseBody Interceptor interceptor = new Interceptor() { @Override public Response intercept(Chain chain) throws IOException { Response originalResponse = chain.proceed(chain.request()); return originalResponse.newBuilder() .body(new ProgressResponseBody(originalResponse.body(), progressListener)) .build(); } }; return new OkHttpClient.Builder() .addNetworkInterceptor(interceptor) .build(); } //startsPoint指定开始下载的点 public void download(final long startsPoint) { call = newCall(startsPoint); call.enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { Log.e("=======================","fail"); } @Override public void onResponse(Call call, Response response) throws IOException { Log.e("=======================","pass"); } }); } public void pause() { if(call!=null){ call.cancel(); } } private void save(Response response, long startsPoint) { ResponseBody body = response.body(); InputStream in = body.byteStream(); FileChannel channelOut = null; // 随机访问文件,可以指定断点续传的起始位置 RandomAccessFile randomAccessFile = null; try { randomAccessFile = new RandomAccessFile(destination, "rwd"); //Chanel NIO中的用法,由于RandomAccessFile没有使用缓存策略,直接使用会使得下载速度变慢,亲测缓存下载3.3秒的文件,用普通的RandomAccessFile需要20多秒。 channelOut = randomAccessFile.getChannel(); // 内存映射,直接使用RandomAccessFile,是用其seek方法指定下载的起始位置,使用缓存下载,在这里指定下载位置。 MappedByteBuffer mappedBuffer = channelOut.map(FileChannel.MapMode.READ_WRITE, startsPoint, body.contentLength()); byte[] buffer = new byte[1024]; int len; while ((len = in.read(buffer)) != -1) { mappedBuffer.put(buffer, 0, len); } } catch (IOException e) { e.printStackTrace(); }finally { try { in.close(); if (channelOut != null) { channelOut.close(); } if (randomAccessFile != null) { randomAccessFile.close(); } } catch (IOException e) { e.printStackTrace(); } } } } ``` MainActivity类 ``` /** * 1.添加依赖 * 2.生成带进度监听的ProgressResponseBody * 3.创建ProgressDownloader * 4.清单文件中添加网络权限和文件访问权限 */ public class MainActivity extends AppCompatActivity implements ProgressResponseBody.ProgressListener{ public static final String TAG = "MainActivity"; public static final String PACKAGE_URL = "http://gdown.baidu.com/data/wisegame/df65a597122796a4/weixin_821.apk"; @Bind(R.id.progressBar) ProgressBar progressBar; private long breakPoints; private ProgressDownloader downloader; private File file; private long totalBytes; private long contentLength; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ButterKnife.bind(this); } @OnClick({R.id.downloadButton, R.id.cancel_button, R.id.continue_button}) public void onClick(View view) { switch (view.getId()) { case R.id.downloadButton: // 新下载前清空断点信息 breakPoints = 0L; file = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS), "sample.apk"); downloader = new ProgressDownloader(PACKAGE_URL, file, this); downloader.download(0L); break; case R.id.cancel_button: downloader.pause(); Toast.makeText(this, "下载暂停", Toast.LENGTH_SHORT).show(); // 存储此时的totalBytes,即断点位置。 breakPoints = totalBytes; break; case R.id.continue_button: downloader.download(breakPoints); break; } } @Override public void onPreExecute(long contentLength) { // 文件总长只需记录一次,要注意断点续传后的contentLength只是剩余部分的长度 if (this.contentLength == 0L) { this.contentLength = contentLength; progressBar.setMax((int) (contentLength / 1024)); } } @Override public void update(long totalBytes, boolean done) { // 注意加上断点的长度 this.totalBytes = totalBytes + breakPoints; progressBar.setProgress((int) (totalBytes + breakPoints) / 1024); if (done) { // 切换到主线程 Observable .empty() .observeOn(AndroidSchedulers.mainThread()) .doOnCompleted(new Action0() { @Override public void call() { Toast.makeText(MainActivity.this, "下载完成", Toast.LENGTH_SHORT).show(); } }) .subscribe(); } } } ``` 代码链接:https://blog.csdn.net/halaoda/article/details/78502693
有关断点续传后文件夹损坏的问题
具体下载的代码: long endPos = bean.getEndLen(); long startPos = bean.getStartLen(); System.out.println(current.getId() + "-------------------当前线程ID--------当前线程临时文件" + itemFile.getClass().getName() + "-----文件的开始和结束位置----" + startPos + "---" + endPos); while (endPos > startPos && !isDownloadOver) { try { URL url = new URL(bean.getFileUrl()); HttpURLConnection conn = (HttpURLConnection) url .openConnection(); conn.setConnectTimeout(10000); conn.setReadTimeout(10000); InputStream is = new BufferedInputStream(conn .getInputStream()); byte[] buff = new byte[BUFF_LENGTH]; int length = -1; while((length = is.read(buff)) > 0 && startPos < endPos && !isDownloadOver) { startPos += itemFile.write(buff, 0, length); // 写入文件下载量 writePoint(bean, startPos + ""); } is.close(); conn.disconnect(); System.out.println("分线程号:"+current.getId()+"下载完成"); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } //写文件的类 public class FileAccess implements Serializable { private RandomAccessFile oSavedFile; @SuppressWarnings("unused") private long nPos; public FileAccess() throws IOException { this(""); } public FileAccess(String sName) throws IOException { this.oSavedFile = new RandomAccessFile(sName, "rw"); this.nPos = oSavedFile.length(); this.oSavedFile.seek(nPos); } /** * 分写内容 * @param b * @param nStart * @param nLen * @return */ public int write(byte[] b, int nStart, int nLen) { int n = -1; try { this.oSavedFile.write(b,nStart,nLen); n = nLen; } catch(IOException e) { e.printStackTrace(); } return n; } public long getSize() throws IOException{ return oSavedFile.length(); } public void close() throws IOException{ oSavedFile.close(); oSavedFile = null; } } 问题:如果不断,直接一次性下载文件就可以打开,但是如果断点后,在连的化,文件就无法打开了
RandomAccessFile 读取一行 为什么每一行都会少2个字节,
RandomAccessFile 读取一行 为什么每一行都会少2个字节,每一行读取出来的字节要少于原文件,怎么解决呀!还有怎么解决断点续读的问题呀
RandomAccessFile流是否可以读写对象
我知道RandomAccessFile可以读写文件我想问的是RandomAccessFile流是否可以读写对象
java RandomAccessFile问题,求解答
raf = new RandomAccessFile(file, "rw"); //利用读写模式实例化随机文件 raf.seek(file.length()); //文件指针跳至文件尾,准备追加数据 byte b[] = new byte[16]; //声明数组,表示地名 StringBuffer sb = new StringBuffer(16); //实例化字符缓冲对象,长度为16B sb.replace(0, 16," "); //填充16个空格确保地名长度相同 sb.replace(0,nation.length()*2, nation);//把地名信息放在字符缓冲对象sb中 b = sb.toString().getBytes(); raf.write(b); raf.close(); 写入文件的内容不对啊,求大神解答
jsp 用 RandomAccessFile上传文件
File a=new File("D:/ceshi/2/2.txt"); FileOutputStream a1=new FileOutputStream(a); InputStream b1=request.getInputStream(); byte v[]=new byte[20000]; int n; while((n=b1.read(v))!=-1) a1.write(v, 0, n); a1.close(); b1.close(); String filename="t.txt"; byte cc[]=filename.getBytes("ISO-8859-1"); filename=new String(cc); File c1=new File("D:/ceshi/2/"+filename); RandomAccessFile randomwrite=new RandomAccessFile(c1,"rw"); RandomAccessFile randomread=new RandomAccessFile(a,"r"); int second=1; String secondLine=null; while(second<=2) { secondLine=randomread.readLine(); second++; } randomread.seek(0); long four=0; int four1=1; while((n=randomread.readByte())!=-1&&(four1<=4)) { if(n=='\n') { four=randomread.getFilePointer(); four1++; } } randomread.seek(randomread.length()); long end=randomread.getFilePointer(); int j=1; while( (end>=0) && (j<6)) { end--; randomread.seek(end); n=randomread.readByte(); if(n=='\n') { end=randomread.getFilePointer(); j++; } randomread.seek(four); while(four<end-1) { n=randomread.readByte(); randomwrite.write(n); four=randomread.getFilePointer(); } randomread.close(); randomwrite.close(); } 每次传完 文件后面都有一行多余的代码
请教:关于RandomAccessFile阻塞ScheduledExecutorService的问题
大家好, 我想实现 读一个正在动态增长的日志 的功能,下面第一段代码本够用了,可惜 那个日志还会不定时自动 归档(滚动,也就是 *.log 变 *.log1 ,*.log1变 *.log2 ,类推) 已经打开的 RandomAccessFile 仍然盯着最早关联的文件,无法识别关联到新生成的 *.log, 所以我修改了这段代码,就是下面第二段代码 新的问题是: 程序已运行到 randomFile.close(); 处就卡住 ,不能进行了 想知道原因,我对多线程了解不多,请大家指点。谢谢了 final RandomAccessFile randomFile = new RandomAccessFile(logFile, "rw"); ScheduledExecutorService exec = Executors.newScheduledThreadPool(1); exec.scheduleWithFixedDelay(new Runnable() { public void run() { try { RandomAccessFile randomFile = new RandomAccessFile(logFile, "rw"); randomFile.seek(lastTimeFileSize); String tmp = ""; while ((tmp = randomFile.readLine()) != null) { //do something } } catch (IOException e) { throw new RuntimeException(e); } ScheduledExecutorService exec = Executors.newScheduledThreadPool(1); exec.scheduleWithFixedDelay(new Runnable() { public void run() { try { RandomAccessFile randomFile = new RandomAccessFile(logFile, "rw"); randomFile.seek(lastTimeFileSize); String tmp = ""; while ((tmp = randomFile.readLine()) != null) { //do something } //程序会停止到这个位置,无法进行下去,没有报任何异常或错误 //如果把 close() 给删除掉,程序就可以正常往下运行了 randomFile.close(); } catch (IOException e) { throw new RuntimeException(e); } } }, 0, 10, TimeUnit.SECONDS);
Java RandomAccessFile的读取问题
代码如下: public static void main(String[] args) { //(十) 使用随机文件流类RandomAccessFile将一个文本文件倒置读出。 File file = new File("ma.dat"); try { RandomAccessFile raf = new RandomAccessFile(file,"r"); //??? int b=raf.read(); System.out.println(b); /*int b = raf.readByte(); System.out.println(b);*/ int c=raf.readByte(); System.out.println(c); int d=raf.readByte(); System.out.println((char)d); char ch = '建'; System.out.println(Integer.toBinaryString(ch)); //101111011111010 } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } 然后ma.dat里的内容是: 建2ield&*@` 中文乱码 如何解决? 打印到控制台的结果是: 189 -88 2 101111011111010 为什么结果是189,-88???后面的2和101111011111010我懂。就是不懂前面二个结果?求大牛解答!感激不尽!
使用RandomAccessFile写文件出现乱码
各位前辈!请教一下为什么使用RandomAccessFile写文件出现乱码? 具体代码如下: import java.io.*; public class mRandomAccess { public static void main(String[] args) throws IOException { RandomAccessFile file = new RandomAccessFile("f:\\360Downloads\\movie\\moviess\\text.txt", "rw"); file.writeBoolean(false); file.writeBoolean(true); file.writeFloat(1.23f); file.writeDouble(1.234343); file.writeLong(1234L); file.writeShort(123); file.writeUTF("好学"); file.close(); } } 其运行结果为: ?漰?罂農緮 ? { 濂藉 ? { 濂藉 ? { 榛庢磱
RandomAccessFile中read()方法的返回值
RandomAccessFile raf= new RandomAccessFile("D:/fis2.txt","rw"); raf.write(100); raf.seek(0); int a=raf.read(); System.out.println(a);//输出 100 raf.close(); 之前所了解到的知识是: read()方法返回值是所读取到byte的个数 以上的返回值如何理解?
Android 求帮忙看看这段程序错在哪 在Android虚拟机上运行停止
package com.example.change1; import java.io.BufferedReader; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStreamReader; import java.io.RandomAccessFile; import java.util.Timer; import java.util.TimerTask; import android.app.Activity; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Rect; import android.os.Bundle; import android.os.Environment; import android.util.Log; import android.view.Menu; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.View; import android.widget.Button; public class MainActivity extends Activity { /** Called when the activity is first created. */ Button btnSimpleDraw, btnTimerDraw; SurfaceView sfv; SurfaceHolder sfh; private Timer mTimer; private MyTimerTask mTimerTask; int Y_axis[],//保存Y轴上的点 centerY,//中心线 oldX,oldY,//上一个XY点 currentX;//当前绘制到的X轴上的点 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnSimpleDraw = (Button) this.findViewById(R.id.drawbotton); btnTimerDraw = (Button) this.findViewById(R.id.timerbotton); btnSimpleDraw.setOnClickListener(new ClickEvent()); btnTimerDraw.setOnClickListener(new ClickEvent()); sfv = (SurfaceView) this.findViewById(R.id.surfaceview); sfh = sfv.getHolder(); //动态绘制 mTimer = new Timer(); mTimerTask = new MyTimerTask(); String string = ""; String mString = null; //File file = new File("/mnt/sdcard/abc.txt");//读取txt中数据 try { FileInputStream fis=new FileInputStream(Environment.getExternalStorageDirectory()+"/abc.txt"); byte buffer[]=new byte[1024]; ByteArrayOutputStream baops=new ByteArrayOutputStream(); int length=0; try { while((length=fis.read(buffer))!=-1){ baops.write(buffer, 0, length); string=baops.toString(); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } catch (FileNotFoundException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } //RandomAccessFile randomAccessFile = null; // try { // // //randomAccessFile = new RandomAccessFile(file,"rw"); // } catch (FileNotFoundException e) { // // TODO 自动生成的 catch 块 // e.printStackTrace(); // } // try { // while((mString=randomAccessFile.readLine())!= null) ; // // System.out.println(mString+"只拿去了"); // string += mString; // } catch (Exception e) { // // TODO: handle exception // } String[] strings = string.split(","); int[] array = new int[strings.length]; for(int i=0;i<array.length;i++){ if(strings[i]=="" || strings[i].equals("")){ }else{ array[i] = Integer.valueOf(strings[i]); } } // 初始化y轴数据 centerY = (getWindowManager().getDefaultDisplay().getHeight() - sfv .getTop()) / 2; Y_axis = new int[getWindowManager().getDefaultDisplay().getWidth()]; for (int i = 1; i < Y_axis.length; i++) {// array中的数据复制给Y_axis Y_axis[i-1] = array[i]; } } class ClickEvent implements View.OnClickListener { //点击事件 @Override public void onClick(View v) { if (v == btnSimpleDraw) { SimpleDraw(Y_axis.length-1);//直接绘制 } else if (v == btnTimerDraw) { oldY = centerY; mTimer.schedule(mTimerTask, 0, 5);//动态绘制 } } } class MyTimerTask extends TimerTask { @Override public void run() { SimpleDraw(currentX); currentX++;//往前进 if (currentX == Y_axis.length - 1) {//如果到了终点,则清屏重来 ClearDraw(); currentX = 0; oldY = centerY; } } } /* * 绘制指定区域 */ void SimpleDraw(int length) { if (length == 0) oldX = 0; Canvas canvas = sfh.lockCanvas(new Rect(oldX, 0, oldX + length, getWindowManager().getDefaultDisplay().getHeight()));// 关键:获取画布 Log.i("Canvas:", String.valueOf(oldX) + "," + String.valueOf(oldX + length)); Paint mPaint = new Paint(); mPaint.setColor(Color.GREEN);// 画笔为绿色 mPaint.setStrokeWidth(2);// 设置画笔粗细 int y; for (int i = oldX + 1; i < length; i++) {// 绘画正弦波 y = Y_axis[i - 1]; canvas.drawLine(oldX, oldY, i, y, mPaint); oldX = i; oldY = y; } sfh.unlockCanvasAndPost(canvas);// 解锁画布,提交画好的图像 } void ClearDraw() { Canvas canvas = sfh.lockCanvas(null); canvas.drawColor(Color.BLACK);// 清除画布 sfh.unlockCanvasAndPost(canvas); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }
RandomAccessFile类的write(byte[])方法怎么用?
RandomAccessFile类的write(byte[])方法怎么用?
对于RandomAccessFile的seek函数的一些疑问?
seek就是查询的意思,可以根据文件中的字节进行查询数据(不知道这么说对不对) 下面这个函数中 ``` private void setThreadBreakpoint( File file, File tempFile, long contentLength, long[] startPos, long[] endPos) { RandomAccessFile tempFileFos = null; try { if (file.exists()) { System.out.println("file " + fileName + " has exists!"); long localFileSize = file.length(); // 下载的目标文件已存在,判断目标文件是否完整 if (localFileSize < contentLength) { System.out.println("Now download continue ... "); tempFileFos = new RandomAccessFile(tempFile, "rw"); // 遍历目标文件的所有临时文件,设置断点的位置,即每个临时文件的长度 for (int i = 0; i < threadNum; i++) { tempFileFos.seek(4 + 24 * i + 8); endPos[i] = tempFileFos.readLong(); tempFileFos.seek(4 + 24 * i + 16); startPos[i] = tempFileFos.readLong(); } } else { System.out.println("This file has download complete!"); } } else { // 如果下载的目标文件不存在,则创建新文件 file.createNewFile(); tempFile.createNewFile(); tempFileFos = new RandomAccessFile(tempFile, "rw"); tempFileFos.writeInt(threadNum); for (int i = 0; i < threadNum; i++) { // 创建子线程来负责下载数据,每段数据的起始位置为(threadLength * i) startPos[i] = threadLength * i; tempFileFos.writeLong(startPos[i]); /* * 设置子线程的终止位置,非最后一个线程即为(threadLength * (i + 1) - 1) * 最后一个线程的终止位置即为下载内容的长度 */ if (i == threadNum - 1) { endPos[i] = contentLength; } else { endPos[i] = threadLength * (i + 1) - 1; } // end position tempFileFos.writeLong(endPos[i]); // current position tempFileFos.writeLong(startPos[i]); } } } catch (IOException e1) { e1.printStackTrace(); } finally { try { tempFileFos.close(); } catch (IOException e2) { e2.printStackTrace(); } } } ``` 这个循环方法体里 ``` // 遍历目标文件的所有临时文件,设置断点的位置,即每个临时文件的长度 for (int i = 0; i < threadNum; i++) { tempFileFos.seek(4 + 24 * i + 8); endPos[i] = tempFileFos.readLong(); tempFileFos.seek(4 + 24 * i + 16); startPos[i] = tempFileFos.readLong(); } ``` 这句话 ``` tempFileFos.seek(4 + 24 * i + 8); ``` 这里面seek的参数是根据什么确定的?
JAVA RandomAccessFile方法的一些问题
学习RandomAccessFile的过程中,老师说String类型的长度固定为16, 返回方法的size()中String是16乘2,这是一个问题 还有一个我在一个空的文件里存储一个int类型的数据,实际是2字节,但是占用空间是4096字节 老师说的int类型是长度是4,对于这些有点迷糊,可能我表达也不是很清楚,打扰了...
如何使用可能是内部类,刚学java
package downutil; import java.net.URL; import java.io.RandomAccessFile; import java.net.HttpURLConnection; import java.lang.Thread; import org.omg.CORBA_2_3.portable.InputStream; public class DownUtil<DownThread> { private String path; private String targetFile; private int threadNum; private DownThread[] threads; private int fileSize; public DownUtil(String path, String targetFile, int threadNum) { this.path = path; this.threadNum = threadNum; //此处DownThread类不能用,以下如此,亦不能实例化 threads = (DownThread[]) new DownThread(threadNum); this.targetFile = targetFile; } public void download() throws Exception { URL url = new URL(path); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setConnectTimeout(5 * 1000); conn.setRequestMethod("GET"); conn.setRequestProperty("Accept", "image/gif,image/jpeg,image/pjpeg,image/pjpeg," + "application/x-shockwave-falsh,application/xaml+xml," + "application/vnd.ms-xpsdocument,application/x-ms-xbap," + "application/x-ms-application,application/vnd.ms-excel," + "application/vnd.ms-powerpoint,application/msword,*/*"); conn.setRequestProperty("Accept-Language", "zh-CN"); ; conn.setRequestProperty("Charset", "UTF-8"); conn.setRequestProperty("Connection", "Keep-Alive"); fileSize = conn.getContentLength(); conn.disconnect(); int currentPartSize = fileSize / threadNum + 1; RandomAccessFile file = new RandomAccessFile(targetFile, "rw"); file.setLength(fileSize); ; file.close(); for (int i = 0; i < threadNum; i++) { int startPos = i * currentPartSize; RandomAccessFile currentPart = new RandomAccessFile(targetFile, "rw"); currentPart.seek(startPos); ; //此处如此DownTread threads[i] = new DownThread(startPos, currentPartSize, currentPart); ((Thread) threads[i]).start(); } } public double getCompleteRate() { int sumSize = 0; for (int i = 0; i < threadNum; i++) { //此处length报错,不知啥问题 sumSize += threads[i].length; } return sumSize * 1.0 / fileSize; //此处DownThread不知啥问题 private class DownThread extends Thread { private int startPos; private int currentPartSize; private RandomAccessFile currentPart; public int length; public DownThread(int startPos, int currentPartSize, RandomAccessFile currentPart) { this.startPos = startPos; this.currentPartSize = currentPartSize; this.currentPart = currentPart; } public void run() { try { URL url = new URL(path); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setConnectTimeout(5 * 1000); conn.setRequestMethod("GET"); conn.setRequestProperty("Accept", "image/gif,image/jpeg,image/pjpeg,image/pjpeg," + "applicaton/x-shockwave-flash,application/xaml+xml," + "spplication/vnd.ms-xpsdocument,application/x-ms-xbap," + "application/x-ms-application,application/vnd.ms-excel," + "appplication/vnd.ms-powerpoint,application/mswerd,*/*"); conn.setRequestProperty("Accept-Language", "zh-CN"); conn.setRequestProperty("Charset", "UTF-8"); java.io.InputStream inStream = conn.getInputStream(); inStream.skip(this.startPos); byte[] buffer = new byte[1024]; int hasRead = 0; while (length < currentPartSize && (hasRead = inStream.read(buffer)) != -1) ; { currentPart.write(buffer, 0, hasRead); length += hasRead; currentPart.close(); inStream.close(); } } catch (Exception e) { e.printStackTrace(); } }; } } public static class MultiThreadDown { public static void main(String[] args) throws Exception { final DownUtil downUtil = new DownUtil( "http://www.crazyit.org/" + "attachments/month_1403/1403202355ff6cc9a4fbf6f14a.png", "ios.png", 4); downUtil.download(); new Thread(() -> { while (downUtil.getCompleteRate() < 1) { System.out.println("已完成:" + downUtil.getCompleteRate()); try { Thread.sleep(1000); } catch (Exception ex) { } } }).start(); } } }
安卓怎么读取TXT大文件(10M左右)
我用RandomAccessFile试过,读取5M就出错了,各位有能读取10M文本的源码吗?麻烦分享一下,谢谢
怎么在android实验中获得文件的路径?
RandomAccessFile rf = new RandomAccessFile(Environment.getExternalStorageDirectory().getPath()+"/da", "rw");//context.getFilesDir().getPath() 我用了第一个获得的路径不对。 java.io.FileNotFoundException: /storage/emulated/0/da: open failed: EACCES (Permission denied) 第二个不知道Context是什么?
Android 多线程下载APK文件,网络不稳定时,APK文件出错
使用的是RandomAccessFile, 为什么会出现这种情况?
length cannot be resolved or not a field咋解决,谢谢(网络传输)
package downutil; import java.net.URL; import java.util.RandomAccess; import java.io.RandomAccessFile; import java.io.Serializable; import java.net.HttpURLConnection; public class DownUtil { private DownThread[] threads; private String path; private String targetFile; private int threadNum; private int fileSize; private long startPos; private int currentPartSize; private RandomAccessFile currentPart; public DownUtil(String path,String targetFile,int threadNum) { this.path=path; this.threadNum=threadNum; threads = new DownThread[threadNum]; this.targetFile=targetFile; } public void download()throws Exception{ URL url=new URL(path); HttpURLConnection conn=(HttpURLConnection)url.openConnection(); conn.setConnectTimeout(5*1000); conn.setRequestMethod("GET"); conn.setRequestProperty( "Accept", "image/gif,image/jpeg,image/pjpeg,image/pjpeg," +"application/x-shockwave-falsh,application/xaml+xml," +"application/vnd.ms-xpsdocument,application/x-ms-xbap," +"application/x-ms-application,application/vnd.ms-excel," + "application/vnd.ms-powerpoint,application/msword,*/*"); conn.setRequestProperty("Accept-Language", "zh-CN");; conn.setRequestProperty("Charset", "UTF-8"); conn.setRequestProperty("Connection","Keep-Alive"); fileSize=conn.getContentLength(); conn.disconnect(); int currentPartSize=fileSize/threadNum+1; RandomAccessFile file=new RandomAccessFile(targetFile,"rw"); file.setLength(fileSize);; file.close(); for(int i=0;i<threadNum;i++) { int startPos=i*currentPartSize; RandomAccessFile currentPart=new RandomAccessFile(targetFile,"rw"); currentPart.seek(startPos);; threads[i]= new DownThread(startPos, currentPartSize,currentPart); threads[i].start(); } } public double getCompleteRate() { int sumSize=0; for(int i=0;i<threadNum;i++){ // 此处显示length cannot be resolved or not a field? sumSize+=threads[i].length; } return sumSize*1.0/fileSize; } public class DownThread extends Thread{ private int startPos; private int currentPartSize; private RandomAccessFile currentPart; private int[] threadNum; public DownThread(int startPos, int currentPartSize,RandomAccessFile currentPart) { this.startPos=startPos; this.currentPartSize=currentPartSize; this.currentPart= currentPart; } } public void run() { try { URL url=new URL(path); HttpURLConnection conn=(HttpURLConnection)url.openConnection(); conn.setConnectTimeout(5*1000); conn.setRequestMethod("GET"); conn.setRequestProperty("Accept", "image/gif,image/jpeg,image/pjpeg,image/pjpeg," +"applicaton/x-shockwave-flash,application/xaml+xml," +"spplication/vnd.ms-xpsdocument,application/x-ms-xbap," +"application/x-ms-application,application/vnd.ms-excel," +"appplication/vnd.ms-powerpoint,application/mswerd,*/*"); conn.setRequestProperty("Accept-Language", "zh-CN"); conn.setRequestProperty("Charset", "UTF-8"); java.io.InputStream inStream=conn.getInputStream(); inStream.skip(this.startPos); byte[] buffer=new byte[1024]; int hasRead=0; int length; while(length<currentPartSize&&(hasRead=inStream.read(buffer))!=-1); { currentPart.write(buffer,0,hasRead); length+=hasRead; currentPart.close(); inStream.close(); } } catch(Exception e) { e.printStackTrace(); } } public class MultiThreadDown{ public static void main(String[] args)throws Exception{ final DownUtil downUtil=new DownUtil("http://127.0.0.1/"+ "/ProgramData/网页/摄影/0001.jpg", "ios.jpg",4); downUtil.download(); new Thread(()->{ while( downUtil.getCompleteRate()<1){ System.out.println("已完成:"+downUtil.getCompleteRate()); try { Thread.sleep(1000);} catch(Exception ex) {} } }).start(); } }
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
使用 Docker 部署 Spring Boot 项目
Docker 技术发展为微服务落地提供了更加便利的环境,使用 Docker 部署 Spring Boot 其实非常简单,这篇文章我们就来简单学习下。首先构建一个简单的 S...
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
redis分布式锁,面试官请随便问,我都会
文章有点长并且绕,先来个图片缓冲下! 前言 现在的业务场景越来越复杂,使用的架构也就越来越复杂,分布式、高并发已经是业务要求的常态。像腾讯系的不少服务,还有CDN优化、异地多备份等处理。 说到分布式,就必然涉及到分布式锁的概念,如何保证不同机器不同线程的分布式锁同步呢? 实现要点 互斥性,同一时刻,智能有一个客户端持有锁。 防止死锁发生,如果持有锁的客户端崩溃没有主动释放锁,也要保证锁可以正常释...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
Android 9.0 init 启动流程
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:一、启动流程概述一、 启动流程概述Android启动流程跟Linux启动类似,大致分为如下五个阶段。1.开机上电,加载固化的ROM。2.加载BootLoader,拉起Android OS。3.加载Uboot,初始外设,引导Kernel启动等。...
相关热词 c# 引用mysql c#动态加载非托管dll c# 两个表数据同步 c# 返回浮点json c# imap 链接状态 c# 漂亮字 c# 上取整 除法 c#substring c#中延时关闭 c#线段拖拉
立即提问