RandomAccessFile流是否可以读写对象

我知道RandomAccessFile可以读写文件我想问的是RandomAccessFile流是否可以读写对象

1个回答

首先,RandomAccessFile就是操作文件的类,没听过RandomAccessFile流啊。
其次,对象只能序列化写入文件中,然后再反序列化读入内存,其实本质上就是字节数据的,能将对象序列化的是java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
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(); } 每次传完 文件后面都有一行多余的代码
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(); 写入文件的内容不对啊,求大神解答
请教:关于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的个数 以上的返回值如何理解?
RandomAccessFile类的write(byte[])方法怎么用?
RandomAccessFile类的write(byte[])方法怎么用?
JAVA RandomAccessFile方法的一些问题
学习RandomAccessFile的过程中,老师说String类型的长度固定为16, 返回方法的size()中String是16乘2,这是一个问题 还有一个我在一个空的文件里存储一个int类型的数据,实际是2字节,但是占用空间是4096字节 老师说的int类型是长度是4,对于这些有点迷糊,可能我表达也不是很清楚,打扰了...
对于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的参数是根据什么确定的?
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为初始化
关于文件追加读写的问题
业务场景如下: 有一个文件A,A文件容量达到100G以上。 我需要将一段字符串写入到文件A,写入位置从第一行第一个开始。 FileWriter类中支持write(String File,boolean true)这种追加方式,但是需要将100G以上文件读完整在追加,而且不能指定光标偏移量。 RandomAccessFile 支持光标偏移,但是写入时候会覆盖后面内容。 求大神指教
RandomAccessFile 读取一行 为什么每一行都会少2个字节,
RandomAccessFile 读取一行 为什么每一行都会少2个字节,每一行读取出来的字节要少于原文件,怎么解决呀!还有怎么解决断点续读的问题呀
jsp 用 RandomAccessFile上传文件 不知道哪儿有问题
package tom.jiafei; import java.io.*; import tom.jiafei.xinxi; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.sql.*; public class Safe extends HttpServlet { /** * Constructor of the object. */ public Safe() { super(); } /** * Destruction of the servlet. <br> */ public void destroy() { super.destroy(); // Just puts "destroy" string in log // Put your code here } /** * The doGet method of the servlet. <br> * * This method is called when a form has its tag value method equals to get. * * @param request the request send by the client to the server * @param response the response send by the server to the client * @throws ServletException if an error occurred * @throws IOException if an error occurred */ public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); PrintWriter out = response.getWriter(); out .println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">"); out.println("<HTML>"); out.println(" <HEAD><TITLE>A Servlet</TITLE></HEAD>"); out.println(" <BODY>"); out.print(" This is "); out.print(this.getClass()); out.println(", using the GET method"); out.println(" </BODY>"); out.println("</HTML>"); out.flush(); out.close(); } /** * The doPost method of the servlet. <br> * * This method is called when a form has its tag value method equals to post. * * @param request the request send by the client to the server * @param response the response send by the server to the client * @throws ServletException if an error occurred * @throws IOException if an error occurred */ public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 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(); } /* try { Class.forName("com.mysql.jdbc.Driver"); } catch (Exception e) { // TODO: handle exception } Connection con; Statement sql = null; ResultSet rs = null; String uri="jdbc:mysql://localhost:3306/qwer?user=root&password=root&characterEncoding=gb2312"; try { con=DriverManager.getConnection(uri); sql=con.createStatement(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } xinxi xinxi=new xinxi(); HttpSession session=request.getSession(); session.setAttribute("xinxi",xinxi); String yonghuming=request.getParameter("yonghuming"); String mima=request.getParameter("mima"); String cha=""; int l=1; String l1=request.getParameter("jieshou"); l=Integer.parseInt(l1); String name=""; switch(l) { case 10: { name="xuesheng"; cha="insert into xuesheng values(3,'xc','xv')"; try { sql.executeUpdate(cha); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } case 11: { name="xuesheng"; cha="update xuesheng set 姓名='123',学号='qwe'"; try { sql.executeUpdate(cha); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } case 2: { } case 3: { } } xinxi.setYonghuming(yonghuming); xinxi.setMima(mima); String ty="select * from jiaoshi"; try { rs= sql.executeQuery(ty); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } RequestDispatcher dispatcher=request.getRequestDispatcher("ceshi.jsp"); dispatcher.forward(request, response); PrintWriter out=response.getWriter();*/ /*try { rs.next(); for(int i = 0;i<=rs.getRow();i++) out.println(rs.getString(i+1)); sql.executeUpdate(cha); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }*/ } /** * Initialization of the servlet. <br> * * @throws ServletException if an error occurs */ public void init() throws ServletException { // Put your code here } }
用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
【求助】代码问题,关于RandomAccessFile类的定长写入读取
正在做一个交作业用的本地小型数据库,在删除属性的部分,听老师的建议把原来的内容用新内容覆盖。但在关于定长写入读取的部分有了错误。代码如下 写入部分: ``` for (int i = 0; i < num; i++) {//写入定长属性名 randoms.writeBytes(RandomAccessFiles.format(attris[i], 20, attris[i].length())); } randoms.write("\r\n".getBytes()); for (int i = 0; i < num; i++) {//写入定长类型 randoms.writeBytes(RandomAccessFiles.format(types[i], 10, types[i].length())); } randoms.write("\r\n".getBytes()); for (int i = 0; i < num; i++) {//写入长度 randoms.writeInt(length[i]); } randoms.write("\r\n".getBytes()); for (int i = 0; i < num; i++) {//写入是否主键 randoms.writeBoolean(key[i]); } randoms.write("\r\n".getBytes()); for (int i = 0; i < num; i++) {//写入是否允许空值 randoms.writeBoolean(isnull[i]); } randoms.write("\r\n".getBytes()); randoms.close(); ``` 这是读取和替换的部分,指针位置是没问题的。value里保存删除后的新内容,最后一并写入 ``` int x = 0; byte[] b = new byte[20]; for (int i = 0; i < num; i++) { random.read(b, 0, 20); if (new String(b).trim().equals(attri)) { //查找属性名 x = i; }else { value.append(new String(b)); } } random.readLine();//将换行符读掉 value.append("\r\n"); s = random.readLine();//类型组 System.out.println(s.length()); System.out.println(s); s = s.substring(0 ,x*10) + s.substring((x + 1)*10, s.length()); //数据类型 //System.out.println(s); value.append(s + "\r\n"); s = random.readLine(); System.out.println(s.length()); s = s.substring(0 ,x*4) + s.substring((x + 1)*4, s.length()); //数据长度 //System.out.println(s); value.append(s + "\r\n"); s = random.readLine(); System.out.println(s.length()); s = s.substring(0, x) + s.substring(x + 1, s.length()); //是否key //System.out.println(s); value.append(s + "\r\n"); s = random.readLine(); System.out.println(s.length()); s = s.substring(0, x) + s.substring(x + 1, s.length()); //是否null //System.out.println(s); value.append(s + "\r\n"); ``` 因为属性组、长度组、标志组都是定长的,删除的时候也只要定长搜索到要删除的属性是第几个,然后用substring方法就可以越过被删除的数据。但是后续测试中发现,substring方法偶尔会出现越界、偶尔不会,但删除了非对应属性的类型。尤其在读取长度那里,用readline方法读取后输出长度,(测试时输入了4个属性,writeInt应该写入四个4字节长度),竟然是9?顿时迷茫了,有大神帮帮忙,检查一下代码吗?
安卓怎么读取TXT大文件(10M左右)
我用RandomAccessFile试过,读取5M就出错了,各位有能读取10M文本的源码吗?麻烦分享一下,谢谢
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(); } }
FtpClient 中completePendingCommand 方法卡住
自己的代码如下: RandomAccessFile raf = new RandomAccessFile(localFile, "r"); OutputStream out; //读写操作 .................. out.flush(); raf.close(); out.close(); Log.i(TAG, "befor setDefaultTimeout"); CLogger.i(TAG, "befor setDefaultTimeout"); ftpClient.setDefaultTimeout(1000 * 10); Log.i(TAG, "befor completePendingCommand"); boolean result = ftpClient.completePendingCommand(); Log.i(TAG, "after completePendingCommand"); 从log中看出: befor completePendingCommand 已打印 after completePendingCommand 未打印 可以判断是completePendingCommand方法一直没有返回。 我看了FtpClient 的源码,发现completePendingCommand做的事比较简单: public boolean completePendingCommand() throws IOException { return FTPReply.isPositiveCompletion(getReply()); } 不知道为何会阻塞。 求高人指点,多谢!!
如何使用可能是内部类,刚学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(); } } }
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python学习方法总结(内附python全套学习资料)
不要再问我python好不好学了 我之前做过半年少儿编程老师,一个小学四年级的小孩子都能在我的教学下独立完成python游戏,植物大战僵尸简单版,如果要肯花时间,接下来的网络开发也不是问题,人工智能也可以学个调包也没啥问题。。。。。所以python真的是想学就一定能学会的!!!! --------------------华丽的分割线-------------------------------- ...
兼职程序员一般可以从什么平台接私活?
这个问题我进行了系统性的总结,以下将进行言简意赅的说明和渠道提供,希望对各位小猿/小媛们有帮助~ 根据我们的经验,程序员兼职主要分为三种:兼职职位众包、项目整包和自由职业者驻场。 所谓的兼职职位众包,指的是需求方这边有自有工程师配合,只需要某个职位的工程师开发某个模块的项目。比如开发一个 app,后端接口有人开发,但是缺少 iOS 前端开发工程师,那么他们就会发布一个职位招聘前端,来配合公司一...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
JAVA 基础练习题
第一题 1.查看以下代码,并写出结果 public class Test01 { public static void main(String[] args) { int i1 = 5; boolean result = (i1++ &gt; 5) &amp;&amp; (++i1 &gt; 4); System.out.println(result); Sy...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
C++知识点 —— 整合(持续更新中)
本文记录自己在自学C++过程中不同于C的一些知识点,适合于有C语言基础的同学阅读。如果纰漏,欢迎回复指正 目录 第一部分 基础知识 一、HelloWorld与命名空间 二、引用和引用参数 2.1引用的定义 2.2 将引用用作函数参数 2.3 将引用用于类对象 2.4 引用和继承 2.5 何时使用引用参数 2.6 引用和指针的区别 三、内联函数 四、默认参数的...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
Python实例大全(基于Python3.7.4)
博客说明: 这是自己写的有关python语言的一篇综合博客。 只作为知识广度和编程技巧学习,不过于追究学习深度,点到即止、会用即可。 主要是基础语句,如三大控制语句(顺序、分支、循环),随机数的生成,数据类型的区分和使用; 也会涉及常用的算法和数据结构,以及面试题相关经验; 主体部分是针对python的数据挖掘和数据分析,主要先攻爬虫方向:正则表达式匹配,常用数据清洗办法,scrapy及其他爬虫框架,数据存储方式及其实现; 最后还会粗略涉及人工智能领域,玩转大数据与云计算、进行相关的预测和分析。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
机械转行java自学经历,零基础学java,血泪总结的干货
机械转行java自学经历,零基础学java,血泪总结的干货 据说,再恩爱的夫妻,一生中都有100次想离婚的念头和50次想掐死对方的冲动。 求职路上亦是如此,打开这篇文章,相信你也有转行的想法。和身边的朋友聊过,入职后的他们,或多或少对现在的职位都有些不满,都有过转行的冲动。 可他们只是想,而我真的这样做了。 下面就介绍下我转行的血泪史。 我为什么要转行 高中复读了一年,考了个双非院校的机械。当时...
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
【Linux系统编程】Linux信号列表
00. 目录 文章目录00. 目录01. Linux信号编号02. 信号简介03. 特殊信号04. 附录 01. Linux信号编号 在 Linux 下,每个信号的名字都以字符 SIG 开头,每个信号和一个数字编码相对应,在头文件 signum.h 中,这些信号都被定义为正整数。信号名定义路径:/usr/include/i386-linux-gnu/bits/signum.h 要想查看这些信号和...
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
借助AI力量,谷歌解开生命奥秘?
全文共4484字,预计学习时长8分钟 Paweł Czerwiński发布在 Unsplash上的原图 假如疾病不复存在会发生什么?如果我们能像大自然一样迅速获取能量又会发生什么?要是我们能够在极短时间内循环塑料、废油、或其它的一些物质呢?如果人类能够解开生命的奥秘,那么以上这些想象将在未来成为现实。人工智能企业DeepMind的数据科学分析师日前在此领域有了重大发现。以下为具体内容:...
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
相关热词 c#委托 逆变与协变 c#新建一个项目 c#获取dll文件路径 c#子窗体调用主窗体事件 c# 拷贝目录 c# 调用cef 网页填表c#源代码 c#部署端口监听项目、 c#接口中的属性使用方法 c# 昨天
立即提问