----【Java核心API】
YEN_csdn
这个作者很懒,什么都没留下…
展开
-
JAVA集合框架学习总结
集合框架 HashMap HashSet Hashtable LinkedHashMap LinkedHashSet ArrayList LinkedList原创 2016-06-07 10:12:05 · 4261 阅读 · 1 评论 -
Java多线程线程安全实现方式
线程安全就是要保证数据的高度一致性和准确性,但不是一定要加锁才是线程安全性,只要代码里没有变量互串,线程之间互不影响,就是线程安全的。 要了解线程安全,可以先看一下线程不安全是怎样的一种现象。public class TreadNoSafeDemo { public static void main(String[] args) { new ThreadNoSafeTest(原创 2016-06-17 19:38:30 · 14973 阅读 · 3 评论 -
Java内存模型与多线程数据可见性和操作的有序性
CPU在计算的时候,并不总是从内存读取数据,而是按:寄存器->高速缓存->内存的顺序读取,一些使用频繁的数据会被放在寄存器和高速缓存中,当线程计算完后,这些缓存的数据在适当的时候被写回内存,当多个线程同时读取某个内存的数据时,会涉及到数据的可见性和操作的有序性问题。 Java是平台无关性语言,JLS(java语言规范)定义了一个统一的内存管理模型JMM(Java Memory Model),JMM原创 2016-06-17 18:34:23 · 1344 阅读 · 0 评论 -
Java多线程-当前线程副本:ThreadLocal
ThreadLocal是一个关于创建线程局部变量的类。 一般情况我们创建的变量是可以被任何一个线程访问并修改的,而使用ThreadLocal创建的变量只能被当前线程访问,其他线程无法访问和修改。 ThreadLocal<T> 接口的方法也很简单,只有四个方法: public class ThreadLocalDemo { //通过匿名内部类创建一个ThreadLocal对象。原创 2016-06-16 20:27:53 · 1613 阅读 · 0 评论 -
Java守护线程(后台线程)
Java守护线程(后台线程) java的垃圾回收线程就是一个守护线程。 当线程结束的时候守护现场也就自然会结束了,守护线程和普通线程的写法是一样的,只是在start()之前要先使用public final void setDaemon(boolean vale)设置为true。可以使用thread.isDaemon()判断特定的线程thread是否为守护线程:public class Threa原创 2016-06-16 16:23:48 · 2464 阅读 · 0 评论 -
线程的生命周期与常用方法
线程的生命周期一共五个状态:新建、就绪、运行、堵塞、死亡 (1)新建 new Thread Thread thread=new Thread(); 当创建一个Thread对象时,这个线程就进入了新建状态,有了自己的内存空间,但还没有启动,此时线程还不是活的。 (2)就绪 runable 线程已经启动,正在等待CPU时间片。(通过线程的start()方法启动线程后进入就绪状态),此时具备运原创 2016-06-15 14:24:28 · 1206 阅读 · 0 评论 -
关于线程的中断机制
Java中没有提供任何的机制来安全的终止线程,那我们应该怎么让线程停止或者中断呢? java停止或中断线程有下列方式: 1.调用Thread.stop() 2.利用Thread.interrupt()方法和机制调用Thread.stop() 使用这种方法强迫停止一个线程,并抛出一个新创建的ThreadDeath对象作为异常,停止一个还未启动的线程也是允许的,如果稍后启动该线程,他会立即终止。原创 2016-06-15 13:08:14 · 3442 阅读 · 0 评论 -
多线程执行时为什么调用的是start()方法而不是run()方法
Thead类中start()方法和run()方法的区别 start()用来启动一个线程,当调用start()方法时,系统才会开启一个线程,通过Thead类中start()方法来启动的线程处于就绪状态(可运行状态),此时并没有运行,一旦得到CPU时间片,就自动开始执行run()方法。此时不需要等待run()方法执行完也可以继续执行下面的代码,所以也由此看出run()方法并没有实现多线程。原创 2016-06-15 11:34:25 · 11133 阅读 · 5 评论 -
多线程的实现基础知识总结
多线程是在同一程序内部并行执行,因此会对相同的内存空间进行并发读写操作。Java中实先多线程的方式主要有如下几种:1.继承Tread类2.实现Runable接口3.实现Callable接口(应用程序可以使用Executor框架来创建线程池)。其中最常见的是继承Tread类和实现Runable接口这两种方式。这两种方式的话一般选择实现Runable接口,因为实现Runable接口比继承Trea原创 2016-06-14 22:05:00 · 802 阅读 · 0 评论 -
Java集合框架使用场景
不需要唯一用List 需要快速插入、删除元素:用LinkedList 需要快速访问元素: |–单线程环境:用ArrayList |–多线程环境:用Vector 需要先进后出的特殊结构用Stack需要唯一用Set 需要指定的顺序:TreeSet 不需要指定的顺序:HashSet 需要得到与存储一致的顺序:LinkedHashSet存储的是键值对用Map 涉及堆栈、队原创 2016-06-14 10:02:26 · 3778 阅读 · 3 评论 -
Java中Fail-Fast机制、ConcurrentModificationException异常
ConcurrentModificationException 异常:当方法检测到对象的并发修改,但不允许修改时就会抛出这个异常。Fail-Fast 机制是java集合(Collection)中的一种错误机制。当多个线程对同一个集合操作时就可能会产生Fail-Fast 事件。 比如:有两个线程A和B,线程A通过iterator 遍历集合T中的元素时,某个时候线程B修改了集合T的结构,此时就会产生F原创 2016-06-07 20:58:27 · 1132 阅读 · 0 评论 -
Java关键字volatile修饰变量
volatile关键字的作用是告诉编译器,凡是被该关键字申明的变量都是易变的、不稳定的,所以不要试图对该变量使用缓存等优化机制,而应当每次都从他的内存地址中去读取值,但volatile并不是每次更改完就要立刻将他写回内存,volatile只提供了内存的可见性,并不提供原子性(与锁机制的区别:锁机制即提供了内存的可见性又提供了原子性)。 使用volatile标记的变量在读取或写入时不需要使用锁,原创 2016-06-18 08:55:22 · 2066 阅读 · 0 评论 -
线程安全的集合类、CopyOnWrite机制介绍
关于集合框架的其他部分可以查看另一篇文章:JAVA集合框架学习总结,这里仅就集合框架中的线程问题做讨论,有错误之处欢迎指正。LinkedList、ArrayList、HashSet是非线程安全的,Vector是线程安全的; HashMap是非线程安全的,HashTable是线程安全的;Java.util.concurrent.ConcurrentHashMap ConcurrentHashMa原创 2016-06-18 14:22:22 · 1665 阅读 · 0 评论 -
LinkedList的实现
package main.java.LinkedListdemo;import java.util.ConcurrentModificationException;import java.util.Iterator;import java.util.NoSuchElementException;/** * DateTime: 2016/11/4 15:02 * 功能: * 思路: */p原创 2016-11-07 13:21:08 · 776 阅读 · 0 评论 -
ArrayList的实现
ArrayList泛型类的实现。 内部类实现方式源码:package main.java.arraydemo;import java.util.Iterator;/** * DateTime: 2016/11/4 09:42 * 功能:实现ArrayList泛型类的实现: * MyArrayList将保持基础数组,数组的容量,以及存储在MyArrayList中的当前项数; *原创 2016-11-04 10:38:59 · 834 阅读 · 0 评论 -
信息摘要算法——MessageDigest类
MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。 MessageDigest 对象开始被初始化。该对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。 对于给定原创 2016-09-17 17:38:06 · 2834 阅读 · 0 评论 -
初识Java TCP/IP Socket-UDP网络编程知识
Java 通过 DatagramPacket 类和 DatagramSocket 类来使用 UDP 套接字,客户端和服务器端都通过DatagramSocket 的 send()方法和 receive()方法来发送和接收数据,用 DatagramPacket 来包装需要发送或者接收到的数据。发送信息时,Java 创建一个包含待发送信息的 DatagramPacket 实例,并将其作为参数传递给Data原创 2016-07-26 00:43:28 · 572 阅读 · 0 评论 -
初识Java TCP/IP Socket-TCP网络编程知识
Java为TCP提供了两个类:Socke 类和 ServerSocket 类。 一个 Socket 实例代表了 TCP 连接的一个客户端,而一个 ServerSocket 实例代表了 TCP 连接的一个服务器端,一般在 TCP Socket 编程中,客户端有多个,而服务器端只有一个,客户端 TCP 向服务器端 TCP 发送连接请求,服务器端的 ServerSocket 实例则监听来自客户端的 T原创 2016-07-26 00:24:26 · 719 阅读 · 0 评论 -
Java 中网络相关 API:InetAddress、URL 的应用
Java 中网络相关 API 的应用(1)Java 中的 InetAddress 的应用 (此类表示互联网协议(IP) 地址),使用方法如下:public class InetAddressDemo { public static void main(String[] args) throws UnknownHostException { //获取本机的InetAddress原创 2016-07-25 23:54:45 · 711 阅读 · 0 评论 -
Java注解
Java注解是插入代码中的一种注释或者说一种元数据(mete data)。这些注解信息可以在编译期使用编译期使用预编译工具进行处理,也可以运用Java的反射机制在运行时处理。注解为我们在代码中添加信息提供了一种形式化的方法。Java中的注解主要是:元注解自定义注解元注解 Java提供了四个基本的元注解类型: 这些类型在:java.lang.annotation包中 @Documente原创 2016-06-23 21:40:32 · 1943 阅读 · 0 评论 -
Java NIO和IO的区别
IO的主要内容FileInputStreamOutputStreamReaderWriterRandomAccessFileNIO有以下核心的数据抽象类型。BufferChannelsSelectorIO是面向流(Stream)的,NIO是面向缓冲(Buffer)的。 面向流就是每次都是流中读取一个或多个字节/字符,直至读完所有的字节/字符,不能前后移动流中的数据;面向缓冲是原创 2016-06-19 19:52:45 · 818 阅读 · 0 评论 -
Java反射机制
Java反射机制可以让我们在运行期检查类、接口、变量、以及方法的信息。反射机制还可以让我们在运行期实例化对象,调用方法,通过调用get/set方法设置变量的值。 那么,通过Java的反射机制我们能获取到哪些信息呢?主要就是一下几大类:类构造器变量(包括私有的)方法(包括私有的)访问器(Sitter/Getter)注解泛型数组动态代理动态类加载与重载下面通过操作Test类的代码原创 2016-06-18 21:02:55 · 744 阅读 · 0 评论 -
Java多线程synchronized、ReentrantLock、ReentrantReadWriteLock 和StampedLock 的对比
synchronized是在JVM层面上实现的,可以通过一些监控工具控制synchronized的锁定,当代码出现异常时,JVM会自动释放锁定。当只有少量竞争者的时候,synchronized是一个很好的通用的锁实现。synchronized的锁是针对一个对象的。ReentrantLock、ReentrantReadWriteLock 和StampedLock都是代码层面的锁定,要保证锁一定会被释原创 2016-06-17 22:24:39 · 1872 阅读 · 0 评论