file.listFiles()
// 返回绝对路径
file.getAbsolutePath()
byte[] tempbytes = new byte[fileSize];
// 从输入流中读取一定数量的字节,并将其存储到字节数组
new FileInputStream(file).read(tempbytes);
File finallyFile = new File(fileUrl);
FileOutputStream fos = new FileOutputStream(finallyFile);
// 文件复制,底层是调用fos.write
Files.copy(sourceFilePath, fos);
// 第一个参数是包括在内的inclusive
String.substring(...)
// 通俗一点的说,就像洗牌一样,随机打乱原来的顺序
Collections.shuffle(list)
// 创建临时文件
file.createTempFile(String prefix, String suffix)
// 创建文件
file.createNewFile()
// createNewFile()需要指定目录路径,createTempFile()的路径为App.getInstance().getApplicationContext().getCacheDir()目录下。
// 将收到的文件传输到给定的目标文件
multipartFile.transferTo(destFile)
// hexStr表示字符串,16表示字符串数值的进制
int a = Integer.parseInt(hexStr, 16)
// 向集合中加入指定元素
Collections.addAll(colls, elements)
public static void main(String[] args) {
List<Student> list = new ArrayList<>();
list.add(new Student("张", 80));
list.add(new Student("王", 70));
// new了一个实现接口的匿名类,需要在匿名类内部(花括号内)实现那个接口
list.sort(new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o1.getGrade() - o2.getGrade();
}
});
}
静态内部类的加载不需要依附外部类,在使用时才加载。
二维数组其实就是二级数组,数组中包含数组。
char[][] x = new char[][]{{'a', 'b'}, {'c', 'd'}};
System.out.println(x[0][1]); //b
- Arrays.copyOf(...)
Arrays的copyOf()方法传回的数组是新的数组对象,改变传回数组中的元素值,不会影响原来的数组。
copyOf()的第二个自变量指定要建立的新数组长度,如果新数组的长度超过原数组的长度,则保留数组默认值0。
- System.arraycopy(...)
byte[] srcBytes = new byte[]{1,2,3,4,5,6,7,10,15,50};
byte[] destBytes = new byte[5];
// 原数组、从源数据的起始位置开始、目标数组、目标数组的开始起始位置、源数组中要copy的数组的长度
System.arraycopy(srcBytes,0,destBytes ,0,4);
System.out.println(destBytes); // 1 2 3 4 0
- HashMap
hashmap进行put时,key相同,value值会进行覆盖。
put过程-》对象key的hashcode 经过hash()处理-》得到hash值-》(n - 1) & hash计算出数组下标i。 (n - 1) & hash相当于hash % n。
在put放入元素时,HashMap又自己写了一个hash方法来计算hash值,为什么不用key本身的hashCode方法,而是又处理了一下?
我的理解是当table很小的时候,计算元素在table中的位置(n-1)&hash。如果用key本身的hashCode作为hash,只用到了hash值的低位,这样当不同的hash值低位相同,高位不同的时候会产生冲突。
实际上的hash值是将hashcode低16位与高16位做异或运算,相当于混合了高位和低位,增加了随机性。
判断放入HashMap中的元素要不要替换当前节点的元素,key满足以下两个条件即可替换:
1、hash值相等。
2、key的==或equals的结果为true。
- 位移运算符
<<左移运算,>>右移运算,还有不带符号的位移运算 >>>。
左移一位相当于乘以2,左移n位就相当于乘以2的n次方。
右移一位相当于除2,右移n位相当于除以2的n次方。
- catalina
Tomcat服务器使用的 Apache实现的servlet容器的名字。
Tomcat的核心分为3个部分:
(1)Web容器---处理静态页面;
(2)catalina --- 一个servlet容器-----处理servlet;
(3)还有就是JSP容器,它就是把jsp页面翻译成一般的servlet。