- 我们先来看一个问题:有两个线程,子线程先执行10次,然后主线程执行5次,然后再切换到子线程执行10,再主线程执行5次……如此往返执行50次。看完这个问题,很明显要用到线程间的通信了, 先分析一下思路:首先肯定要有两个线程,然后每个线程中肯定有个50次的循环,因为每个线程都要往返执行任务50次,主线程的任务是执行5次,子线程的任务是执行10次。线程间通信技术主要用到 wait() 方法和 no... 我们先来看一个问题:有两个线程,子线程先执行10次,然后主线程执行5次,然后再切换到子线程执行10,再主线程执行5次……如此往返执行50次。看完这个问题,很明显要用到线程间的通信了, 先分析一下思路:首先肯定要有两个线程,然后每个线程中肯定有个50次的循环,因为每个线程都要往返执行任务50次,主线程的任务是执行5次,子线程的任务是执行10次。线程间通信技术主要用到 wait() 方法和 no...
- 我们知道,使用 synchronized 关键字可以有效的解决线程同步问题,但是如果不恰当的使用 synchronized 关键字的话也会出问题,即我们所说的死锁。死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。我们先写一个死锁的例子,再来分析一下死锁产生的原因:public class DeadLock {... 我们知道,使用 synchronized 关键字可以有效的解决线程同步问题,但是如果不恰当的使用 synchronized 关键字的话也会出问题,即我们所说的死锁。死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。我们先写一个死锁的例子,再来分析一下死锁产生的原因:public class DeadLock {...
- 传统线程技术中有个定时器,定时器的类是 Timer,我们使用定时器的目的就是给它安排任务,让它在指定的时间完成任务。所以先来看一下 Timer 类中的方法(主要看常用的 TimerTask() 方法):返回值方法名方法描述voidschedule(TimerTasktask,longdelay)安排在指定延迟后执行指定的任务。voidschedule(TimerTasktask,longde... 传统线程技术中有个定时器,定时器的类是 Timer,我们使用定时器的目的就是给它安排任务,让它在指定的时间完成任务。所以先来看一下 Timer 类中的方法(主要看常用的 TimerTask() 方法):返回值方法名方法描述voidschedule(TimerTasktask,longdelay)安排在指定延迟后执行指定的任务。voidschedule(TimerTasktask,longde...
- 提到虚拟化技术,我们首先想到的一定是 Docker,经过四年的快速发展 Docker 已经成为了很多公司的标配,也不再是一个只能在开发阶段使用的玩具了。作为在生产环境中广泛应用的产品,Docker 有着非常成熟的社区以及大量的使用者,代码库中的内容也变得非常庞大。同样,由于项目的发展、功能的拆分以及各种奇怪的改名 PR,让我们再次理解 Docker 的的整体架构变得更加困难。虽然 Docke... 提到虚拟化技术,我们首先想到的一定是 Docker,经过四年的快速发展 Docker 已经成为了很多公司的标配,也不再是一个只能在开发阶段使用的玩具了。作为在生产环境中广泛应用的产品,Docker 有着非常成熟的社区以及大量的使用者,代码库中的内容也变得非常庞大。同样,由于项目的发展、功能的拆分以及各种奇怪的改名 PR,让我们再次理解 Docker 的的整体架构变得更加困难。虽然 Docke...
- arthas是有阿里巴巴开源的Java故障诊断的工具,它采用shell模式的交互,提供丰富的自动补全功能。 arthas是有阿里巴巴开源的Java故障诊断的工具,它采用shell模式的交互,提供丰富的自动补全功能。
- Android内存管理包含两部分,一部分是Framework对内存的管理,一部分是Linux内核对内存管理,这两部分共同决定应用程序的生命周期 Android内存管理包含两部分,一部分是Framework对内存的管理,一部分是Linux内核对内存管理,这两部分共同决定应用程序的生命周期
- 新乡市先臣振动机械有限公司是一家生产各种不锈钢振动筛的厂家,产品含有摇摆筛、超声波振动筛、回旋筛、旋振筛、高频筛、强制筛等,想要了解相关产品信息可以关注我们的官网或者打电话,我们竭诚为您服务! 新乡市先臣振动机械有限公司是一家生产各种不锈钢振动筛的厂家,产品含有摇摆筛、超声波振动筛、回旋筛、旋振筛、高频筛、强制筛等,想要了解相关产品信息可以关注我们的官网或者打电话,我们竭诚为您服务!
- 从 Memcached1.5 开始,实现了一个改良的 LRU 算法,也叫做分段 LRU(Segmented LRU)算法,新算法主要是为了更好的利用内容,并提升性能。包括了二个重要的线程,本文先讲解 maintainer 线程,后一篇讲解 crawler 线程。每个 Slab-class 有一个 LRU,每个 LRU 又由四个子 LRU 组成,每个子 LRU 维护独立的锁(mutex loc... 从 Memcached1.5 开始,实现了一个改良的 LRU 算法,也叫做分段 LRU(Segmented LRU)算法,新算法主要是为了更好的利用内容,并提升性能。包括了二个重要的线程,本文先讲解 maintainer 线程,后一篇讲解 crawler 线程。每个 Slab-class 有一个 LRU,每个 LRU 又由四个子 LRU 组成,每个子 LRU 维护独立的锁(mutex loc...
- 31.1 JAVA程序运行的内存分析栈: 1. 每个线程私有,不能实现线程间的共享! 2. 局部变量放置于栈中。 3. 栈是由系统自动分配,速度快!栈是一个连续的内存空间!堆: 1. 放置new出来的对象! 2. 堆是一个不连续的内存空间,分配灵活,速度慢!方法区(也是堆): 1. 被所有线程共享! 2. 用... 31.1 JAVA程序运行的内存分析栈: 1. 每个线程私有,不能实现线程间的共享! 2. 局部变量放置于栈中。 3. 栈是由系统自动分配,速度快!栈是一个连续的内存空间!堆: 1. 放置new出来的对象! 2. 堆是一个不连续的内存空间,分配灵活,速度慢!方法区(也是堆): 1. 被所有线程共享! 2. 用...
- 文件子系统中的高层内核算法引用管理高速缓冲的算法。当它们试图检索一个块时,由高层算法决定它们想要存取的逻辑设备号和块号。举例来说,正如在第4章将要看到的那样,如果一个进程想要从一个文件中读数据,则内核需判定哪一个文件系统包含该文件,以及该文件系统中的哪一块包含该数据。当要从一个特定的磁盘块上读数据时,内核检查是否该块在缓冲区池中。如果不在,则分配给它一个空闲缓冲区。当要把数据写到一个特定磁盘... 文件子系统中的高层内核算法引用管理高速缓冲的算法。当它们试图检索一个块时,由高层算法决定它们想要存取的逻辑设备号和块号。举例来说,正如在第4章将要看到的那样,如果一个进程想要从一个文件中读数据,则内核需判定哪一个文件系统包含该文件,以及该文件系统中的哪一块包含该数据。当要从一个特定的磁盘块上读数据时,内核检查是否该块在缓冲区池中。如果不在,则分配给它一个空闲缓冲区。当要把数据写到一个特定磁盘...
- 本书摘自《基于Kubernetes的容器云平台实战》——书中的第1章,第1.4.2节作者是陆平、左奇、付光、张晗、赵培、单良 本书摘自《基于Kubernetes的容器云平台实战》——书中的第1章,第1.4.2节作者是陆平、左奇、付光、张晗、赵培、单良
- nginx unit服务非正常关闭后,出现bind(6, unix:control.unit.sock) failed (98: Address already in use)异常错误提示,且无法启动服务的问题处理 nginx unit服务非正常关闭后,出现bind(6, unix:control.unit.sock) failed (98: Address already in use)异常错误提示,且无法启动服务的问题处理
- 众所周知,现在的服务器可以处理多个socket连接,背后并发的实现主要有两种途径。多线程同步阻塞I/O多路复用socket的建立聊到socket,就不得不提到socket的建立的流程。祭出经典的老图:服务器依次使用socket,bind,listen之后就会监听对应的地址,此时accept会一直阻塞直到有连接建立,如果客户端和服务器建立了连接,那么accept就会返回一个连接句柄,可以对连接... 众所周知,现在的服务器可以处理多个socket连接,背后并发的实现主要有两种途径。多线程同步阻塞I/O多路复用socket的建立聊到socket,就不得不提到socket的建立的流程。祭出经典的老图:服务器依次使用socket,bind,listen之后就会监听对应的地址,此时accept会一直阻塞直到有连接建立,如果客户端和服务器建立了连接,那么accept就会返回一个连接句柄,可以对连接...
- 一、现象接到客户的电话,说自己的云服务器被提供商禁止访问了,原因是监测到网络流量暴满,服务器不停的向外发包,在确认客户没有业务量突增的情况下,初步判断可能服务器遭受了流量攻&击(DDOS),不过按照常理来说,客户的业务系统就是一个小的web系统,平时流量不大,影响力也一般,不至于遭受DDOs,带着这些疑问,要到了客户服务器的登录方式,废话少说,还是进入系统,一查究竟吧。点击此处有惊喜二、排查... 一、现象接到客户的电话,说自己的云服务器被提供商禁止访问了,原因是监测到网络流量暴满,服务器不停的向外发包,在确认客户没有业务量突增的情况下,初步判断可能服务器遭受了流量攻&击(DDOS),不过按照常理来说,客户的业务系统就是一个小的web系统,平时流量不大,影响力也一般,不至于遭受DDOs,带着这些疑问,要到了客户服务器的登录方式,废话少说,还是进入系统,一查究竟吧。点击此处有惊喜二、排查...
- 英文:Linoxide,编译:Linux中国/geekpilinux.cn/article-2352-1.htmlLinux中的top命令显示系统上正在运行的进程。它是系统管理员最重要的工具之一。被广泛用于监视服务器的负载。在本篇中,我们会探索top命令的细节。top命令是一个交互命令。在运行top的时候还可以运行很多命令。我们也会探索这些命令。(译注:不同发行版的top命令在各种细节有不同,如果 英文:Linoxide,编译:Linux中国/geekpilinux.cn/article-2352-1.htmlLinux中的top命令显示系统上正在运行的进程。它是系统管理员最重要的工具之一。被广泛用于监视服务器的负载。在本篇中,我们会探索top命令的细节。top命令是一个交互命令。在运行top的时候还可以运行很多命令。我们也会探索这些命令。(译注:不同发行版的top命令在各种细节有不同,如果
上滑加载中
推荐直播
-
HDC深度解读系列 - Serverless与MCP融合创新,构建AI应用全新智能中枢2025/08/20 周三 16:30-18:00
张昆鹏 HCDG北京核心组代表
HDC2025期间,华为云展示了Serverless与MCP融合创新的解决方案,本期访谈直播,由华为云开发者专家(HCDE)兼华为云开发者社区组织HCDG北京核心组代表张鹏先生主持,华为云PaaS服务产品部 Serverless总监Ewen为大家深度解读华为云Serverless与MCP如何融合构建AI应用全新智能中枢
回顾中 -
关于RISC-V生态发展的思考2025/09/02 周二 17:00-18:00
中国科学院计算技术研究所副所长包云岗教授
中科院包云岗老师将在本次直播中,探讨处理器生态的关键要素及其联系,分享过去几年推动RISC-V生态建设实践过程中的经验与教训。
回顾中 -
一键搞定华为云万级资源,3步轻松管理企业成本2025/09/09 周二 15:00-16:00
阿言 华为云交易产品经理
本直播重点介绍如何一键续费万级资源,3步轻松管理成本,帮助提升日常管理效率!
回顾中
热门标签