Java错题本01

如何实现字符串的反转及替换?


ArrayList和 Vector 都是使用数组方式存储数据

LinkedList使用双向链表实现存储


Set和 Map 容器都有基于哈希存储和排序树的两种实现版本,基于哈希存储的版本理

论存取时间复杂度为O(1),List以特定索引来存取元素


sleep()方法(休眠)是线程类(Thread)的静态方法,wait()是 Object 类的

方法,只有调用对象的notify()方法(或 notifyAll()方法)时才能唤醒


设计模式

二分法


程序和进程的本质区别是:静态和动态特征

Ipv6占用16个字节,128bits;IP数据包的最大长度是64K字节(65535)

RARP协议根据MAC地址求主机对应的IP地址

异常:

可查异常即必须进行处理的异常,要么try catch住,要么往外抛,谁调用,谁处理,比如 FileNotFoundException。如果不处理,编译器,就不让你通过

运行时异常RuntimeException指: 不是必须进行try catch的异常 常见运行时异常: 除数不能为0异常:ArithmeticException下标越界异常:ArrayIndexOutOfBoundsException空指针异常:NullPointerException在编写代码的时候,依然可以使用try catch throws进行处理,与可查异常不同之处在于,即便不进行try catch,也不会有编译错误 。Java之所以会设计运行时异常的原因之一,是因为下标越界,空指针这些运行时异常太过于普遍,如果都需要进行捕捉,代码的可读性就会变得很糟糕。


每个Unicode码,一个字符两个字节,所以16bit。

String +“xxxx”会生成一个新的字符串对象。数组不具备索引访问功能。

Collection主要方法

8种基本数据类型:byte short long char boolean int float double   使用时是值传递,除此为应用传递。

String s1=“hello”;String s2= “hello”,(s1==s2)为true。若String s1 = new String(“hello”),为false;,new操作会在堆上分配两个字符串,地址不同


Jvm会给新创建的对象一个指针this,this是对当前类对象的引用,实例化后才存在。

类方法是不依赖对象而存在的方法,只要有访问权限,类方法可以调用任意的类方法。

对象被实例化后,类方法即可调用实例方法。


构造方法:

可省略,编译器会提供一个默认的方法

构造方法必须与类同名,方法名也可以和类同名。

一个对象被new时一定会调用构造方法。

因为构造方法可以重载,所以一个类可以定义多个构造方法


Array Vector LinkedList都是 可动态改变 的数组

A和V是基于Object[] array,内存开辟连续空间。L采用双向列表。v是线程安全的。


事务是数据库中一个单独的执行单元,四个属性:原子性、一致性、隔离性、持久性


Java集合笔记:

四种体系:

Set:无序不重复

List:有序重复

Map:有映射关系

Queue:队列集合实现

两个接口:Collection(list set queue)和Map(根接口)

HashSet:不是同步;元素值可以是null。当向HashSet存入元素,调用该对象的hashCode()方法得到该对象的hashCode值,由值决定在在HashSet的存储位置。

两个元素相等的标准:equals()方法返回true,hashCode()相等

不要轻易修改HashSet的对象。

LinkedHashSet是Hashet的子类,使用链表维护元素次序

TreeSet是SortedSet接口的实现类,确保集合元素处于排序状态。只能添加同一种类型的对象

当一个对象加入加入TreeSet集合时,调用该对象的compareTo(Object obj)方法与容器其他方法比较大小,然后根据红黑树结构找到存储位置,若相等,无法添加。返回0表示相等。

EnumSet类


各Set实现类的性能分析

Hashset的性能优于TreeSet,除非需要一个保持排序的Set。遍历LinkedHashSet更快。

EnumSet是所有Set中性能最好的,但只能保存同一个枚举类的枚举值作为集合元素

这三个类都是线程不安全的,可以通过synchronizedSortedSet方法包装,在创建时进行。

SortedSet s = Collections.synchronizedSortedSet(new TreeSet());


List集合

集合的每个元素都有对应的顺序索引。允许重复元素,默认按添加顺序设置索引。

Void add (int index,Object element)

Object get/remove(int index)


List类的两个典型实现:ArrarList和Vector,都是基于数组实现,动态允许再分配。使用initialCapacity设置数组长度,超过时会自动增加。

显著区别,ArrayList是线程不安全的

ArrayKust LinkedList是线性表的典型实现,基于数组和链。LinkedList提供了双端队列、栈的功能。总体上A的性能好。遍历集合,A和V使用随机访问方法(get),L使用迭代器(iterator)

Queue集合

PriorityQueue按队列大小重新排序


Map集合

List有数字索引,Map用key索引。从源码上看,包装所有value为null的Map即可实现Set。

HashSet和Hashtable(古老的类):

Table线程安全,不能有key或value为null。Map允许有key或value为null

判断key需要hashnode和equals。判断value只要equals



泛型

集合缺点,忘记对象数据类型,dog对象的集合可能放进cat对象


例子:创建一个只保存字符串的集合

List strList = new ArratList()后面的方括号可省略。


Java多线程

进程的三个特征:独立性(独立拥有自己的资源,用户进程不可以直接访问其他进程的地址空间)

动态性:进程和程序的区别。进程具有生命周期和各种不同状态

并发性:多个进程可以在单个处理器上并发进行(并行性是指同时执行没有切换)


线程,也被称为轻量级进程

进程与线程的区别

1)一个程序至少有一个进程,一个进程至少有一个线程.

2)多线程程序的并发性高,因为线程的划分尺度小于进程。

3)进程在执行过程中拥有独立的内存单元分配大量资源,而多个线程共享内存,效率高。

4)线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

5)进程和线程的重要区别:从逻辑角度来看,多线程的意义在于一个应用程序,有多个执行部分可以同时执行。但对于操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。

创建线程

1.继承Thread类

一、重写run方法,也称为线程执行体。

二、创建子类的实例,即创建了线程的对象

三、调用start()方法启动线程

2.实现Runnable接口

一、定义Runnable接口的实现类,重写run方法

二、创建Runnable实现类的实例


Runnable好处:

1可继承多个接口

2共享一个target对象


Thread好处:

使用this即可获得当前线程

���fH�l

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容