Java局部变量全局变量递归问题

图片说明

先说明一下 代码求的是一个文件夹的大小

****写法1:用全局变量 不对 写法2 :用局部变量 对****
为什么?最好能解释的详细一点

 import java.io.File;
import java.util.Scanner;
public class Directory{
public static void main(String []args){
System.out.println("Enter a directory of file ") ;
Scanner input = new Scanner (System.in);
String directory = input.nextLine();
System.out.println(getSize(new File(directory)) + "bytes");
}
public static long getSize(File file ){
long size = 0;
if (file.isDirectory()){
File[]files = file.listFiles();
for (int i =0;files != null && i<files.length; i++)
size+=getSize(files[i]);
}
else 
size +=file.length(); 
return size;
}
}

3个回答

如果你使用成员变量,那么你就不要返回值,因为每次都将获得的文件大小累加到成员变量size上了。但很显然你使用成员变量的同时又返回了值。
比方说:
第一次查找到一个文件,大小是 100 byte,size 此时 = 100;
第二次查找到一个文件,大小是 200 byte , size 此时 = 300;
然后查找到一个文件夹,此时递归。
紧接着找的一个文件,文件的大小是 50 byte, size 此时 = 350;
这个文件夹没有文件了,退出,注意!!! 重点来了,return 一个 size
而你用size += getSize() 去接收返回值,此时的成员变量会是多少呢? 350 + 350 = 700,莫名其妙的翻了一倍有木有!!!!

这样子的话,如果你这个文件夹里的有很多层级,那就一直一倍一倍的往上翻,最后就是个天文数字。。。。

自个好好理一下,我说的如果你能够理解那就最好不过。

 首先,你定义为成员变量后,每调用一次还方法,size都累加到类的成员变量上了,相当于求多个文件夹大小的总容量。但是局部变量只是当前方法内部有效,每次重新赋值为0,所以符合计算一个文件大小的需求。

说个通俗点的
全局变量 你定义一个 long a 然后第一遍1000 第二遍操作 2000 那输出的就是1000+2000=3000

局部变量 就是你每次调用这个方法的时候 就会新定义一个 long a 第一遍 赋值了1000 那就是输出 1000

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java 局部变量与全局变量问题

![图片说明](https://img-ask.csdn.net/upload/201612/02/1480676001_341464.png) 整个代码求的是一个文件夹的大小 (文件夹里可能还有文件夹) 用的递归 问题1:原代码是书上例子 结果正确 红色标出的是我自己重写遇到的 结果是很大的负数 按我的理解 size 在方法里面是局部变量 作用整个方法 在外面是类变量 作用整个类 但是在这段代码中应该没什么不同吧,因为我只有一个方法,SIZE意思是固定的 问题2: 第14行的 files != null && 能不能省掉? 代码如下: import java.io.File; import java.util.Scanner; public class Directory{ public static void main(String []args){ System.out.println("Enter a directory of file ") ; Scanner input = new Scanner (System.in); String directory = input.nextLine(); System.out.println(getSize(new File(directory)) + "bytes"); } public static long getSize(File file ){ long size = 0; if (file.isDirectory()){ File[]files = file.listFiles(); for (int i =0;files != null && i<files.length; i++) size+=getSize(files[i]); } else size +=file.length(); return size; } }

想请教一下全局变量在递归中是怎么样的

以下是一个函数完整的代码 利用static int code[10]来保存哈夫曼编码 但是static 的东西不是只有一个吗,在向左右子树递归的时候不会冲突吗 想了解以下code这个数组在这个函数的递归中是怎么被改变的 ``` void HuffManCoding(BTreeNode *FBT, int len) { // 根据FBT指针所指向的哈夫曼树输出每个叶子的编码,len初值为0 static int code[10]; // 数组的长度要至少等于哈夫曼树的深度减1 if (FBT != NULL) { // 访问到叶子结点时输出其保存在数组code中的0和1序列编码 if (FBT->left == NULL && FBT->right == NULL) { cout << "结点权值为" << FBT->weight << "的编码:"; for (int i = 0; i < len; i++) cout << code[i] << " "; cout << endl; } // 访问到非叶子节点时分别向左、右子树递归调用,并分别把分支上 // 的0、1编码保存到数组code,向下深入一层时len+1 else { code[len] = 0; HuffManCoding(FBT->left, len + 1); code[len] = 1; HuffManCoding(FBT->right, len + 1); } } } ```

递归的时候局部变量会不会定义重了

递归的时候,由于方法没有结束,如果定义局部变量没消息,我在次递归岂不是又定义一次了吗

在递归中使用全局变量是一种好习惯

<div class="post-text" itemprop="text"> <p>I'm helping someone on his school assignment - we're trying to write recursive function (if it matters - either in PHP or JavaScript).</p> <p>I understand principles of recursion quite well, but I haven't wrote any of those from "academic" viewpoint. </p> <p>Is it good practice to use global variable to store result, something like:</p> <pre><code>var results = []; var rec = function(a) { ... if (match) results.push(someValue); } </code></pre> <p>Or should I use return for collecting all those results back together (which would be much more difficult)?</p> </div>

js 递归 传入的变量值每次在递归时被初始化了

代码如下: ``` function recursionNode(html, node) { if (node.length > 0) { var len = node.length; for(var i = 0; i < len; i++) { var cnode = node[i]; if (cnode.children != null) { recursionNode(html,cnode.children); } else { var jsonData = $.toJSON(cnode.data); var obj = $.parseJSON(jsonData); if (obj.type == 'Department') { html += "<div>"+obj.name+"</div>"; } } } } } ``` 在js中递归调用时,每次递归时html都被初始化成html = "";但在java中我一直是这么写的,html变量的值会叠加,为什么js中就不行?

java递归问题,求助 很着急

如有数组[["白色","黑色"],["64GB","128GB"],["中国移动","中国联通"]] 要拼接返回一个数组 如["白色/64GB/中国移动","黑色/64GB/中国移动","白色/128GB/中国移动","黑色/128GB/中国移动","白色/64GB/中国联通","黑色/64GB/中国联通","白色/128GB/中国联通","黑色/128GB/中国联通"] 问题是 数组[["白色","黑色"],["64GB","128GB"],["中国移动","中国联通"]] 不是固定的的 可能只有一个数组 可能有两个数组 可能有三个数组 可能有四个数组 数组里的值也不固定 ,可能只有一个,可能有5个 有大神在吗?

java循环匹配递归的问题

wuxian递归的问题 wuxian递归的问题wuxian递归的问题wuxian递归的问题 wuxian递归的问题wuxian递归的问题 wuxian递归的问题 wuxian递归的问题wuxian递归的问题 wuxian递归的问题

Java中递归快还是循环快?

Java中递归快还是循环快? 还是有什么适用情况? 例如求100万的阶乘

[JAVA]for循环换成递归有没有什么套路?反之呢?

本人是刚刚自学java过来的,偶然机会看到一个视频,说有的时候需要使用递归, 尤其是在java中的删除多级目录,于是我就开始琢磨,有没有什么套路呢, 现在有一个简单案例,就是把1+到100的等差数列求和, **首先是简单的for循环写法:** ``` for循环方式输出结果 @Test public void testAdd(){ String str="1"; System.out.println(str); int result=0; for(int i=2;i<=100;i++){ str+=("+"+i); result+=i; System.out.println(str+"="+(result+1)); } } ``` 这是改写的递归法, 每一步是输出结果 然而这简单的算法,我却琢磨了很久,感觉里面有一些东西非常接近, **递归写法**** ```递归写法 public class DemoAdd { static int result=1; public static int add(int n) { if (n < 100) { result += (++n); System.out.println(result); return add(n); } else { return 0; } } public static void main(String[] args) { add(1); } } ``` 现在问题来了,就是新手在学习递归方法的时候,有没有什么思维套路, 不可能每次需要使用的时候都要琢磨半天吧, 比如我需要先把for循环写出来吗,或者需要打什么草稿,然后怎么做,请高手指点一下,

JAVA函数递归调用问题

/** 计算5! */ public class Function { static int i=5,sum=1; public static void print(){ sum=sum*i; i--; if(i>1) {print(); System.out.println("****** "+sum); } else System.out.println("sum="+sum); } public static void main(String[] args) { // TODO Auto-generated method stub print(); } 输出结果: sum=120 ****** 120 ****** 120 ****** 120 在结果输出后为何继续多次执行 System.out.println("****** "+sum);

java ftpclient 递归下载问题

public void getGaojingData(QueryCriteria criteria) { //切换GP数据库 CustomerContextHolder.setContextType(CustomerContextHolder.SESSION_FACTORY_GP); FtpUtil ftpUtil = new FtpUtil(); //连接ftp FTPClient ftpClient = ftpUtil.connect(); try { ftpClient.setFileType(FTPClient.BINARY_FILE_TYPE); // 设置文件类型(二进制) ftpClient.enterLocalPassiveMode(); String remotePath ="/FMS_ALARMDATA/"; if(ftpUtil.changeDirectory(remotePath)){//如果切换目录成功 //获取 remotePath 目录下所有文件夹 FTPFile[] fs2 = ftpClient.listFiles(); for(int i =0;i<fs2.length;i++){ //判断是文件夹还是文件,返回完整路径路径、例如 /FMS_ALARMDATA/GZ/20161011/czxxx.csv.gz String remotePath1 ="/"+ fs2[i].getName(); ///FMS_ALARMDATA/GZ //进入下一层目录FMS_ALARMDATA/GZ ftpUtil.changeDirectory(remotePath1+"/"); FTPFile[] fsCity = ftpClient.listFiles();///FMS_ALARMDATA/GZ for (int j=0;j<fsCity.length;j++){ String remotePath2 ="/"+fsCity[j].getName()+"/"; ///FMS_ALARMDATA/GZ/20160912 ftpUtil.changeDirectory(remotePath2); FTPFile[] fsFile = ftpClient.listFiles(); for(int r=0;r<fsFile.length;r++){ //适配程序修改名称 String fileName = new StringBuffer(fsFile[r].getName()).replace(13,14,"-").toString().toLowerCase(); criteria.put("fileName",fileName); criteria.put("fileTime",fsFile[r].getTimestamp().getTime()); criteria.put("fileSize",fsFile[r].getSize()>0?fsFile[r].getSize():0.00); //查询这个文件是否已经下载 int flg = lteDatadistributionMapper.queryFtpTransmissionFile(criteria); if(flg==0){ //如果没有下载过则下载 File localFile = new File("/data1/ftp_data/"+fileName); OutputStream is = new FileOutputStream(localFile); ftpClient.retrieveFile(fsFile[r].getName(), is); is.close(); String csvName=fileName.replace(".gz",""); //下载完解压成.csv文件 excuteLiuxOrde3r("gzip -d /data1/ftp_data/"+fileName); //删除第一行表头 String[] cmds = {"/bin/sh","-c","sed -i '1d' /data1/ftp_data/" +csvName}; excuteLiuxOrde3r(cmds); //替换文件中的!为- String[] cmds1 = {"/bin/sh","-c","sed -i 's/!/-/g' /data1/ftp_data/" + csvName}; excuteLiuxOrde3r(cmds1); //替换|^% 为 | String[] cmds2 = {"/bin/sh","-c","sed -i 's/|^%/|/g' /data1/ftp_data/" + csvName}; excuteLiuxOrde3r(cmds2); //添加年,月,日 String yyyymmdd = fileName.split("_")[3]; //截取字符串: 20160116.csv String ymd = yyyymmdd.substring(0,8); //年月日:20160116 String yyyy = yyyymmdd.substring(0,4); //年:2016 String mm = yyyymmdd.substring(4,6); //月:01 String dd = yyyymmdd.substring(6,8); //日:16 //2016|01|12|20160112| String changeStr =yyyy+"|"+mm+"|"+dd+"|"+ymd+"|"; String[] cmds3 = {"/bin/sh","-c","sed -i 's/^/"+changeStr+"&/g' /data1/ftp_data/" + csvName}; excuteLiuxOrde3r(cmds3); //记录下载情况 lteDatadistributionMapper.saveFtpTransmissionLog(criteria); } } if(j==fsCity.length){ ftpUtil.changeDirectory("/"); ftpUtil.changeDirectory("/FMS_ALARMDATA/"); ftpUtil.changeDirectory("/"+remotePath2+"/"); } } if(i==fs2.length){ ftpUtil.changeDirectory("/"); ftpUtil.changeDirectory("/FMS_ALARMDATA/"); ftpUtil.changeDirectory("/"+remotePath1+"/"); } } } }catch (IOException e){ e.printStackTrace(); }finally { try{ ftpClient.disconnect(); System.out.println("ftp关闭成功"); } catch (IOException e){ System.out.println("ftp关闭失败"); e.printStackTrace(); } } //断开与远程服务器的连接 ftpUtil.disconnect(); } ``` ``` public boolean changeDirectory(String directory) { try { int start = directory.startsWith("/") ? 1 : 0; int end = directory.indexOf("/", start); while (true) { String subDirectory = directory.substring(start, end); if (!ftpClient.changeWorkingDirectory(subDirectory)) { if (ftpClient.makeDirectory(subDirectory)) { ftpClient.changeWorkingDirectory(subDirectory); } else { log.info("创建目录:"+subDirectory+"失败"); return false; } } start = end + 1; end = directory.indexOf("/", start); // 检查所有目录是否创建完毕 if (end <= start) { break; } } } catch (Exception e) { log.error(this, e); } return true; } ftp登录到根目录,让后进入/FMS...../目录,再进入到/FMS..../GZ/目录,然后进入到/FMS..../GZ/20161012/目录,需要下载20161012文件夹里面的几个文件,然后跳出20161012目录进回到GZ目录,然后进入/FMS..../GZ/20161013/.。依。以此类推 ,需要把/FMS....下面的全部目录文件都下载到本地,经过测试,下木有问题,现在要问怎么ftpclient怎么退出当前目录,,,,

怎么才能用静态局部变量当作函数参数,初学C尝试用函数递归解n! 系统提示有坏的存储类

#include<stdio.h> int fact(static int ,int,static int); void main(void) { int n; scanf_s("%d", &n); printf("%d\n",fact(1,n,1)); } int fact(static int i,int n,static int m) { m = m*i; i = i + 1; if (i != n + 1) fact(i, n, m); return m; }

java递归排序 帮忙写出代码

![图片说明](https://img-ask.csdn.net/upload/201707/28/1501250603_538137.jpg)

java递归查询算法。。。

有个级联菜单 1-- ---1-1 ------1-1-1 2--- 2---1 -------2-1-1 我要模糊查询“1”关键字 我要把带“1”的全部查出来,如果是二级菜单要把一级顺便连出来, 如果是三级要把二级和一级全部查出来,如果只是一级,只显示一级菜单, 两个查询 1,全部查出来,放map中 (父id,对象) 2,符合查询条件的查出来,放list中 我要把我想要的结果放在一个map或者list中 这个【递归】该怎么写。

java递归原理求高人解惑

int i=1; int Test(int n){ System.out.println("*****************"+(i++)); int result =0; if(n==1) return 1; result = Test(n-1)*n; System.out.println(result+" "+n); return result; } 我进行调试,比如n=8,只打印第一条语句,打了八次,当n=1时返回结果1,跳出方法,然后继续执行,此时n变为2,为何?再然后只执行第二条打印语句的内容,为何?直到n变为8。求解啊...

java里递归次数太多,为什么会出错?

萌新自己写了一个用链表找质数的代码,运行时没问题,但如果输入的数太大,就会出错,为什么会这样?求大神解答,万分感谢! 代码如下: //一个找出质数的程序 public class Zhishu{ public static Zhishu firstZhishu=new Zhishu(2); public Zhishu next=null; public int number=0; private Zhishu(int number){ this.number=number; } public static void main(String[] args){ Zhishu.find(19); Zhishu.find(17); Zhishu.find(100); Zhishu.find(1000); Zhishu.find(1069); Zhishu.find(3630); Zhishu.find(5000); } public static void find(int n){ find(n,firstZhishu); } private static void find(int n,Zhishu a){ if (n==a.number){ System.out.println(n+"是质数"); return; }else if(n<a.number){ System.out.println(n+"不是质数"); return; }else if(a.next==null){ find(a.number+1,n,a); }else{ find (n,a.next); } } private static void find(int i,int n,Zhishu a){ if (i<n){ if (test(i,firstZhishu)){ a.next=new Zhishu(i); find(i+1,n,a.next); }else{ find(i+1,n,a); } }else{ if (test(n,firstZhishu)){ a.next=new Zhishu(n); System.out.println(n+"是质数"); }else{ System.out.println(n+"不是质数"); } } } private static boolean test(int i,Zhishu a){ if (i%a.number==0){ return false; }else if(a.number*2>i){ System.out.println("找到质数"+i); return true; }else{ return (test(i,a.next)); } } } 运行结果如下:![图片说明](https://img-ask.csdn.net/upload/201711/24/1511497063_934946.png) 或 ![图片说明](https://img-ask.csdn.net/upload/201711/24/1511497165_316272.png)

Java利用递归进行遍历出这些数据?

![图片说明](https://img-ask.csdn.net/upload/201704/06/1491459658_303242.png)

Java中的递归方法,是那个对象调用的

当递归方法在其他类中的时候,需要创建该类对象才能调用这个递归方法,那么递归调用自己的时候,需不需要写,this。我发现不写也没什么问题,可是当这个方法第二次调用的时候是那个对象调用的呢 ,还是第一次那个调用递归方法的对象吗,

递归问题:递归引用传递的问题

最近在学递归有两个问题困扰了我很久, 问题:递归引用传递的问题 贴个代码说事 ``` public static List<List<Integer>> threeSum(int[] nums,int counter,List<List<Integer>> results,List<Integer> result) { //递归 } ``` 就拿这个做例子,我发现比如说数组原始内容是{-1, 0, 1, 2, -1, -4},递归做的是找出三个元素使得a+b+c=0,比如说我在里面有循环,当我从第三次次递归回调到第二次递归时,数组里的变量也会回退到第二次的情况,但是为什么List列表不会回退到第二次呢,而是不管递归了多少次他都会一直往下记录?

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐