距离上次Java的学习有点儿远,工作中还要做自己的公司的项目,所以耽误了,但是,会持续学习,更新自己的笔记。
一、多线程
1.多线程安全问题
问题原因:
当多条语句在操作同一个线程共享数据时,一个线程对多条语句只执行了一部分,还没有执行完,另一个线程参与进来执行。
导致共享数据的错误。
解决:
对多条操作共享数据的语句,只能让一个线程都执行完。在执行过程中,其他线程不可以参与执行。
java中多线程问题有专门的解决方案
就是同步代码块:
synchronized(对象) {
需要被同步的代码
}
对象如同锁。持有锁的线程可以在同步中执行。
没有持有锁的线程即使获取cpu的执行权,也进不去,因为没有锁。
2.同步函数和同步代码块
同步函数用的是哪一个锁?
函数需要被对象调用,那么函数都有一个所属对象引用,就是this。所以同步函数使用的锁是this。
3.多线程通讯<多个生产者和消费者>
a、对于多个生产者和消费者,为什么定义while判断标记?
原因:让被唤醒的线程再一次判断标记。
b、为什么定义notifyAll?
原因:因为需要唤醒对方的线程。<使用notify,容易出现只唤醒本方线程的情况。导致程序中的所有线程都等待>
Java JDK升级到5.0之后,java.util.concurrent.locks
二、String
Java String字符串
String s1 = “abc”; // s1是一个类类型变量,“abc”是一个对象。 字符串最大的特点:一旦被初始化就不可以被改变。
String s2 = new String(“abc”); // s1和s2有什么区别?s1在内存中有一个对象,s2在内存中有两个对象。
System.out.println(s1==s2);
System.out.println(s1.equals(s2)); // String类复写了Object类中equals方法,该方法用于判断字符串是否相同。
3.1常见的字符串操作
1、获取
1.1 字符串中的包含的字符数。也就是字符串的长度。 int length():获取长度
1.2 根据位置获取位置上的某个字符。 char charAt(int index):
1.3 根据字符获取该字符在字符串中的位置。
int indexOf(int ch):返回的是ch在字符串中第一次出现的位置。
int indexOf(int ch, int fromIndex):从fromIndex指定位置开始,获取ch在字符串中出现的位置。
int indexOf(String str):返回的是str在字符串中第一次出现的位置。
int indexOf(String str, int fromIndex):从fromIndex指定位置开始,获取str在字符串中出现的位置。
2、判断
2.1字符串中是否包含某一个子串。
boolean contains(str);
特殊之处:indexOf(str):可以索引str第一次出现的位置,如果返回-1,表示该str不在字符串中存在。
所以,也可以用于对指定判断是否包含。
if(str.indexOf(“aa”)!= 1)
而该方法即可以判断,也可以获取出现的位置。
2.2 字符中是否有内容
boolean isEmpty():原理就是判断长度是否为0.
2.3 字符串是否是以指定内容开头。
boolean startsWith(str);
2.4 字符串是否是以指定内容结尾。
boolean endsWith(str);
2.5 判断字符串内容是否相同。复写了Object类中的equals方法。
boolean equals(str);
2.6 判断内容是否相同,并忽略大小写。
boolean equalsIgnoreCase();
3、转换
3.1 将字符数组转成字符串
构造函数:String(char[])
String(char[],offset,count):将字符数组中的一部分转成字符串。
静态方法:
static String copyValueOf(char[]);
static String copyValueOf(char[] data, int offset, int count)
static String valueOf(char[]);
3.2 将字符串转成字符数组 ***
char[] toCharArray();
3.3 将字节数组转成字符串
String(byte[]);
String(byte[],offset,count):将字节数组中的一部分转成字符串。
3.4 将字符串转成字节数组
byte[] getBytes();
3.5 将基本数据类型转成字符串
static String valueOf(int)
static String valueOf(double)
// 3+“”; // String.valueOf(3);
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。
4、替换
String replace(old char,new char);
5、切割
String[] split(regex);
6、子串。 获取字符串中的一部分
String substring(begin);
String substring(begin, end);
7、转换、去除空格、比较
7.1 将字符串转成大写或者小写
String toUpperCase();
String toLowerCase();
7.2 将字符串两端的多个空格去除。
String trim();
7.3 对两个字符串进行自然顺序的比较。
int compareTo(string);
4.StringBuffer
StrinfBuffer是字符串缓存区
是一个容器。
特点:a、长度可变化。b、可以字符操作多个数据类型。c、最终会通过toString方法变成字符串。
C create U update R read D delete
1.存储
StringBuffer append():将指定数据作为参数添加到已有数据结尾处。
StringBuffer insert(index,数据):可以将数据插入到指定index位置。
2.删除
StringBuffer delete(start,end):删除缓冲区中的数据,包含start,不包含end。
StringBuffer deleteCharAt(index):删除指定位置的字符。
3.获取
char charAt(int index)
int indexOf(String str)
int lastIndexOf(String str)
int length()
String substring(int start, int end)
4.修改
StringBuffer replace(start,end,string)
void setCharAt(int index, char ch)
5.反转
StringBuffer reverse();
6.
将缓冲区中指定数据存储到指定字符数组中。
void getChars(int srcBegin,int srcEnd,char[] dst,int dstBegin)
JDK 1.5版本之后出现了StringBuilder
StringBuffer是线程同步。(多线程建议试用)
StringBuilder是线程不同步的。(单线程建议试用)
Java 基本数据类型对象包装类的最常见作用。
1.基本数据类型对象包装类的最常见作用。
a、基本数据类型转成字符串
基本数据类型+“”
基本数据类型.toString(基本数据类型值);
如:Integer.toString(34);// 将34整数变成字符串型的”34"
b、字符串转成基本数据类型
xxx a = Xxx.parseXxx(String);
int a = Integer.parseInt(“123”);// parse静态方法
double b = Double.parseDouble(“12.34”);
boolean b = Boolean.parseBoolean(“true”);
Integer i = new Integer(“123”);
int num = i.intValue(); // 非静态方法
补充:十进制转成其他进制
toBinaryString();
toHexString();
toOctalString();
其他进制转成十进制
parseInt(String,radix); // parseInt(“110”, 2); // “3c”,16