[Java Basics] Stack, Heap, Constructor, I/O, Immutable, ClassLoader
Good about Java:
friendly syntax, memory management[GC can collect unreferenced memory resources], object-oriented features, portability.
Stack
Stores method invocations, local variables(include object reference, but the object itself is still stored in heap).
If you look at the stack trace, the top method is the one being called, and once it is finished, it will be removed out of the stack.
Heap
Stores all objects(include instance variables in the class).
.hashcode() returns the memory address of the object, so no same hashcode for two objects.
But when the Class is value object, you could override .hashcode() and .equals().
Constructor
Default parameterless constructor: only generated by compiler when there is no your constructor.
Parent constructor: if parent class has default constructor, compiler will automatically call it without .super(). But if not, or you want to call the parent constructor with parameters, you need to call .super() explicitly.
Overloaded constructor: use .this(...) at the first line.
File I/O
There are two streams: Character stream & Binary stream
Character stream: to read/write human readable files, like .txt .xml .html
Class: FileReader/Writer[extends InputStreamReader, 缺点:使用系统默认字符字节编码方式], more advanced: BufferedReader/Writer
Binary stream: to read/write machine readable files, like .exe .class .obj
Class: FileInput/OutputStream, more advanced for Object: ObjectInput/OutpoutStream(.writeObject() method).
FileInputStream是最基本的,只能读出来Byte,而Wrapper class DataInputStream高级一些,可以读出来各种primitive types。ObjectInputStream另有readObject()。如果你想读出来String, 那么使用InputStreamReader[优点:可以指定字符字节编码方式].InputStreamReader (and its father Reader) are used specifically to deal with characters (so strings) so they handle charset encodings (utf8, iso-8859-1, and so on) gracefully.
Example:
// 读取字节转换成字符
String charset = "US-ASCII";
FileInputStream inputStream = new FileInputStream(file);
InputStreamReader reader = new InputStreamReader(inputStream, charset);
StringBuffer buffer = new StringBuffer();
char[] buf = new char[64];
int count = 0;
try {
while ((count = reader.read(buf)) != -1) {
buffer.append(buffer, 0, count);
}
} finally {
reader.close();
}
读写file要注意的: new FileReader(filename)会throw FileNotFoundException(extends IOException),bufferedReader.readLine()会throw IOException,最后别忘记bufferedReader.close()。读写file更好的方法是用InputStreamReader(new FileInputStream(filename)),因为FileReader does not allow you to specify an encoding and instead uses the plaform default encoding, which makes it pretty much useless as using it will result in corrupted data when the code is run on systems with different platform default encodings.
Immutable Class
Instance could not be modified. 这就保证了当前线程用到的immutable object不会被其它线程修改。
How to: private final fields, final class, no setter methods, ensure exlusive access to mutable components.
String
StringBuilder不是thread-safe的,而StringBuffer由于有synchronized methods所以是thread-safe的。
ClassLoader
JVM有Bootstrap(核心类库), Extensions(扩展类库), System Class Loaders,App classloader(CLASSPATH类),会load很多classes before loading包含main()的class。
程序的开始是main(String[] args), 由此开始由Class loader来load用到的class。
一个classloader只能load同一个class一次,而同一个class可以由不同的classloaders来load。
A software library is a collection of related object code. In the Java language, libraries are typically packaged in JAR files. Libraries can contain objects of different types. The most important type of object contained in a Jar file is a Java class. A class can be thought of as a named unit of code. The class loader is responsible for locating libraries, reading their contents, and loading the classes contained within the libraries. This loading is typically done "on demand", in that it does not occur until the class is actually used by the program. A class with a given name can only be loaded once by a given classloader.
Even building a JAR file from the class files doesn't change this -- the JAR is just a container for the class files.
The initial set of class loads are all triggered by the attempt to load the 起始class. These are the core classes that are used by every Java program, no matter how small. 然后开始load 当前class用到的class, recursively.
A lot happens inside the JVM when a class is loaded and initialized, including decoding the binary class format, checking compatibility with other classes, verifying the sequence of bytecode operations, and finally constructing a java.lang.Class instance to represent the new class.
Sockets
In UDP, as you have read above, every time you send a datagram, you have to send the local descriptor and the socket address of the receiving socket along with it. Since TCP is a connection-oriented protocol, on the other hand, a connection must be established before communications between the pair of sockets start. So there is a connection setup time in TCP.
Client:
Socket MyClient;
try {
MyClient = new Socket("Machine name", PortNumber);
}
catch (IOException e) {
System.out.println(e);
}
Server:
ServerSocket MyService;
try {
MyServerice = new ServerSocket(PortNumber);
}
catch (IOException e) {
System.out.println(e);
}
Socket clientSocket = null;
try {
serviceSocket = MyService.accept();
}
catch (IOException e) {
System.out.println(e);
}
Input at Client side:
DataInputStream input;
try {
input = new DataInputStream(MyClient.getInputStream());
}
catch (IOException e) {
System.out.println(e);
}
Input at Server side:
DataInputStream input;
try {
input = new DataInputStream(serviceSocket.getInputStream());
}
catch (IOException e) {
System.out.println(e);
}
Output at Client side:
PrintStream output;
try {
output = new PrintStream(MyClient.getOutputStream());
}
catch (IOException e) {
System.out.println(e);
}
Passing parameter
Java is always passing by value. Value means copy of primitive variable, or copy of object reference[pointing to the same object].
So the original variable is not changed, in the method there will be a copy, but if you set the object, it will change the object content.
Why arguments passed to an anonymous inner class have to be final?
如果你pass local variables to anonymous class, 那么当当前method退出的时候这些local var会被stack清除,而你的anonymous class object如果再想access这些fields就会报错。所以,如果你把这些local var定义为final,那么JVM compiler就把它们变成了constants,之后再access这些fields就不会有问题。
Boxing & Unboxing
Why do we need wrappers for primitive types?
So that a null value is possible, to include in a collection...
Boxing: auto from primitive to Wrapper class. Unboxing: vice versa, but can throw NullPointerException, if Integer i = null; int x = i;
Public methods of java.land.Object class
.toString(), .hashCode(), .equals(), .clone(), .wait(), .notify(), .notifyAll(), .getClass()
What problems can be encountered when only overriding .equals() and not .hashcode()?
x.equals(y) does not mean they have same hashcode[default implementation], then it is not possible to use this type as a key in hashmap: because hashmap will first call .hashcode() and then .equals() when determining if the key is present in the map.
所以实际中你override了.equals()以后,一定要override .hashcode(),用同一套fields来calculate both methods.
[Java Basics] Stack, Heap, Constructor, I/O, Immutable, ClassLoader的更多相关文章
- 如何给女朋友讲明白:Java 中 Stack(栈) 与 Heap(堆)
背景 Java 中 Stack(栈) 与 Heap(堆) 是面试中被经常问到的一个话题. 有没有对 Java 中 Stack(栈) 与 Heap(堆) 烂熟于心的童鞋,请举手!!!(怎么没人举手-) ...
- 认识Java Core和Heap Dump
什么是Java Core和Heap Dump Java程序运行时,有时会产生Java Core及Heap Dump文件,它一般发生于Java程序遇到致命问题的情况下. 发生致命问题后,Java进程有时 ...
- java集合类——Stack类
查看java的API文档,Stack继承Vector类. 栈的特点是后进先出. API中Stack自身的方法不多,基本跟栈的特点有关. import java.util.Stack; public c ...
- java.util.Stack类中 empty() 和 isEmpty() 方法的作用
最近在学习算法和数据结构,用到Java里的Stack类,但程序运行结果一直和我预料的不一样,网上也没查清楚,最后查了API,才搞明白. java.util.Stack继承类 java.util.Vec ...
- Java数据类型Stack栈、Queue队列、数组队列和循环队列的比较
判断括号是否匹配:调用java本身 import java.util.Stack; public class Solution { public boolean isValid(String s){ ...
- java.util.Stack类中的peek()方法
java.util.stack类中常用的几个方法:isEmpty(),add(),remove(),contains()等各种方法都不难,但需要注意的是peek()这个方法. peek()查看栈顶的对 ...
- java之Stack详细介绍
1 Stack介绍 Stack简介 Stack是栈.它的特性是:先进后出(FILO, First In Last Out). java工具包中的Stack是继承于Vector(矢量队列)的,由于Ve ...
- java.util.Stack(栈)的简单使用
import java.util.Stack; import org.junit.Before; import org.junit.Test; /** * Stack(栈)继承了Vector类,底层实 ...
- java集合类——Stack栈类与Queue队列
Stack继承Vector类,它通过五个操作对类 Vector 进行了扩展. 栈是 后进先出的. 栈提供了通常的 push 和 pop 操作,以及取堆栈顶点的 peek 方法.测试堆栈是否为空的 em ...
随机推荐
- MVC设计模式(持续更新中)
MVC设计模式--->英文全称为: model(模型) View (视图) Controller(控制) MVC是一种设计思想.这种思想强调实现模型(Model).视图(View)和控制 ...
- 179. Largest Number -- 数字字符串比较大小
Given a list of non negative integers, arrange them such that they form the largest number. For exam ...
- Android之ScrollView嵌套ListView
在ScrollView中嵌套使用ListView,ListView只会显示的内容只有一行多一点 解决方案: public class Utility { public void setListView ...
- C++实现对树的创建和前中后序遍历
#include<iostream>#include<stdio.h> using namespace std; class BitNode{ public: char dat ...
- javascript 把字符串转换为对象
function strToJson(str) { var json = (new Function("return " + str))(); return json;}
- Servlet页面跳转实现方法的区别
一直对Servlet页面跳转的几种方式理解的糊里糊涂的,今天在网上搜了一把,找到一遍比较好的,记下来,以后看看. Servlet页面跳转分两部分,一是发生在Servlet,一是在JSP,其实JSP也就 ...
- redhat enterprixe 5.0 web 服务配置与管理
一.Web服务及工作原理 Web服务的实现采用客户/服务器模型.客户机运行Web客户程序(浏览器),作用是解释和显示Web页面,相应用户的输入请求,并且通过http协议将用户请求传递给Web服务器.W ...
- [示例]NSDictionary编程题-字典的排序应用(iOS5班)
代码? #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { @autoreleasepo ...
- [转] jQuery源码分析-如何做jQuery源码分析
jQuery源码分析系列(持续更新) jQuery的源码有些晦涩难懂,本文分享一些我看源码的方法,每一个模块我基本按照这样的顺序去学习. 当我读到难度的书或者源码时,会和<如何阅读一本书> ...
- POJ 1083 Moving Tables 思路 难度:0
http://poj.org/problem?id=1083 这道题题意是有若干段线段,每次要求线段不重叠地取,问最少取多少次. 因为这些线段都是必须取的,所以需要让空隙最小 思路: 循环直到线段全部 ...