java
文章平均质量分 77
IT_tangh
这个作者很懒,什么都没留下…
展开
-
java反射
什么是java反射? JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。(from:百度百科) 指程序可以访问,检测和修改它本身状态或行为的一种能力,并能根据自身行为的状态和结果,调整或修改应用所描述行为的状态和相关的语义。原创 2017-01-02 16:37:12 · 211 阅读 · 0 评论 -
原型模式
什么是原型模式? 百科定义:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。通俗的说,就是复制现在的已有对象,来创建新的对象,java对象里的复制粘贴。实现方式Object类中提供有本地方法clone,java类只要实现了Cloneable接口,就可以使用clone方法来进行对象的拷贝,使用很简单,下面来看代码:public class Prototype implements原创 2017-07-02 11:06:49 · 272 阅读 · 0 评论 -
有一个任务队列,分别有A、B、C三种类型的任务,设计一种功能,让三种任务分别按照x:y:z(具体比例可配置)的比例进行执行
朋友的面试题,如下 有一个任务队列,分别有A、B、C三种类型的任务,设计一种功能,让三种任务分别按照x:y:z(具体比例可配置)的比例进行执行解之。 主要的思路是lock+condition处理任务调度。原创 2017-07-26 19:13:05 · 1262 阅读 · 0 评论 -
如何控制线程执行的顺序?
如何控制线程执行的顺序?要解决如上的题目,得理解题意的重心在哪。关键词:线程与顺序。先来一段多线程执行的代码。public class Test { public static void main(String[] args) { Thread t1 = new Thread(new MyThread1()); Thread t2 = new原创 2018-01-11 22:56:43 · 17114 阅读 · 3 评论 -
必知必会的单例模式
在开发过程中,有些对象我们至始至终只需要一个实例,比如配置文件、工具类、线程池、缓存、日志对象等,如果创造多个实例,就会导致许多问题,比如占用过多资源,不一致的结果等。基于以上的问题,单例模式应运而生了,下面来看看单例的实现方式吧。v1.0(非线程安全懒汉版)package com.v1;public class Singleton { // 私有构造方法 p原创 2018-01-11 23:05:27 · 222 阅读 · 3 评论 -
源码浅析--String
源码浅析先拿String开刀。试问自己,平常工作中用的那么多,但是真的了解String吗? 想要真正了解一个类,还得从源码入手。(本文JDK源码版本1.7.0_75)public final class String implements java.io.Serializable, ComparableString>, CharSequenceString 实现了Ser原创 2018-01-16 23:25:55 · 199 阅读 · 0 评论 -
JVM进阶之运行时数据区
前言 最近在看重温JVM相关的知识点,但总感觉看书很枯燥乏味,看别人的博客知识又显得零碎,知识体系不够系统,所以有必要把所见所闻所学的点,好好地梳理成文,加强自己理解程度的同时,挖掘自身的盲点。好了,鸡血不宜多,让我们开始JVM的新篇章。 话说平时开发中的我们有曾想过写过的代码运行在哪儿,比如在类中声明了static类型的变量,在方法中new了一个对象等等……如果这些都不了解,我只能说原创 2018-01-19 23:08:49 · 302 阅读 · 0 评论 -
笔试题(1)--两个线程交叉打印递增数字,用synchronized和wait实现
朋友在最近的笔试中遇到一道笔,如下: 开启两个线程,一个线程打印1到100的奇数。如1,3,7…99. 另外一个线程打印1到100的偶数。如2,4,6…100. 1到100的数字最终打印出来格式是1,2,3,4,5…100. 要求用synchronized和wait实现.Talk is cheap,show me the code:public class WaitT...原创 2018-03-23 23:14:37 · 3325 阅读 · 0 评论 -
Java并发编程(二)-- synchronized
从上一篇讲线程中,我们了解到了线程的各个状态,以及如何状态间的转换。此篇来温习下,线程的阻塞状态与运行态是怎样的转换过程。synchronized我们知道,多个线程相互配合的完成某一项工作,必然牵扯到对共享资源的竞争。而synchronized关键字便是有效实现多个线程间同步操作的利器,可以使共享资源在同一时间只能被一个线程享用,从而保证了线程对共享资源的可见性和排他性,实现线程安全。...原创 2018-03-30 22:51:28 · 316 阅读 · 0 评论 -
Java并发编程(一)-- 线程
线程是现代操作系统调度的最小执行单元,也有轻量级进程一说。一个进程可包含多个线程,或者说一个进程里可创建多个线程,每个线程都有自己独立的计数器、栈等等信息,并且能够访问共享的堆内存中变量数据。线程的状态Java的线程是有生命周期的,在运行过程中处于以下6种状态之一:状态名称 说明NEW 初始状态,线程被构建,但是还没有调用start0方法RUNNABLE 运行状态,...原创 2018-03-28 22:47:04 · 286 阅读 · 0 评论 -
Java并发编程(三)-- 线程池及其常用实现
Java里的线程池在平日的工作用的不算少,特别是有大量数据需要多线程处理的情形,那么大家在用之前是不是该刨根问底呢? 我们知道,线程池不光是Java里有涉及,各大开源框架、中间件、数据库等都会设计不同类型的线程池,比如Dubbo、Tomcat、MySQL等等等,因为使用线程池的好处如下:通过重复利用已经创建的线程降低线程创建和销毁带来的性能损耗;提高任务的响应速度,任务不需要等待线程创建...原创 2018-04-06 19:57:44 · 789 阅读 · 0 评论 -
Java并发编程(四)-- AQS
锁是用来控制多个线程访问共享资源的方式,对共享资源加锁能够有效解决对资源的并发问题,比如在方法中或方法块中加synchronized关键字。在JDK5以后并发包中增加了Lock接口,用来实现锁功能。Lock提供了与Synchronized类似的同步功能,但是在使用时需要显示的获取和释放锁,故而Lock又称为“显示锁”,Synchronized则称“隐式锁”。Lock相对于Synchronized,...原创 2018-05-01 17:45:16 · 671 阅读 · 0 评论 -
代理模式
今天聊聊平时工作中很常见的Java设计模式–代理模式。什么是代理模式?为其他对象提供一种代表,以控制对这个对象的访问。代理对象起到中介的作用,用户与代理对象打交道,不直接接触实际对象。使用代理模式创建代表对象,让代理对象控制某对象的访问,被代理的对象可以是远程的对象、创建开销大的对象或者需要安全控制的对象。常见的代理模式:远程代理–为不同地理的对象,提供局域网对象(监控全国分店)虚拟代理原创 2017-05-14 23:09:09 · 463 阅读 · 0 评论 -
JVM探秘之GC
GC的三个问题(what,when,how),带着问题去思考。哪些内存需要回收? 程序计数器、虚拟机栈、本地方法栈3个区域随线程而生死,所需要的内存大小基本是在编译期间确定下来的,一旦线程或方法结束,内存也就跟着回收了,所以这几个区域不需要过多的考虑垃圾回收问题。但是java堆和方法区只有在程序运行时才能确切的知道需要哪些对象需要多少内存,这部分的内存分配和回收都是动态的,所以这部分内存才是需要垃原创 2017-04-19 18:20:13 · 398 阅读 · 0 评论 -
线程安全性
线程或者锁在并发编程中的作用就像铆钉和工字梁在土木工程中的作用。所以在构建稳健的并发程序时,必须正确地使用线程和锁。 要编写线程安全的代码,其核心在于要对状态访问操作进行管理,特别是对共享的和可变的状态的访问。原创 2016-12-14 11:40:24 · 232 阅读 · 0 评论 -
JAVA多线程实现的三种方式
春节还未结束,业务请求还处于高峰期,于是暴露了请求过多、响应时间过长的问题。针对这种问题的优化,揪其原因,在于处理业务请求是单线程处理,请求过多时,响应慢。将业务处理代码改为多线程处理,即解决了问题。 今天浅谈下java多线程的几种实现方式。 JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future原创 2017-02-06 16:19:00 · 320 阅读 · 0 评论 -
Java线程面试题 Top 50
不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题。Java语言一个重要的特点就是内置了对并发的支持,让Java大受企业和程序员的欢迎。大多数待遇丰厚的Java开发职位都要求开发者精通多线程技术并且有丰富的Java程序开发、调试、优化经验,所以线程相关的问题在面试中经常会被提到。 在典型的Java面试中, 面试官会从线程的基本概念问起, 如:为什么你需要使用线程, 如何创建线转载 2017-02-06 16:51:44 · 321 阅读 · 0 评论 -
浅谈volatile关键字
Java的volatile关键字在JDK源码中经常出现,但是对它的认识只是停留在共享变量上,今天来谈谈volatile关键字。volatile,从字面上说是易变的、不稳定的,事实上,也确实如此,这个关键字的作用就是告诉编译器,只要是被此关键字修饰的变量都是易变的、不稳定的。原创 2017-03-19 18:10:41 · 18656 阅读 · 9 评论 -
隐式锁 Synchronized 与显示锁 Lock的用法和简单对比
SynchronizedSynchronized是Java的关键字,当它用来修饰一个方法或一个代码块时,能够保证在同一时刻最多只有一个线程执行该代码。因为当调用Synchronized修饰的代码时,并不需要显示的加锁和解锁的过程,所以称之为隐式锁。Sychronized的用法:1、同步方法体,在方法声明中使用,如下:public synchronized void method(){原创 2017-03-12 19:56:58 · 5329 阅读 · 2 评论 -
浅谈CAS
CAS(Compare and Swap),比较并交换。 java语言中,多线程访问一个互斥的变量时,主要是通过synchronized或者lock锁来达到线程间同步的目的。虽然锁机制在使用合理的情况下可以保证线程安全,但是使用锁带来的性能问题是一个痛点。java5更新后,开发非阻塞算法成为可能,而CAS实现了区别于锁机制的对变量同步特性的一种技术。非阻塞算法 (nonblocking algor转载 2017-04-01 11:49:48 · 261 阅读 · 0 评论 -
浅谈java并发容器ConcurrentHashMap
我们知道concurrentHashMap是线程安全而且高效的HashMap,至于为什么,我们今天来一探究竟。HashMap与HashTable 在多线程的环境下使用HashMap进行put操作会使HashMap的Entry链表出现环形链表,从而在get操作时出现死循环,导致CPU利用率接近100%,看看这篇文章《疫苗:JAVA HASHMAP的死循环》,具体就不赘述了。HashTable虽然是线转载 2017-04-11 17:29:05 · 341 阅读 · 0 评论 -
浅谈Java线程池
Java中的线程池是日常工作中用的比较频繁的并发框架了,几乎所有需要并发执行的程序都可以使用线程池。那么,使用线程池的程序究竟有什么好处呢?答案无非就是以下两点。降低资源消耗。 通过重复利用已创建的线程,降低了频繁切换线程上下文(创建与销毁)所带来的资源消耗。提高了线程的可管理性。 线程是稀缺资源,如果无限制的创建,过多的消耗系统资源,可能会导致服务器崩溃。使用线程池可以进行统一的原创 2017-04-04 15:42:36 · 421 阅读 · 0 评论 -
浅谈ThreadLocal
今天将探讨下JDK源码中出现频次很高的关键字–ThreadLocal,线程本地变量。基本概念ThreadLocal类,究竟是干啥的,首先来看java官方文档的说明: 该类提供了线程局部 (thread-local) 变量。这些变量不同于它们的普通对应物,因为访问某个变量(通过其 get 或 set 方法)的每个线程都有自己的局部变量,它独立于变量的初始化副本。ThreadLocal 实例通常是类中原创 2017-04-13 16:05:03 · 242 阅读 · 0 评论 -
如何合理设置线程池大小
接着上一篇探讨线程池留下的尾巴,如何合理的设置线程池大小。 要想合理的配置线程池的大小,首先得分析任务的特性,可以从以下几个角度分析:任务的性质:CPU密集型任务、IO密集型任务、混合型任务。任务的优先级:高、中、低。任务的执行时间:长、中、短。任务的依赖性:是否依赖其他系统资源,如数据库连接等。性质不同的任务可以交给不同规模的线程池执行。对于不同性质的任务来说,CPU密集型任务应配置尽转载 2017-04-05 16:49:12 · 45479 阅读 · 7 评论 -
JVM探秘之运行时数据区
(图来自《深入理解java虚拟机》)1、程序计数器(Program Counter Register)可以比作当前线程所执行的字节码的行号指示器。每条线程都需要有一个独立的程序计数器,线程私有的内存。计数器记录的是正在执行的虚拟机字节码指令的地址;如果正在执行的是Native方法,这个计数器值就是空的。2、Java虚拟机栈(Java Virtual Machine Stacks)线程私有,原创 2017-04-19 17:57:00 · 247 阅读 · 0 评论 -
Java并发编程(五)-- ReentrantLock
锁是用来控制多个线程访问共享资源的方式,对共享资源加锁能够有效解决对资源的并发问题,比如在方法中或方法块中加synchronized关键字。在JDK5以后并发包中增加了Lock接口,用来实现锁功能。Lock提供了与Synchronized类似的同步功能,但是在使用时需要显示的获取和释放锁,故而Lock又称为“显示锁”,Synchronized则称“隐式锁”。Lock相对于Synchronized,...原创 2018-05-25 23:23:15 · 406 阅读 · 0 评论