jvm中一共创建多少对象 5C
String a=new String("A");
String b=a+new String("b");
请问一共在jvm中创建多少对象
123

8个回答

综合一下,是3个对象,2个变量。变量存在栈中,有a,b。对象存在堆中,有new String("A"),new String("b"),a+new String("b")

u010293844
XionChen 回复wohenni0931: String s = new String("xyz"); 这个创建了几个对象?
4 年多之前 回复
wohenni0931
wohenni0931 回复cx_xiii: 这个是对象的内容。
4 年多之前 回复
u010293844
XionChen “A”和“b”不算吗?
4 年多之前 回复

三个对象,a指向A对象,b指向了a+B的对象。最后还有一个b自己的对象。一共三个

而且你可以用syso(system.out.println())输出一下试试,验证一下到底是不是三个对象

java_cloub
java_cloub 哪些是堆对象哪些是栈对象
4 年多之前 回复

四个

java_cloub
java_cloub 哪4个
4 年多之前 回复

“A","b",a,b

u010293844
XionChen new String(“b”)算不算一个?
4 年多之前 回复
u010293844
XionChen new String(“b”)算不算一个?
4 年多之前 回复

我觉得有五个。。。。。。。。。。

u010293844
XionChen “A”;"b" ;new String("A")他和a是同一个对象;new String("B");b 这五个
4 年多之前 回复

创建了三个对象,b=a+new String(“B”);这句代码等价于:b=new Sting(a+new String(“B”));这句代码会创建两个对象。

1个对象,2个变量。a既是变量也是对象,b是变量不是对象,String类型的变量都是在字符串缓存池中产生的,new String(“B”)会产生一个匿名对象,付值结束就会被jvm回收,最终是1个对象,2个变量

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
请问在 JVM 堆中使用,可以有几个句柄池,句柄池中又可以有多少句柄?
请问在 JVM 堆中使用句柄引用,是为每一个对象创建一个独立句柄池,还是在说在堆中只存在一个句柄池,所有对象都在这唯一的句柄池中创建句柄?
Java 中final修饰的成员变量在创建对象时候会不会被附初值?
如上所述 Java 中final修饰的成员变量在创建对象时候会不会被附初值? 我看周志明的jvm说在创建对象时候要给所有的内存空间都要初始化为零值(不包括对象头),我就想如果是final类型的会不会被初始化微零值再进行程序员自己编写的赋值语句呢?那样的话是不是就是两次对final变量赋值了?
JAVA中不能创建抽象类的对象 ? 我觉得可以!
都说抽象类不允许创建具体对象实例,但是只是不能显式创建吧 ? 在一个类继承抽象类的时候,如果 new 一个子类对象,那么 JVM 首先就会创建一个抽象类的实例并调用其构造函数的,然后把这个抽象类对象包含在字类对象中,并通过 super关键子引用. 按 thinking in java 里所说,创建子类对象的时候,首先会递归的创建父类对象,并借助父类构造函数完成对父类对象的初始化。那么当父类为抽象类的时候,JVM 也同样会自动创建抽象父类的对象,然后把它包含在子类对象中。如此一来,我们平时所说的不能创建抽象类的对象并不准确了,只是我们不能在语法上写出 new abstractClass() 而已,但在继承体系中,JVM其实会自动创建的. abstract class Father { public void print() { System.out.println("in father"); } } public class Test extends Father { public void print() { super.print(); } 这里的 super 就是对JVM 自动创建的抽象父类对象的引用,我觉得应该就是如此了. 大家怎么认为呢 ?
JVM内存 Perm Gen永久代
我在测试测序里写了死循环,循环内sleep 1秒,在监控内存发现,永久代内存使用一直在增加,所以,想知道永久代的内存是如何分配的, Perm Gen是方法区,那么每创建一个对象,都会加载对应类的方法吗,如果不断创建同一个类的多个对象,方法会继续加载吗,方法不是共用的 吗,如果是这样,gc不会管理到这块内存,程序跑久了肯定要oom了呀。永久代占内存一直增加,是说明每次对象的方法单独占内存吗?还有一个问题,创建的新对象在堆内存中,那么堆内存中保存的只是对象的成员变量吗(成员方法保存在永久代?),对象中对别的对象的引用又是保存在哪里?对象的引用(例如People p = new People()),p本身(不是指对象)又在内存的那一块?哎呀呀,问题太多了,求大神解答!
内部类,外部类与jvm的关系
使用 Outer.Inner inner = new Outer().new Inner()创建对象时,Inner类中没有使用Outer中的属性和方法时,外部类对象是否会被jvm的垃圾回收机制回收(可达性分析中没有人连接着外部类对象,但有人连接着内部类对象)
Java第一次创建对象速度会慢于之后的创建
我在创建一个对象时发现第一次new出的对象会耗时比较长,而后面的创建则会很快速,请问大神这是为什么? 代码如下: ``` public static void main(String[] args) throws InterruptedException { for(int i =0;i<5;i++){ long now = System.currentTimeMillis(); RestTemplate httpClient = new RestTemplate(); System.out.println(System.currentTimeMillis() - now); } } ``` 输出结果如下: ``` 1084 16 7 12 5 ``` 感谢大神回答!
字面值字符串是在类加载的时候还是运行的时候在常量池里创建对象?
都说字符串无论在哪里都是非常重要的存在,所以这个问题希望的到解答,我在别的人的博客上看到了这个我觉得说的应该是对的,摘抄如下: 在Java源代码中的每一个字面值字符串,都会在编译成class文件阶段,形成标志号为8(CONSTANT_String_info)的常量表 。当JVM加载 class文件的时候,会为对应的常量池建立一个内存数据结构,并存放在方法区中。同时JVM会自动为CONSTANT_String_info常量表中 的字符串常量的字面值在堆中创建新的String对象(intern字符串对象 ,又叫拘留字符串对象)。然后把CONSTANT_String_info常量表的入口地址转变成这个堆中String对象的直接地址(常量池解析)。 但是我在写的小Demo的结果好像个这个并不符合代码如下: Demo1: String str2 = new String("abc"); String str1 = new String("abc"); String str3=str1+str2; String str4=str3.intern(); String str7="abcabc"; System.out.println(str4==str3); System.out.println(str7==str4); /** * output: * true * true */ Demo2: String str2 = new String("abc"); String str1 = new String("abc"); String str3=str1+str2; String str7="abcabc"; String str4=str3.intern(); System.out.println(str4==str3); System.out.println(str7==str4); /** * output: * false * true */ 如果字面值字符串是在类加载的时候在常量池内创建“abcabc”字符串,那么我感觉两次的答案应该一样 既然不一样,我只能这样解释通 Demo1中str3创建一个对象但是应为是字符串连接对象所以不会调用自身的intern()方法也就不会再常量池里放入“abcabc”, String str4=str3.intern();这句话吧str3的引用放入常量池, String str7="abcabc";这句话则是从常量池里拿所以是truetrue. Demo2中 String str3=str1+str2;同上, String str7="abcabc"发现常量池里面没有所以在常量池里创建“abcabc”, String str4=str3.intern();则是从常量池里得到“abcabc”所以是false true 以上两个Demo可以显示字面值字符串是在运行的时候创建的否则都应该是 false true这个答案 所以我想知道字面值字符串是在类加载的时候还是运行的时候在常量池里创建对象? 是我看到的摘抄错了还是我对于小Demo的理解错了,还是我哪里理解错了?谢谢帮忙
【求解】关于Class对象何时产生的一些疑惑?
《JAVA编程思想》中说每当编写并且编译了一个新类时,就会产生一个Class对象(被保存在一个同名的.class文件中),程序运行的时候JVM也是先检查类对应的class对象是否被加载,如果未加载,JVM会根据类名查找.class文件,并将其载入。一旦某个类的Class对象载入内存,他就被用来创建这个类的所有对象。有一些网上视频和资料说Class对象就是类编译后的字节码文件(.class文件,不知道Class cls=类名.class ;这种取得Class对象的方式后面的“类名.class”是不是类的字节码文件)。综上所述:也就是说每个类Class对象是在类编译后就产生了的,并且在加载类的时候会把Class对象加载到内存。然而我们学校课本以及图书馆查的书上说:Class对象是在加载类时由JVM或者调用类加载器中的defineClass方法自动构造的。也就是说Class对象是在类加载的时候由java虚拟机创建的。这样我就矛盾了,我有以下一些想请教高手们: (1)这个Class对象到底是编译类后就产生的(甚至就是所说的字节码文件)还是加载类时产生的? (2)class LoadedClass{//细节暂时省略} class Test{ public static void main(String[] args){ Class cls=LoadedClass.class; } } 这里面是通过“类名.class”的方式获取类Class对象的。而“类名.class”是和类编译后的字节码文件的全称是一样的,难道这就是视频中说的类的字节码文件就是一个类的Class的对象吗?如果是的话,一个字节码文件能赋值给一个引用类型的变量吗?(不过有的说“class”是一个字面常量,可以通过类调用来获取类的Class对象)。 (3)class LoadedClass{ static{ System.out.println(“类LoadedClass载入”); } public LoadedClass(){ System.out.println(“类LoadedClass实例化”); } } class Test{ public static void main(String[] args){ System.out.println(“以下是通过.class的方式取得LoadedClass类的Class对象”); Class cls=LoadedClass.class; } } 运行结果: 以下是通过.class的方式取得LoadedClass类的Class对象 通过“类名.class”方式可以取得Class的对象,由运行结果看出此时静态代码块没有执行,也就是说类并没有加载,那么我们课本上说:Class对象是在加载类时由JVM或者调用类加载器中的defineClass方法自动构造的。此时类并没有加载,按这种说法就说JVM就还没有创建Class对象,但是现在“类名.class”方式取得的Class对象是哪里来的呢。 (4)在Test类中添加:System.out.println(cls);语句,结果打印的是:class LoadedClass; 这个变量cls是引用类型变量,按理说如果是打印其他的对象,一般不是用@连接的类名和对象地址,这里怎么不是呢,是不是重写了Class类的toString()了导致的? 我说的可能有点混乱,但是现在查资料要么是说Class对象在类编译后就产生了,加载类就是要加载Class对象,也就是字节码文件(表明类加载之前就已经有了类的Class对象了,)。要么是说Class对象是在加载类时由JVM或者调用类加载器中的defineClass方法自动构造的(表明Class对象是加载类的时候产生的)。 那么:java.lang.Class类的class对象到底是在编译后生成的(存在.class文件中,或者就是.class文件),还是在JVM加载类时生成的?或者说这两个Class对象之间有什么样的关系?是同一个class对象吗?请高手们能给我解释一下,在此谢谢各位!
【java】该种情况下GC手否能够回收对象?
``` public class A{ public void test(){ for(int i=0;i<2;i++){ List b = new ArrayList(); } } } ``` 请问循环完毕后内存中有几个list对象? 前一个创建的list是否可以被gc回收 主要是想知道对于后一个创建的list,前一个算不算失去了引用
Java多线程和其创建对象的内存使用机制?
1. ``` public void addActionRecord(Object oldEntity, Object newEntity,String applicationName) { try { ActionVo actionVo = BorpUtil.getActionRecord(oldEntity, newEntity,applicationName); Executors.newFixedThreadPool(1).submit(() -> { try { addAction(actionVo); } catch (Exception var3) { System.out.println(var3.getMessage()); } }); } catch (Exception var4) { System.out.println(var4.getMessage()); } } ``` 主要问题是:是不是每次执行上面这段代码的时候都会创建一个线程?然后用这种线程池创建出的核心线程是不是一直不会被回收?如果这里执行多次的话是不是会创建出许多回收不掉的线程。 PS:addAction(actionVo);这里只是一个业务方法 2.在Linux环境下,每个线程资源共享还是会给每个线程单独分配内存? 3.如果是单独分配内存,当非主线程空闲被回收时,这个线程之前创建的对象会立即被回收吗?还是等垃圾回收的时候才会去回收?
为什么static不能实现多态呢?
假设: class Parent{ public Parent(){}; //静态的方法:被测试能否覆写 public static test(){ System.out.println("Parent的静态方法"); } } class Child extends Parent{ public Child(){}; //静态的方法:测试能否覆写其父类的静态方法 public static test(){ System.out.println(" Child的静态方法"); } } 我所知道的: 1.static方法在JVM类加载时便存在,先与对象存在于内存中 2.当Child对象创建时会先创建Parent对象(而此时父类中的test()方法已经存在了) 2.1 这时接着创建Child对象前,(test()方法已存在) 疑问: 1.是否static方法在类加载分配空间时,当出现了相同的方法名,或者属性名,就只存储先出现的,后面的就不进行存储了? 2.还是,都存储了,只是因为多态的关系,当父类调用test()时,只会去调用其类中的?
JDK的动态代理实现的原理?
看到很多例子,都差不多,比如某个接口被代理了,如果他有一个foo()方法,那么由Proxy.newProxyInstance()方法获取的代理对象proxy也会有foo()方法,但我想知道,调用代理对象proxy.foo()时,对方法的调用是怎样转到InvocationHandler的invoke方法里的???难道是jvm动态创建的代理对象proxy的foo()方法的代码体里是对InvocationHandler对象的invoke方法的调用???哪位大侠告诉小弟啊,我看了源码就是想不通这接口的方法是如何被捕捉又如何被直接转发的呀!
JVM内存溢出问题:freeMemory还很大,为什么出现了OOM?
我使用java编写的一个应用程序,用于产生数据插入到HBase数据库中,但是程序在运行一段时间后就会产生OOM异常: Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread at java.lang.Thread.start0(Native Method) at java.lang.Thread.start(Thread.java:640) at java.util.concurrent.ThreadPoolExecutor.addIfUnderCorePoolSize(ThreadPoolExecutor.java:703) at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:652) at java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:92) at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.processBatch(HConnectionManager.java:1401) at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.processBatchOfPuts(HConnectionManager.java:1499) at org.apache.hadoop.hbase.client.HTable.flushCommits(HTable.java:859) at org.apache.hadoop.hbase.client.HTable.doPut(HTable.java:715) at org.apache.hadoop.hbase.client.HTable.put(HTable.java:693) at storm.monitor.hbase.BasicOperation.addRecord(BasicOperation.java:135) at storm.monitor.util.HBase_Operation.insertIntoHBase(HBase_Operation.java:75) at storm.monitor.util.Data_Generator.insertIntoHBase(Data_Generator.java:215) at storm.monitor.util.Data_Generator.run(Data_Generator.java:394) at storm.monitor.util.Data_Generator.init(Data_Generator.java:68) at storm.monitor.util.Data_Generator.<init>(Data_Generator.java:41) at storm.monitor.util.Main_Generator.main(Main_Generator.java:22) 可是我在类中获得Runtime,输出freeMemory,totalMemory如下free 505328288 total 528154624 max 1037959168 ,明显的可用内存还有很多,怎么会出现上述异常呢? 在我的类中,方法多是静态方法,不过全局变量很少使用,一般都是创建的临时变量,并且是方法结束前都设为null。并且只有一个LinkedList全局对象和几个多维数组。 在eclipse中设置了(x)arguments -Xms512m -Xmx1024m。 到底是什么原因导致了OOM呢,整个应用程序中并没有创建线程的地方。 求解惑!
java调用kettle导入数据内存溢出!!!!!
现在用java调用kettle的ktr模板往数据库中导入数据。kettle版本为4.2.0,oracle版本为11g。 无论jvm设置多大,只要文件数量比较多,内存会一直涨到溢出。调用过程就创建多个ktr对象TranMete,然后放在Trans里面运行。 求大神解决问题。
java中String究竟是传递的值,还是引用
很多人说,java中的String虽然是对象,但是具有值类型的特征。他是值传递,传递的值。 我认为这这种说法完全是错误的。 String和普通对象毫无区别,和其他对象一样,传递的是引用,而不是值。 一段String的运用代码: ``` String a = "123"; public void change(String a){ a = "234"; } ``` 很多人会说,a的值没有变,是因为String是值传递,问题是,就算对于一个普通对象,这样的用法,该对象的值也是不会改变的!这是一个大大的误区。java中根本没有真正的引用传递,不想C#中有ref关键字! 比如: ``` Person p = new Person("张三"); public void change(Person p){ p = new Person("李四"); } ``` 上面对于String的使用和这个自定义Person类的使用上,根本没有本质上的区别。同样,外面的p变量依然是”张三”,不会是“李四。” 同样的代码,放入C#中,加上ref关键字: ``` Person p = new Person("张三"); public void Change(ref Person p){ p = new Person("李四"); } ``` 结果是,p变为了“张三”! 所以说,个人认为java中的String并没有什么特殊性,和其他类一样,同样保存的对象的引用,传递的引用。唯一的特殊性,就是可以直接用“”双引号的方式创建字符串对象。
jni创建虚拟机失败问题,c++dll调用java类在VM初始化中出现错误
![图片说明](https://img-ask.csdn.net/upload/201706/15/1497487523_282629.png) 如上图错误,代码如下: string tmp0 ="-Djava.class.path=.;"; //cout<<tmp0<<endl; string configTmp = tmp0 + m_p0 + ";" + m_p1; //cout<<configTmp<<endl; options[0].optionString = (char*)configTmp.c_str(); vm_args.version = JNI_VERSION_1_6; //设置版本号 vm_args.nOptions = 1; vm_args.options = options; vm_args.ignoreUnrecognized = JNI_TRUE; //定义一个函数指针,下面用来指向JVM中的JNI_CreateJavaVM函数 typedef jint (WINAPI *PFunCreateJavaVM)(JavaVM **, void **, void *); //const wchar_t szJvmPath[]=L"D:\\Java\\jdk1.8.0_131\\jre\\bin\\client\\jvm.dll"; int p2Len = m_p2.length(); WCHAR *szJvmPath = new WCHAR[p2Len+1]; MultiByteToWideChar(0, 0, m_p2.c_str(), -1, szJvmPath, p2Len+1); cout<<szJvmPath<<endl; hInstance = ::LoadLibrary(szJvmPath); cout<<"成功"<<endl; delete []szJvmPath; szJvmPath = NULL; if (hInstance == NULL) { cout<< "LoadLibrary False"<<endl; cout<<::GetLastError()<<endl; return false; } cout<<"成功1"<<endl; //取得里面的JNI_CreateJavaVM函数指针 PFunCreateJavaVM funCreateJavaVM = (PFunCreateJavaVM)::GetProcAddress(hInstance, "JNI_CreateJavaVM"); cout<<"成功2"<<endl; long status = (*funCreateJavaVM)(&jvm, (void**)&env, &vm_args); //查找类,返回JAVA类的CLASS对象 //jclass cls = env->FindClass("D:\\javaOfWorkspace\\Test20170502\\src\\test\\c_call_j"); cout<<"成功3"<<endl; cls = env->FindClass("test20170505/ParserDemo"); 在: long status = (*funCreateJavaVM)(&jvm, (void**)&env, &vm_args);这一步出现错误,如果这个cpp不封装到dll中则能正常运行,封装以后就出现错误,其他配置都一样的,求大神解决。
为什么线程要保存共享成员变量的私有拷贝?
"Java语言规范中指出:为了获得最佳速度,允许线程保存共享成员变量的私有拷贝,而且只当线程进入或者离开同步代码块时才与共享成员变量的原始值对比。" 为什么保存私有拷贝,速度就能提升呢? 还有,这个私有拷贝保存在哪里?frame中的local variable吗? 如果这个共享成员是非primitive的对象,那是不是还要在heap中深克隆这个对象吗? [b]问题补充:[/b] "每条线程都有自己的工作内存(Working Memory),工作内存中保存的是主存中某些变量的拷贝,线程对所有变量的操作都是在工作内存中进行,线程之间无法相互直接访问,变量传递均需要通过主存完成。" JVM的内存模型需要考虑cpu的缓存吗?我以为JVM为每条线程创建的工作内存也是在内存上,所以我就不明白为什么要copy一分到工作内存以提高性能?
java RMI 的问题
问题1 在dos下通过执行start rmiregistry.exe启动了一个注册表进程,简单的说它提供了远程对象的注册服务。当我把一个远程对象注册后,在客户端通过JNDI访问,为什么获取的是一个远程对象的Stub对象?我向里面注册的不是远程对象吗?还是rmiregistry.exe进程就提供了这种机制? 问题2 远程类继承java.rmi.server.UnicastRemoteObject,通过执行exportObject方法,会把一个实现了远程接口的对象导出为远程对象。这个方法到底执行了一个什么样的操作?为什会说“把一个实现了远程接口的对象导出为远程对象”? 问题3 远程对象先创建并注册后才能应用,那我多个客户端程序如何实现访问时服务器都为它们各自生成一个远程对象 问题4 RMI服务器一直在不断的运行,客户端发出的调用请求到底是服务器上哪段程序监听的? 问题5 public static void main(String[] args) { try { HelloService service1 = new HelloServiceImpl("service1"); HelloService service2 = new HelloServiceImpl("service2"); Context namingContext = new InitialContext(); namingContext.rebind("rmi:HelloService1", service1); namingContext.rebind("rmi:HelloService2", service2); System.out.println("服务器注册了两个HelloService对象"); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } 为什么这段服务器段程序在执行完System.out.println("服务器注册了两个HelloService对象"); 后,当前进程仍然没有结束运行? 有书说,向注册表中注册了两个远程对象,注册表一直引用着这两个对象,使得两个对象不会结束生命周期,因而当前服务器程序也不会结束运行。不同的jvm内存中的对象难道可以引用吗? 问题太多了,不好意思多问了,希望大家能帮我解答,谢谢了! [b]问题补充:[/b] lovewhzlq 回答的2和3 我明白了 关于问题1 ,我想做一下补充:在向注册表中注册时,的确是注册的那些远程对象,但客户端通过JNDI获取时获得的是远程对象的Stub,UnicastRemoteObject,通过执行exportObject方法生成一个sketon对象,这个sketon对象保存到什么地方去了,还有客户端用的Stub怎么来的? 我在考虑是不是这个注册表进程,提供了一些满足这些RMI机制,真正实现监听的是不是这个注册表进程
关于java读取文件或连接数据库的资源问题
Java操作文件的时候,是创建相应的对象,利用这个对象来打开和关闭文件。 <br />我想知道当打开文件后只消耗JVM的资源吗(创建的java对象), <br />还是同时也消耗操作系统的资源,如果JVM突然down掉资源能被释放吗 <br /> <br />还有同样,java利用连接DB的时候, <br />那么DB端会产生相应的连接对象, <br />这时候JVM突然down掉,那么DB端并不知道,这个连接对象也不会被释放, <br />那么只有等到超时才能被释放吧<br /><strong>问题补充</strong><br /><div class="quote_title">lifethinker 写道</div><div class="quote_div">对于文件资源,当然耗操作系统资源,并且由操作系统来管理,当JVM突然崩溃,操作系统会回收这个进程的所有资源,当然也包括文件资源。 <br /> <br />对于DB Connection,JVM突然崩溃,DB Server是有办法知道的,最起码它知道Socket连接断开了,数据库连接依赖于它。我测试过Oracle和MySQL的连接,对Oracle的连接,如果不调用Connection.close()方法,即使Socket连接断开了(比如JVM退出),服务器端是不会关闭数据库连接的,但是它设置有超时时间。对MySQL的连接,一旦Socket连接断开,服务器端就会自动关闭数据库连接。 <br /> <br /> <br /><div class="quote_title">sdh5724 写道</div><div class="quote_div">大学学过操作系统了么?</div> <br />你能告诉和操作系统的哪部分相关吗,我去补课! <br /></div> <br /> <br />非常感谢你的回答,从你那学到了google搜不到的东西。 <br /> <br />
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问