对于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的参数是根据什么确定的?

1个回答

首先更正一下,seek函数的作用是从文件起始位置开始计算,将文件指针定位到seek所指向的位置。
这个临时文件的格式应该是:
线程数(4字节)
线程1起始位置(8字节)
线程1结束位置(8字节)
线程1当前位置(8字节)

线程2起始位置(8字节)
线程2结束位置(8字节)
线程2当前位置(8字节)

.....
线程n起始位置(8字节)
线程n结束位置(8字节)
线程n当前位置(8字节)

tempFileFos.seek(4 + 24 * i + 8); 的含义是偏移到:
线程数(4字节) + 24(起始位置8字节+结束位置8字节+当前位置8字节) × 当前第i个线程 + 线程i的起始位置8字节 = 当前第i个线程结束位置数据在文件中的偏移

tempFileFos.seek(4 + 24 * i + 16); 的含义是偏移到:
线程数(4字节) + 24(起始位置8字节+结束位置8字节+当前位置8字节) × 当前第i个线程 + 16(线程i的起始位置8字节 + 线程i的终止位置8字节) = 当前第i个线程当前位置数据在文件中的偏移

u013179958
CSDNRGY 回复tang_cheng: 为什么线程不能大于256,文件大小不能大于2G,这个是如何计算出来的?
大约 3 年之前 回复
tang_cheng
tang_cheng 线程数(2字节)要用short类型,线程n起始位置(4字节)要用int类型,如果你这么改的确seek参数可以这么计算,但是有一点限制:线程数不能大于256,文件长度不能大于2G。而且这种记录文件就这么几个字节,没必要为了省几个字节而使其兼容性变差
大约 3 年之前 回复
u013179958
CSDNRGY 线程数可以是n字节吗?起始位置、结束位置、当前位置都可以是n字节吗?
大约 3 年之前 回复
u013179958
CSDNRGY 那我想修改一下临时文件的格式,改成线程数(2字节)、线程n起始位置(4字节)、线程n结束位置(4字节)、线程n当前位置(4字节),那么seek中的参数就应该是seek(2 + 12 * i + 4);喽?
大约 3 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
JAVA RandomAccessFile方法的一些问题
学习RandomAccessFile的过程中,老师说String类型的长度固定为16, 返回方法的size()中String是16乘2,这是一个问题 还有一个我在一个空的文件里存储一个int类型的数据,实际是2字节,但是占用空间是4096字节 老师说的int类型是长度是4,对于这些有点迷糊,可能我表达也不是很清楚,打扰了...
请教:关于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);
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的个数 以上的返回值如何理解?
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可以读写文件我想问的是RandomAccessFile流是否可以读写对象
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(); } 每次传完 文件后面都有一行多余的代码
用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类的write(byte[])方法怎么用?
RandomAccessFile类的write(byte[])方法怎么用?
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(); } }
【求助】代码问题,关于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?顿时迷茫了,有大神帮帮忙,检查一下代码吗?
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(); 写入文件的内容不对啊,求大神解答
如何使用可能是内部类,刚学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(); } } }
使用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(); } } 其运行结果为: ?漰?罂農緮 ? { 濂藉 ? { 濂藉 ? { 榛庢磱
Java微信开发上传下载语音怎么获取amr语音的秒数,传给APP端
微信端发语音,微信显示语音的秒数,微信接收到语音也能显示秒数,怎么获得这个秒数? 查了很多资料例子 amr获取时长的例子,运行得到的与真实的秒数不符合: 用的方法是下面的: public static int getAmrDuration(File file) throws IOException { long duration = -1; int[] packedSize = { 12, 13, 15, 17, 19, 20, 26, 31, 5, 0, 0, 0, 0, 0, 0, 0 }; RandomAccessFile randomAccessFile = null; try { randomAccessFile = new RandomAccessFile(file, "rw"); long length = file.length();// 文件的长度 int pos = 6;// 设置初始位置 int frameCount = 0;// 初始帧数 int packedPos = -1; byte[] datas = new byte[1];// 初始数据值 while (pos <= length) { randomAccessFile.seek(pos); if (randomAccessFile.read(datas, 0, 1) != 1) { duration = length > 0 ? ((length - 6) / 650) : 0; break; } packedPos = (datas[0] >> 3) & 0x0F; pos += packedSize[packedPos] + 1; frameCount++; } duration += frameCount * 20;// 帧数*20 } finally { if (randomAccessFile != null) { randomAccessFile.close(); } } return (int)((duration/1000)+1); }
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 } }
RandomAccessFile 读取一行 为什么每一行都会少2个字节,
RandomAccessFile 读取一行 为什么每一行都会少2个字节,每一行读取出来的字节要少于原文件,怎么解决呀!还有怎么解决断点续读的问题呀
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为初始化
安卓怎么读取TXT大文件(10M左右)
我用RandomAccessFile试过,读取5M就出错了,各位有能读取10M文本的源码吗?麻烦分享一下,谢谢
不会做了,执行出现异常,多线程网络下载程序书中部分url
import java.io.IOException; import java.io.RandomAccessFile; import java.net.HttpURLConnection; import java.net.URL; import org.omg.CORBA.portable.InputStream; public class DownUtil { public static void main(String[] args) throws Exception { String path="https://ibaotu.com/sucai/18055535.html?clickFrom=colorsearch&kwd=gif??"; String target="11111"; int num=3; DownUtil util=new DownUtil(path,target,num); util.download(); } 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; 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-flash,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++) { sumSize+=threads[i].Length; } return sumSize*1.0/fileSize; } 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," +"application/x-shockwave-flash,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"); InputStream instream =(InputStream)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(IOException e) { e.printStackTrace(); } } } } 编译正常,执行时出现 ``` Exception in thread "main" java.io.IOException: 试图将文件指针移到文件开头之前。 at java.io.RandomAccessFile.setLength(Native Method) at DownUtil.download(DownUtil.java:73) at DownUtil.main(DownUtil.java:18) 谢谢解决一下,刚学》 ``` ``` ```
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
JDK12 Collectors.teeing 你真的需要了解一下
前言 在 Java 12 里面有个非常好用但在官方 JEP 没有公布的功能,因为它只是 Collector 中的一个小改动,它的作用是 merge 两个 collector 的结果,这句话显得很抽象,老规矩,我们先来看个图(这真是一个不和谐的图????): 管道改造经常会用这个小东西,通常我们叫它「三通」,它的主要作用就是将 downstream1 和 downstre...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
【图解经典算法题】如何用一行代码解决约瑟夫环问题
约瑟夫环问题算是很经典的题了,估计大家都听说过,然后我就在一次笔试中遇到了,下面我就用 3 种方法来详细讲解一下这道题,最后一种方法学了之后保证让你可以让你装逼。 问题描述:编号为 1-N 的 N 个士兵围坐在一起形成一个圆圈,从编号为 1 的士兵开始依次报数(1,2,3…这样依次报),数到 m 的 士兵会被杀死出列,之后的士兵再从 1 开始报数。直到最后剩下一士兵,求这个士兵的编号。 1、方...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
GitHub标星近1万:只需5秒音源,这个网络就能实时“克隆”你的声音
作者 | Google团队 译者 | 凯隐 编辑 | Jane 出品 | AI科技大本营(ID:rgznai100) 本文中,Google 团队提出了一种文本语音合成(text to speech)神经系统,能通过少量样本学习到多个不同说话者(speaker)的语音特征,并合成他们的讲话音频。此外,对于训练时网络没有接触过的说话者,也能在不重新训练的情况下,仅通过未知...
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
【管理系统课程设计】美少女手把手教你后台管理
【文章后台管理系统】URL设计与建模分析+项目源码+运行界面 栏目管理、文章列表、用户管理、角色管理、权限管理模块(文章最后附有源码) 1. 这是一个什么系统? 1.1 学习后台管理系统的原因 随着时代的变迁,现如今各大云服务平台横空出世,市面上有许多如学生信息系统、图书阅读系统、停车场管理系统等的管理系统,而本人家里就有人在用烟草销售系统,直接在网上完成挑选、购买与提交收货点,方便又快捷。 试想,若没有烟草销售系统,本人家人想要购买烟草,还要独自前往药...
4G EPS 第四代移动通信系统
目录 文章目录目录4G 与 LTE/EPCLTE/EPC 的架构E-UTRANE-UTRAN 协议栈eNodeBEPCMMES-GWP-GWHSSLTE/EPC 协议栈概览 4G 与 LTE/EPC 4G,即第四代移动通信系统,提供了 3G 不能满足的无线网络宽带化,主要提供数据(上网)业务。而 LTE(Long Term Evolution,长期演进技术)是电信领域用于手机及数据终端的高速无线通...
相关热词 c# 二进制截断字符串 c#实现窗体设计器 c#检测是否为微信 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片
立即提问