腾讯云
开发者社区
文档
建议反馈
控制台
登录/注册
首页
学习
活动
专区
工具
TVP
最新优惠活动
文章/答案/技术大牛
搜索
搜索
关闭
发布
首页
学习
活动
专区
工具
TVP
最新优惠活动
返回腾讯云官网
Coding Diary
与你分享我的学习笔记
专栏成员
举报
42
文章
49276
阅读量
12
订阅数
订阅专栏
申请加入专栏
全部文章(42)
java(19)
编程算法(15)
容器镜像服务(8)
容器(8)
api(7)
jdk(6)
自动驾驶(5)
网站(5)
http(5)
jvm(5)
node.js(3)
linux(3)
缓存(3)
socket编程(3)
erlang(2)
bootstrap(2)
react(2)
android(2)
数据库(2)
sql(2)
ide(2)
消息队列 CMQ 版(2)
企业(2)
存储(2)
面向对象编程(2)
hashmap(2)
tcp/ip(2)
udp(2)
rabbitmq(2)
数据分析(2)
kafka(2)
负载均衡(1)
c++(1)
javascript(1)
jsp(1)
xml(1)
unix(1)
ubuntu(1)
centos(1)
负载均衡缓存(1)
apache(1)
nginx(1)
SSL 证书(1)
网络安全(1)
安全(1)
数据结构(1)
mqtt(1)
搜索文章
搜索
搜索
关闭
Docker Compose集成式应用组合与服务编排
容器
容器镜像服务
编程算法
Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。其代码目前在 https://github.com/docker/compose 开源。
CodingDiray
2019-12-16
1.7K
0
JVM垃圾回收机制
java
企业
编程算法
Java 内存运行时区域中的程序计数器、虚拟机栈、本地方法栈随线程而生灭,栈中的栈帧随着方法的进入和退出而有条不紊地执行着出栈和入栈操作。每一个栈帧中分配多少内存基本上是在类结构确定下来时就已知的(尽管在运行期会由 JIT 编译器进行一些优化),因此这几个区域的内存分配和回收都具备确定性,不需要过多考虑回收的问题,因为方法结束或者线程结束时,内存自然就跟随着回收了。 而 Java 堆不一样,一个接口中的多个实现类需要的内存可能不一样,一个方法中的多个分支需要的内存也可能不一样,我们只有在程序处于运行期间时才能知道会创建哪些对象,这部分内存的分配和回收都是动态的,垃圾收集器所关注的是这部分内存。
CodingDiray
2019-10-14
441
0
Java网络编程--Netty中的ByteBuf
api
java
编程算法
由于JDK中提供的ByteBuffer无法动态扩容,并且API使用复杂等原因,Netty中提供了ByteBuf。
CodingDiray
2019-09-25
676
0
Java网络编程--Netty入门
java
react
自动驾驶
bootstrap
编程算法
Netty是一个高性能,高可扩展性的异步事件驱动的网络应用程序框架,它极大的简化了TCP和UDP客户端和服务器端网络开发。它是一个NIO框架,对Java NIO进行了良好的封装。作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机制,用户可以方便的主动获取或者通过通知机制获得IO操作结果。
CodingDiray
2019-09-25
529
0
Reactor模式
react
编程算法
java
android
自动驾驶
Reactor模式是一种设计模式,它是基于事件驱动的,可以并发的处理多个服务请求,当请求抵达后,依据多路复用策略,同步的派发这些请求至相关的请求处理程序。
CodingDiray
2019-09-25
2K
0
Java网络编程 -- AIO异步网络编程
javascript
node.js
linux
自动驾驶
编程算法
AIO中的A即Asynchronous,AIO即异步IO。它是异步非阻塞的,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理,一般我们的业务处理逻辑会变成一个回调函数,等待IO操作完成后,由系统自动触发。
CodingDiray
2019-09-25
909
0
Java网络编程--BIO阻塞式网络编程
http
java
编程算法
阻塞(blocking)IO :阻塞是指结果返回之前,线程会被挂起,函数只有在得到结果之后(或超时)才会返回
CodingDiray
2019-09-25
959
0
Fork/Join 框架及其使用
unix
编程算法
fork/join框架是ExecutorService接口的一种具体实现,会将任务分发给线程池中的工作线程,更好地利用多处理器带来的好处,提供程序性能。它是为那些能够被递归地拆解成子任务的工作类型量身设计的。
CodingDiray
2019-09-25
671
0
AQS解读及其实践
编程算法
AQS全称AbstractQueuedSynchronizer,即抽象队列同步器。AQS是用来构建锁或者其他同步组件的基础框架,它使用一个整型的volatile变量state来维护同步状态,通过内置的FIFO队列来完成资源获取线程的排队工作。AQS为一系列同步器依赖于一个单独的原子变量state的同步器提供了一个非常有用的基础。
CodingDiray
2019-09-25
558
0
JDK容器类Map源码解读
jdk
存储
hashmap
node.js
编程算法
java.util.Map接口是JDK1.2开始提供的一个基于键值对的散列表接口,其设计的初衷是为了替换JDK1.0中的java.util.Dictionary抽象类。Dictionary是JDK最初的键值对类,它不可以存储null作为key和value,目前这个类早已不被使用了。目前都是在使用Map接口,它是可以存储null值作为key和value,但Map的key是不可以重复的。其常用的实现类主要有HashMap,TreeMap,ConcurrentHashMap等
CodingDiray
2019-09-25
287
0
Java内存模型以及线程安全的可见性问题
java
编程算法
缓存
jvm
首先Java内存模型(JMM)和JVM运行时数据区并不是一个东西,许多介绍Java内存模型的文章描述的堆,方法区,Java虚拟机栈,本地方法栈,程序计数器这东西并不是Java内存模型的内容而是JVM运行时数据区的内容。 要理解二者的区别就要了解《Java虚拟机规范》和《Java语言规范》。我们知道Java虚拟机上并不知只有Java语言,像JRuby, ,Scala,Kotlin,Groovy等也都运行在Java虚拟机上,而这些语言想要在Java虚拟机上运行就要遵守《Java虚拟机规范》,而JVM运行时数据区就是《Java虚拟机规范》的内容。而《Java语言规范》就只是针对Java语言的规范,它对Java内存模型做了详细的描述。
CodingDiray
2019-09-25
876
0
Java中实现线程的方式
java
编程算法
api
jdk
面向对象编程
Java中实现多线程的方式的方式中最核心的就是 run()方法,不管何种方式其最终都是通过run()来运行。
CodingDiray
2019-09-25
457
0
线程的通信和封闭
java
api
编程算法
jdk
要想实现线程之间的协同, 如: 线程先后执行顺序, 获取某个线程的执行结果等, 涉及线程之间的相互通信, 分为下面四类
CodingDiray
2019-09-25
511
0
线程状态
java
编程算法
代码测试 第一种状态切换 - 新建 -> 运行 -> 终止 // 第一种状态切换 - 新建 -> 运行 -> 终止 System.out.println("#######第一种状态切换 - 新建 -> 运行 -> 终止################################"); Thread thread1 = new Thread( new Runnable() { @Override public void run() { System.out.println("thread1当前状态:" + Thread.currentThread().getState().toString()); System.out.println("thread1 执行了"); } }); System.out.println("没调用start方法,thread1当前状态:" + thread1.getState().toString()); thread1.start(); Thread.sleep(2000L); // 等待thread1执行结束,再看状态 System.out.println("等待两秒,再看thread1当前状态:" + thread1.getState().toString()); // thread1.start(); TODO 注意,线程终止之后,再进行调用,会抛出IllegalThreadStateException异常 输出结果: #######第一种状态切换 - 新建 -> 运行 -> 终止################################ 没调用start方法,thread1当前状态:NEW thread1当前状态:RUNNABLE thread1 执行了 等待两秒,再看thread1当前状态:TERMINATED 第二种:新建 -> 运行 -> 等待 -> 运行 -> 终止(sleep方式) System.out.println( "############第二种:新建 -> 运行 -> 等待 -> 运行 -> 终止(sleep方式)###########################"); Thread thread2 = new Thread( new Runnable() { @Override public void run() { try { // 将线程2移动到等待状态,1500后自动唤醒 Thread.sleep(1500); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("thread2当前状态:" + Thread.currentThread().getState().toString()); System.out.println("thread2 执行了"); } }); System.out.println("没调用start方法,thread2当前状态:" + thread2.getState().toString()); thread2.start(); System.out.println("调用start方法,thread2当前状态:" + thread2.getState().toString()); Thread.sleep(200L); // 等待200毫秒,再看状态 System.out.println("等待200毫秒,再看thread2当前状态:" + thread2.getState().toString()); Thread.sleep(3000L); // 再等待3秒,让thread2执行完毕,再看状态 System.out.println("等待3秒,再看thread2当前状态:" + thread2.getState().toString()); 输出结果: ############第二种:新建 -> 运行 -> 等待 -> 运行 -> 终止(sleep方式)########################### 没调用start方法,thread2当前状态:NEW 调用start方法,thread2当前状态:RUNNABLE 等待200毫秒,再看thread2当前状态:TIMED_WAITING thread2当前状态:RUNNABLE thread2 执行了 等待3秒,再看thread2当前状态:TERMINATED 第三种:新建 -> 运行 -> 阻塞 -> 运行 -> 终止 System.out.println("############第三种:新建 -> 运行 -> 阻塞 -> 运行 -> 终止#####################
CodingDiray
2019-09-25
790
0
Java程序运行原理分析
java
编程算法
线程独占: 每个线程都会有它独立的空间,随线程的生命周期而创建和销毁 线程共享: 所有线程都能访问这块内存数据,随虚拟机或GC而创建和销毁 方法区
CodingDiray
2019-09-25
1K
0
没有更多了
社区活动
【纪录片】中国数据库前世今生
穿越半个世纪,探寻中国数据库50年的发展历程
立即查看
Python精品学习库
代码在线跑,知识轻松学
立即查看
博客搬家 | 分享价值百万资源包
自行/邀约他人一键搬运博客,速成社区影响力并领取好礼
立即体验
技术创作特训营·精选知识专栏
往期视频·千货材料·成员作品 最新动态
立即查看
领券
问题归档
专栏文章
快讯文章归档
关键词归档
开发者手册归档
开发者手册 Section 归档