E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
JAVA-并发编程
Java Redis客户端
Redis客户端
Java-
微型redis客户端工具资源名字资源Jar下载JavaDoc查看GitHub查看Gitee查看Maven1.build.grade|setting.graderepositories
RelinRan
·
2024-02-08 23:59
java
redis
开发语言
Java面试题2024(Java面试八股文)
文章目录基础SpringspringMybatis数据库Mysqlredis
并发编程
网络通信消息队列MQ分布式分布式事务设计模式更新中基础Java基础Java对象的创建集合HashMap详解HashMap
思静语
·
2024-02-08 20:17
Java面试总结
java
双非本科准备秋招(20.1)——
并发编程
之生产者消费者
生产者消费者与保护性暂停中的不同,不需要产生结果和消费结果的线程一一对应。生产者仅负责产生结果数据,不关心数据该如何处理,而消费者专心处理结果数据JDK中各种阻塞队列,采用的就是这种模式代码实现:首先,设计消息队列类MessageQueue,需要指定容量capacity,用双向链表list作为容器。提供take方法:检查list是否是空,空的话就wait,如果不空就打印Message,并唤醒所有线
随心自风流
·
2024-02-08 20:26
设计模式
java
开发语言
生产者消费者
并发编程
秋招
并发编程
中一种经典的分而治之的思想!!
写在前面在JDK中,提供了这样一种功能:它能够将复杂的逻辑拆分成一个个简单的逻辑来并行执行,待每个并行执行的逻辑执行完成后,再将各个结果进行汇总,得出最终的结果数据。有点像Hadoop中的MapReduce。ForkJoin是由JDK1.7之后提供的多线程并发处理框架。ForkJoin框架的基本思想是分而治之。什么是分而治之?分而治之就是将一个复杂的计算,按照设定的阈值分解成多个计算,然后将各个计
冰河团队
·
2024-02-08 19:06
Java并发系列学习(三)
Java生态圈中提供了非常丰富的
并发编程
类库,但是这样子也造就了非常多的人知其然而不知其所以然,很多人只会用,却不知其底层的运行机制,不知其优势与缺陷,也就无法将其融会贯通,做到信手拈来。
丑人林宗己
·
2024-02-08 18:37
并行和并发有什么区别?说一下 runnable 和 callable 有什么区别?线程有哪些状态?
并行和并发是计算机科学中两个相关但不同的概念,它们在多任务处理和
并发编程
中有着重要的区别。
weixin_53180424
·
2024-02-08 14:09
java
java
服务器
数据库
Java-
图片转base64及富文本中图片地址解析为base64并替换原字符串内容
项目场景:该功能是向第三方站点接口拉取的资源,拉取图片和富文本内容。1问题描述由于第三方的图片资源是返回的本地图片路径,拉取到自己服务器,图片和富文本内容的图片无法显示。12方案1-图片转换base64:首先通过后端访问获取到的图片地址进行base64转换一般处理图片跨域类问题都可使用base64方式,但是还需文件大小来判断是否会影响到性能``@Testpublicvoidtest()throws
Trank-Lw
·
2024-02-08 13:17
java
【Java八股面试系列】
并发编程
-进程与线程
目录进程线程线程和进程的区别Java线程和操作系统的线程的区别请简要描述一下进程和线程在Java中的关系,区别及优缺点?编辑编辑编辑并发和并行的区别为什么要使用多线程?线程的生命周期什么是线程上下文切换?sleep()方法和wait()方法对比为什么wait()方法不定义在Thread中?进程进程是程序的一次执行过程,是系统运行程序的基本单位,因此进程是动态的。系统运行一个程序即是一个进程从创建,
叮咚Zz
·
2024-02-08 13:43
java
面试
开发语言
进程与线程
Golang 并发 生产者消费者模式
Golang并发生产者消费者模式生产者-消费者模式能够带来的好处生产者消费者模式是一种常见的
并发编程
模式,用于解决生产者和消费者之间的数据传递和处理问题。
26857259
·
2024-02-08 11:19
Golang
golang
github
中间件
多线程
并发编程
9-ReentrantReadWriteLock源码剖析
前面文章说到了ReentrantLock,解决线程间安全问题,使用ReentrantLock就可以,但是ReentrantLock是独占锁,某一个时刻只能一个线程获取锁,在写少读多的场景下,显然ReentrantLock并不能满足次场景。今天要说的ReentrantReadWriteLock锁就能满足写少读多的场景。ReentrantReadWriteLock锁采用读写分离的策略,读锁是一个共享锁
Demo_zfs
·
2024-02-08 07:42
【2019-06-11】
并发编程
基本知识整理
1.同步和异步同步和异步通常用来形容一次方法的调用,同步方法调用一旦开始,调用者必须等到方法调用返回后,才能继续后续的行为;异步方法调用,会在另外一个线程中执行,调用者可以继续后续的操作,如果异步调用需要返回结果,那么在完成后通知调用者。2.并行和并发并行和并发是两个容易混淆的概念,并行是真正意义上的同时执行,并发则是多个任务交替执行,而他们之间则还是串行执行的。3.临界区临界区用来表示一种公共资
菜鸟开始飞
·
2024-02-08 07:21
如何在Python中多线程处理特定任务
多线程编程是一种
并发编程
技术,可以在单个程序中同时执行多个任务,提高程序的执行效率。在本文中,我们将介绍如何在Python中使用多线程处理特定任务。
厂里无人
·
2024-02-08 03:18
python
java
开发语言
【Go】三、Go
并发编程
并发编程
我们主流的
并发编程
思路一般有:多进程、多线程但这两种方式都需要操作系统介入,进入内核态,是十分大的时间开销由此而来,一个解决该需求的技术出现了:用户级线程,也叫做绿程、轻量级线程、协程python-asyncio
清河__
·
2024-02-08 02:20
Go
golang
开发语言
后端
请解释Java中的线程池是什么,以及为什么要使用线程池?
在Java中,线程池是一种
并发编程
的机制,它维护了一个线程队列,用于重用已创建的线程,以便在处理任务时减少线程的创建和销毁开销。
顶碗冷笑话
·
2024-02-08 02:45
java
java
开发语言
面试
改行学it
java-
判断字符串是否相等
对字符串对象比较不能简单的比较运算符“==”,因为比较运算符比较的是两个字符串的地址是否相同。即使字符串的内容相同,两个对象的内存地址也是不同的。因为字符串是对象,tom、bob是引用。因此要比较两个字符串内容是否相等,应该使用equals()方法和equalsIgnoreCase()方法。
逆风的妞妞
·
2024-02-07 20:00
jdk切换所需操作
2、设置环境变量JAVA6_HOME:D:\ProgramFiles\Java\jdk1.6.0_45JAVA_HOME:%JAVA6_HOME%image.png3、控制面板(查看方式‘大图标’):
Java
二枚目
·
2024-02-07 18:24
高
并发编程
基础-02-线程基础知识说明
引言现在几乎所有操作系统都支持多任务执行,其中每个任务被视为一个进程。在每个进程内部,至少有一个线程在运行,线程也被称为轻量级进程。线程可以看作是程序执行的一条路径,每个线程都有自己的局部变量表、程序计数器(指向当前正在执行的指令)以及各自的生命周期。现代操作系统通常支持同时运行多个线程。例如,在启动Java虚拟机(JVM)时,操作系统会创建一个新的进程(即JVM进程),并在该进程中生成多个派生或
c0detrend
·
2024-02-07 14:52
高并发编程
java
jvm
数据结构
高
并发编程
基础-引言
5W1H这里用“六何”的分析方法概括下即将开始的新主题高
并发编程
基础系列文章。what何事:高
并发编程
指同一时间进行大量任务的处理,同时保持过程稳定和结果一致。
c0detrend
·
2024-02-07 14:21
高并发编程
java
锁(一)java中的锁相关
《Java
并发编程
的艺术》-Java并发包中的读写锁及其实现分析|
并发编程
网–ifeve.com一、java.util.concurrent.Lock接口1、锁的简单介绍锁可以控制多个线程访问共享资源的方式
w_t_y_y
·
2024-02-07 13:07
多线程编程
安全
java
jvm
java多线程实现(四)java中的并发工具类
一、等待多线程完成的CountDownLatch二、同步屏障CyclicBarrier三、控制
并发编程
数的Semaphore四、线程间交换数据的Exchanger
w_t_y_y
·
2024-02-07 13:37
多线程编程
java
开发语言
【
Java-
框架-SpringSecurity】单点登录(认证和授权)- 随笔
项目文件;【1】预览文件文件01名称pom.xml;内容(01)总的4.0.0org.springframework.bootspring-boot-starter-parent2.5.9com.exampleSpringDemo0.0.1-SNAPSHOTSpringDemoDemoprojectforSpringBoot8org.springframework.bootspring-boot-
SUNxRUN
·
2024-02-07 11:43
java
spring
security
spring
【
并发编程
】手写线程池&阻塞队列
个人主页:五敷有你系列专栏:
并发编程
⛺️稳重求进,晒太阳示意图步骤1:自定义任务队列变量定义用Deque双端队列来承接任务用ReentrantLock来做锁并声明两个条件变量ConditionfullWaitSetemptyWaitSet
五敷有你
·
2024-02-07 11:01
并发编程
java
服务器
并发编程
线程池
光背面试题可没用,谈谈如何真正掌握一个技术知识点
1、第一次接触作为一个学习者,在学习过程中往往会遇到很多新概念,比如你在学习
并发编程
的时候,会遇到“锁”、“同步”、“CAS”等奇奇怪怪的概念,光看文字解释大部分人都是一
程序员黄小斜
·
2024-02-07 11:19
Golang学习路径
进阶阶段:
并发编程
:学习Go语言的并发模型和
并发编程
技术,如Goroutine、通道(Channel)、互斥锁等,掌握
并发编程
的基本原理和使用方法。
kioaaa
·
2024-02-07 07:24
golang
AQS与ReentrantLock
AbstractQueuedSynchronizer简称AQSJava
并发编程
核心在于java.concurrent.util包而juc当中的大多数同步器实现都是围绕着共同的基础行为,比如等待队列、条件队列
蒋斌文
·
2024-02-07 06:41
【并行编程框架】AsyncTool
AsyncTool快速入门1)导入依赖2)自定义Worker3)编排包装类Wrapper4)提交任务执行5)运行结果
并发编程
常见的场景串行并行阻塞等待-先串行,后并行阻塞等待-先并行,后串行AsyncToolAsyncTool
@lihewei
·
2024-02-07 06:14
java
架构
Go语言学习笔记-
并发编程
-共享内存并发机制
MutexWaitGroup类似java中的joinpackageshare_memimport("sync""testing""time")funcTestCounter(t*testing.T){counter:=0fori:=0;i<1000;i++{gofunc(){counter++}()}time.Sleep(2*time.Second)t.Logf("counter=%d",coun
noonenote
·
2024-02-07 06:23
并发编程
之:深入解析线程池
大家好,我是小黑,一个在互联网苟且偷生的农民工。本期带来线程池的第二期内容,如果对线程池的基本概念还不是很清楚,可以先看我上一篇文章。面试官:谈谈你对线程池的理解本期内容会从以下几个方面解析线程池的具体实现:线程池状态线程池初始化如何执行任务钩子方法等待队列和排队策略自定义拒绝策略线程池关闭动态调整容量合理配置容量线程池状态imageThreadPoolExecutor中定义了如下几种线程池状态:
小黑说Java
·
2024-02-07 02:48
python
并发编程
这一篇就够了
Python提供了多种
并发编程
的工具和库,让你能够更轻松地实现并发操作。以下是一些在Python中实现
并发编程
的常用方式:多线程编程:使用threading模块可以创建多个线程来并发执行任务。
卫玠_juncheng
·
2024-02-07 02:05
python
Python
并发编程
之join方法
frommultiprocessingimportProcessimporttimedeftask(name):print('%sisrunning'%name)time.sleep(3)print('%sisover'%name)if__name__=='__main__':#1.创建一个对象p=Process(target=task,args=('loky',))#2.开启进程p.start(
su小哲
·
2024-02-07 02:05
python
Python
并发编程
Python
并发编程
一、Python对
并发编程
的支持二、怎样选择多线程多进程多协程?1、什么是CPU密集型计算、IO密集型计算?2、多线程、多进程、多协程的对比3、怎样根据任务选择对应的技术?
fattt_
·
2024-02-07 02:04
Python
python
scala 系列之 19scala 的 actor
并发编程
23Actor
并发编程
模型23.1Actor概述为什么要学习actor?
海牛大数据_青牛老师
·
2024-02-07 01:05
JAVA-
构造方法和文件提取
文章目录构造器重载读取文件Student类publicclassStudent{privateStringname;privateintage;privatedoublegrade;publicStudent(){}publicStringgetName(){returnname;}publicvoidsetName(Stringname){this.name=name;}}publicclass
Les baleines tombent
·
2024-02-06 20:09
java
jvm
开发语言
JAVA-
类
文章目录类的构建类的构建packagecn.liuli.ex1;publicclassMain{publicstaticvoidmain(String[]args){Studentstudent=newStudent();student.name="chy";student.score=100;System.out.println(student.name+","+student.score);S
Les baleines tombent
·
2024-02-06 20:39
JAVA
java
jvm
开发语言
Java-
序列化-详解
什么是序列化和反序列化?如果我们需要持久化Java对象比如将Java对象保存在文件中,或者在网络传输Java对象,这些场景都需要用到序列化。简单来说:序列化:将数据结构或对象转换成二进制字节流的过程反序列化:将在序列化过程中所生成的二进制字节流转换成数据结构或者对象的过程对于Java这种面向对象编程语言来说,我们序列化的都是对象(Object)也就是实例化后的类(Class),但是在C++这种半面
无心六神通
·
2024-02-06 17:46
高级编程
java
开发语言
序列化
Java-
泛型-通配符-详解
通配符#什么是通配符?有什么作用?泛型类型是固定的,某些场景下使用起来不太灵活,于是,通配符就来了!通配符可以允许类型参数变化,用来解决泛型无法协变的问题。举个例子:#通配符?和常用的泛型T之间有什么区别?T可以用于声明变量或常量而?不行。T一般用于声明泛型类或方法,通配符?一般用于泛型方法的调用代码和形参。T在编译期会被擦除为限定类型或Object,通配符用于捕获具体类型。#什么是无界通配符?无
无心六神通
·
2024-02-06 17:16
高级编程
java
泛型
通配符
JVM内存模型
并发编程
模型中线程之间的通信机制有两种:共享内存和消息传递。java的并发采用的是共享内存模型(为什么java的并发采用共享内存模型呢?
土豆有点
·
2024-02-06 16:01
[转载]聊聊并发(一)——深入分析Volatile的实现原理
方腾飞---聊聊并发(一)——深入分析Volatile的实现原理引言在多线程
并发编程
中synchronized和Volatile都扮演着重要的角色,Volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的
胖瘦馒头
·
2024-02-06 14:57
python线程安全类型_通俗易懂:说说 Python 里的线程安全、原子操作
首发于微信公众号:Python编程时光在
并发编程
时,如果多个线程访问同一资源,我们需要保证访问的时候不会产生冲突,数据修改不会发生错误,这就是我们常说的线程安全。那什么情况下,访问数据时是安全的?
weixin_39847728
·
2024-02-06 08:00
python线程安全类型
多线程之线程安全与非线程安全
使用volatile关键字的场景案例七
并发编程
中的三个概念原子性、可见性
ddxshf
·
2024-02-06 08:24
后端
多线程
线程安全
synchronized
volatile
java-
SFTP文件上传下载
JSch-SFTP文件上传下载文章目录JSch-SFTP文件上传下载1.JSch简介2.ChannelSftp常用ApiJSch支持三种文件传输模式文件上传put()方法文件下载get()方法3.SFTP上传下载代码实现1.sftp工具pom依赖2.编写SFTP工具类3.测试【文件上传】4.测试【文件下载】4.SFTP监控传输进度4.1监控逻辑代码实现4.2上传进度监控【测试】4.3测试结果5.扩
@lihewei
·
2024-02-06 07:30
java
服务器
C#
并发编程
之二
1、指数退避策略Task.Delay方法:在指定时间结束后返回已完成的任务。//////指数退避策略(可增加重试之间的延迟间隔)。当在Web服务中采用这种策略时,可避免服务器被重试淹没。////////////asyncTaskDownloadStringWithRetries(HttpClientclient,stringurl){TimeSpannextDelay=TimeSpan.FromS
Lingoesforstudy
·
2024-02-06 07:51
c#
并发
并发编程
Java-
创建线程的三种方式
继承Thread1、定义一个类MyThread继承Thread,并重写run方法。2、将要执行的代码写在run方法中。3、创建该类的实例,并调用start()方法开启线程。publicclassTestThreadextendsThread{publicstaticvoidmain(String[]args){//3、创建该类的实例,并调用start()方法开启线程。MyThreadmyThrea
有腹肌的豌豆Z
·
2024-02-06 07:51
Java-
对象构造
重载java允许重载任何方法,因此,在描述一个方法时要指定方法名和参数类型,这种方法叫做签名,因为返回类型不是方法签名的一部分,所以不能有两个方法名和参数类型都相同但是返回类型却不同的方法举例说明add(int){returnint;}add(int,int){returnint;}//不可以这样使用add(int,int){returndouble;}默认初始化在构造器中如果没有显示的为变量设置
H_7835
·
2024-02-06 06:49
Java
并发编程
:线程间协作的两种方式:wait、notify、notifyAll和Condition
https://www.cnblogs.com/dolphin0520/p/3920385.html
博弈史密斯
·
2024-02-06 04:27
Go同步原语的基石
Go是一门以
并发编程
见长的语言,它提供了一系列的同步原语方便开发者使用,例如sync包下的Mutex、RWMutex、WaitGroup、Once、Cond,以及抽象层级更高的Channel。
机器铃砍菜刀s
·
2024-02-06 01:12
01-C++ “hello world”
写在前面接下来一段时间,我会重温一下C++,都说学习Java需要十年功力,学好C++需要一辈子,当然,程序员的鄙视链(汇编->C/C++->
java-
>python/js/php/OC),这也让C++开发凌驾于其他程序员
_东阁堂主_
·
2024-02-05 21:51
JAVA-
抽象类和普通类
概述在JAVA中,如果一个类用abstract关键字修饰,我们通常把它称为抽象类。类,我们可以把它理解为类型,现实中我们用类型描述具有共性的事物,例如生物,生物中有动物,动物中有狗。假如我们创建了一个生物类时,我们不能通过创建对象获取具体的狗的信息(种类,姓名等),像这种指向性更广泛的只描绘了多种事物公共属性的类,就是抽象类。而普通类就是具体的实例对象。JAVA中(abstract)抽象类案例如下
zyt.com
·
2024-02-05 21:34
java
开发语言
【
并发编程
】原子累加器
个人主页:五敷有你系列专栏:
并发编程
⛺️稳重求进,晒太阳JDK8之后有专门做累加的类,效率比自己做快数倍以上累加器性能比较参数是方法//supplier提供者无中生有()->结果//function函数一个参数一个结果
五敷有你
·
2024-02-05 20:09
并发编程
windows
C++
并发编程
:如何编写多线程代码
一、多线程概述1多线程的概念与优劣多线程是指在程序中同时运行多个线程,每个线程都可以独立执行不同的代码段,且各个线程之间共享程序的数据空间和资源。粉丝福利,免费领取C/C++开发学习资料包、技术视频/项目代码,1000道大厂面试题,内容包括(C++基础,网络编程,数据库,中间件,后端开发/音视频开发/Qt开发/游戏开发/Linuxn内核等进阶学习资料和最佳学习路线)↓↓↓↓↓↓见下面↓↓文章底部点
程序员老舅
·
2024-02-05 19:54
C++Linux后端
c++
服务器
后端开发
linux
C++多线程
C++线程池
高并发
上一页
1
2
3
4
5
6
7
8
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他