自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

  • 博客(234)
  • 收藏
  • 关注

原创 公众号:徘徊笔记

公众号:徘徊笔记CSDN博客:https://blog.csdn.net/ph3636

2019-04-20 12:53:33 376

转载 Mysql的事务实现原理

来源:https://www.toutiao.com/a6777338939360412171/?wid=16191711471181 开篇相信大家都用过事务以及了解他的特点,如原子性(Atomicity),一致性(Consistency),隔离型(Isolation)以及持久性(Durability)等。今天想跟大家一起研究下事务内部到底是怎么实现的,在讲解前我想先抛出个问题:事务想要做到什么效果?按我理解,无非是要做到可靠性以及并发处理。可靠性:数据库要保证当insert..

2021-04-26 15:01:46 180

原创 Netty的Sharable注解

在学习一些使用到netty的框架进行网络交互时,经常能碰到管道添加处理器是如下(1,2)形式,有的是每次创建一个实例,有的却是共用一个实例呢?首先这块代码的作用是给管道添加处理器,每个线程对应一个管道,管道在初始化时会把这些处理器添加进来,当有网络交互时就会通过管道依次执行对应的处理器,所以这些处理器在某些情况下需要解决线程安全问题,由此可以得出能保证线程安全的处理器可以设置为单实例,反之则为多实例,但是就算该处理器可以保证线程安全,也得需要添加Sharable注解来明确含义,具体代码在往管道.

2021-04-26 14:59:35 303

原创 工具类之导出EXCEL和CSV

文件名注解,参数为文件名,可以选择增加日期后缀,作用在要导出是实体类上@Target(ElementType.TYPE)@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface FileName {​ // 前缀 String value();​ // 是否加日期后缀 boolean addDate() default false;​ // 日期后缀 String pattern() defaul

2021-04-26 14:58:46 351

原创 工具​类之分页和组装Map

分页工具类,一般请求参数会有第几页和每页大小,返回值也会把对应的参数传递回去,其他的参数还有数据的总页数和总数,这样使用方就可以更根据这两个参数判断出是否还有下一页以及显示多少页,集合数据代表这次请求所需要的数据,其他数据可以存储一些汇总信息。@Setter@Getterpublic class Pagination<T> implements Serializable {​ // 第几页 private int page; // 每页大小 private int

2021-03-10 15:34:25 242

原创 Java线程池任务处理以及异常恢复

一、任务处理:当在线程池中执行任务时,如何记录任务的开始结束时间?如何记录异常日志?如何对任务进行一些自定义处理?针对上面的问题,我们可以采用直接在任务中编码的形式,也可以利用ThreadPoolExecutor的模版方法进行实现,其实在使用线程池时,都需要重新构造线程池类,配置对应的参数,这样才能使它发挥应有的效果。如下图(1146行,1157行),线程池有任务前置后置方法,关于任务的一些处理可以通过这两个方法进行实现,首先就需要继承ThreadPoolExecutor...

2021-03-09 16:13:49 943

原创 基于Jackson的Json工具类

封装jackson框架,主要有把对象转为json字符串,把json字符串转为对象,把json字符串转为对象集合,把json字符串转为泛型对象(主要用于json转为map,list等),把json字符串转为未知类型对象(主要用于json转为某个方法的返回值类型)。public class JsonUtil { private static final Logger LOGGER = LoggerFactory.getLogger(JsonUtil.class); private sta

2020-09-03 16:36:02 437

原创 支持URI、方法、RPC的Mock平台

mock平台支持三种方式(URI、方法、RPC)URI:当前端需要根据接口的各种状态来进行不同的展示时,而后端还没有写完完整的代码时,可以在项目开发初期通过该方式进行自定义设置接口返回结果。方法:当后端需要某个方法返回某些特定的值时,而这时真实的情况又很难构造这个值时,就可以采用该方式。RPC:当后端要与别的服务进行合作时,而别的服务方接口提供较慢或有问题时,可以采用该方式进行自测。mock平台的数据存储可以是数据库或者其他平台等等,主要存储对应关系,key可以为UR...

2020-08-15 18:50:15 663

原创 leetcode-80-删除排序数组中的重复项 II

给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。示例 1:给定 nums = [1,1,1,2,2,3],函数应返回新长度 length = 5, 并且原数组的前五个元素被修改为 1, 1, 2, 2, 3 。...

2020-01-01 15:50:09 155

原创 leetcode-78-子集

给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。说明:解集不能包含重复的子集。示例:输入: nums = [1,2,3]输出:[ [3], [1], [2], [1,2,3], [1,3], [2,3], [1,2], []]迭代方式,首先结果只有一个空集合,...

2020-01-01 15:49:36 113

原创 开源框架的第一个Pull Request(seata)

seata是一个分布式事务框架。Pull Request俗称PR,也就是给开源框架提交的代码更改请求,一般需要先fork开源代码到自己的GitHub仓库,然后进行下载,在开发分支的基础上新建分支进行开发,开发完成后直接push,然后打开对应的自己的GitHub仓库代码,这时就会有对应的那个分支的提交请求按钮,点击填写具体更改内容提交即可,这时在开源框架的Pull Request中就会出现...

2019-12-18 18:55:39 199

原创 第一个开源框架的issue(RocketMQ)

之前在学习RocketMQ的时候发现了一个问题,客户端和broker之间关于topic的长度判断不一致,客户端发消息的判断为org.apache.rocketmq.client.Validators#checkTopic,这里的CHARACTER_MAX_LENGTH为255if (topic.length() > CHARACTER_MAX_LENGTH) { throw n...

2019-12-18 18:53:43 302

原创 leetcode-60-第k个排列

给出集合 [1,2,3,…,n],其所有元素共有 n! 种排列。按大小顺序列出所有排列情况,并一一标记,当 n = 3 时, 所有排列如下:"123""132""213""231""312""321"给定 n 和 k,返回第 k 个排列。说明:给定 n 的范围是 [1, 9]。给定 k 的范围是[1, n!]。示例 1:...

2019-11-16 14:03:56 131

原创 leetcode-77-组合

给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合。示例:输入: n = 4, k = 2输出:[ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4],]深度优先搜索DFS,每遍历一个数字就往集合中添加,当集合中的数字达到对应的k个时,就保存到结果集合中,直接...

2019-11-16 14:02:39 102

原创 leetcode-70-爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?注意:给定 n 是一个正整数。示例 1:输入:2输出:2解释:有两种方法可以爬到楼顶。1. 1 阶 + 1 阶2. 2 阶示例 2:输入:3输出:3解释:有三种方法可以爬到楼顶。1. ...

2019-11-16 14:02:08 97

原创 leetcode-69-x 的平方根

实现 int sqrt(int x) 函数。计算并返回 x 的平方根,其中 x 是非负整数。由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。示例 1:输入: 4输出: 2示例 2:输入: 8输出: 2说明: 8 的平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。直接用...

2019-11-16 14:00:53 191

原创 leetcode-67-二进制求和

给定两个二进制字符串,返回他们的和(用二进制表示)。输入为非空字符串且只包含数字 1 和 0。示例 1:输入: a = "11", b = "1"输出: "100"示例 2:输入: a = "1010", b = "1011"输出: "10101"从字符串尾部开始向前遍历,以最长的为准,超出长度的字符按0处理,对应的数字字符减去字...

2019-11-16 13:59:39 103

原创 leetcode-66-加一

给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。示例 1:输入: [1,2,3]输出: [1,2,4]解释: 输入数组表示数字 123。示例 2:输入: [4,3,2,1]输出: [4,3,2,2]解...

2019-11-16 13:58:26 109

原创 leetcode-64-最小路径和

给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。说明:每次只能向下或者向右移动一步。示例:输入:[ [1,3,1], [1,5,1], [4,2,1]]输出: 7解释: 因为路径 1→3→1→1→1 的总和最小。使用动态规划,从右下角开始,各个位置的最小路径权值存...

2019-11-16 13:57:57 104

原创 leetcode-61-旋转链表

给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数。示例 1:输入: 1->2->3->4->5->NULL, k = 2输出: 4->5->1->2->3->NULL解释:向右旋转 1 步: 5->1->2->3->4->NULL向右旋转 2 ...

2019-11-16 13:57:20 123

原创 leetcode-59-螺旋矩阵 II

给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵。示例:输入: 3输出:[[ 1, 2, 3 ],[ 8, 9, 4 ],[ 7, 6, 5 ]]最外层所有元素按照顺时针顺序输出,其次是次外层,假设当前层左上角坐标是(r1,c1),右下角坐标是(r2,c2),判断每一层是否有四层边(r...

2019-11-16 13:55:23 122

原创 leetcode-58-最后一个单词的长度

给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度。如果不存在最后一个单词,请返回 0 。说明:一个单词是指由字母组成,但不包含任何空格的字符串。示例:输入: "Hello World"输出: 5从字符串结尾开始遍历,遇到第一个非空字符说明已经遍历到最后一个单词的结尾,设置开始标志,统计长度,下一次遇到空字符说明已...

2019-11-04 11:04:04 83

原创 leetcode-56-合并区间

给出一个区间的集合,请合并所有重叠的区间。示例 1:输入: [[1,3],[2,6],[8,10],[15,18]]输出: [[1,6],[8,10],[15,18]]解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].示例 2:输入: [[1,4],[4,5]]输出: [[1,5]]解释: 区间 [1,4] 和 [4,5]...

2019-10-18 11:29:16 185

原创 leetcode-55-跳跃游戏

给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个位置。示例 1:输入: [2,3,1,1,4]输出: true解释: 从位置 0 到 1 跳 1 步, 然后跳 3 步到达最后一个位置。示例 2:输入: [3,2,1,0,4]输出: false解释: 无...

2019-10-18 11:28:11 194 1

原创 leetcode-54-螺旋矩阵

给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素。示例 1:输入:[[ 1, 2, 3 ],[ 4, 5, 6 ],[ 7, 8, 9 ]]输出: [1,2,3,6,9,8,7,4,5]示例 2:输入:[ [1, 2, 3, 4], [5, 6, 7, 8],...

2019-10-18 11:27:34 117

原创 leetcode-151-翻转字符串里的单词

给定一个字符串,逐个翻转字符串中的每个单词。示例 1:输入: "the sky is blue"输出: "blue is sky the"示例 2:输入: " hello world! "输出: "world! hello"解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。示例 3:输入: "a...

2019-10-18 11:26:55 91

原创 leetcode-53-最大子序和

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。示例:输入: [-2,1,-3,4,-1,2,1,-5,4],输出: 6解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。进阶:如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解。每往后移动一位,就取前面...

2019-10-18 11:26:21 68

原创 leetcode-48-旋转图像

给定一个 n × n 的二维矩阵表示一个图像。将图像顺时针旋转 90 度。说明:你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要使用另一个矩阵来旋转图像。示例 1:给定 matrix =[ [1,2,3], [4,5,6], [7,8,9]],原地旋转输入矩阵,使其变为:[ [7,4...

2019-10-18 11:25:49 74

原创 leetcode-47-全排列 II

给定一个可包含重复数字的序列,返回所有不重复的全排列。示例:输入: [1,1,2]输出:[ [1,1,2], [1,2,1], [2,1,1]]先给数组进行排序,递归的退出条件为遍历结束,也就是当前下标已经超过数组限制,把数组中的元素保存到结果中,每个元素都需要存在任何一个位置,不用额外的空间保存结果,直接交换数组元素来达到不同的排...

2019-10-18 11:25:14 73

原创 leetcode-46-全排列

给定一个没有重复数字的序列,返回其所有可能的全排列。示例:输入: [1,2,3]输出:[ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1]]递归的退出条件为遍历结束,也就是当前下标已经超过数组限制,把数组中的元素保存到结果中,每个元素都需要存在任何一个位置,不...

2019-10-12 18:21:43 84

原创 leetcode-45-跳跃游戏 II

给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。你的目标是使用最少的跳跃次数到达数组的最后一个位置。示例:输入: [2,3,1,1,4]输出: 2解释: 跳到最后一个位置的最小跳跃数是 2。 从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。说明...

2019-10-12 18:21:14 115

原创 leetcode-41-缺失的第一个正数

给定一个未排序的整数数组,找出其中没有出现的最小的正整数。示例 1:输入: [1,2,0]输出: 3示例 2:输入: [3,4,-1,1]输出: 2示例 3:输入: [7,8,9,11,12]输出: 1说明:你的算法的时间复杂度应为O(n),并且只能使用常数级别的空间。不能对数组进行排序,只能一次遍历,所以可...

2019-10-12 18:20:26 94

原创 leetcode-40-组合总和 II

给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。candidates 中的每个数字在每个组合中只能使用一次。说明:所有数字(包括目标数)都是正整数。解集不能包含重复的组合。示例 1:输入: candidates = [10,1,2,7,6,1,5], targ...

2019-09-09 10:10:14 93

原创 leetcode-39-组合总和

给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。candidates 中的数字可以无限制重复被选取。说明:所有数字(包括 target)都是正整数。解集不能包含重复的组合。示例 1:输入: candidates = [2,3,6,7], targe...

2019-09-09 10:09:32 127

原创 leetcode-35-搜索插入位置

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。你可以假设数组中无重复元素。示例 1:输入: [1,3,5,6], 5输出: 2示例 2:输入: [1,3,5,6], 2输出: 1示例 3:输入: [1,3,5,6], 7输出: 4示例 4:输...

2019-09-09 10:08:47 63

原创 leetcode-34-在排序数组中查找元素的第一个和最后一个位置

给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。你的算法时间复杂度必须是 O(log n) 级别。如果数组中不存在目标值,返回 [-1, -1]。示例 1:输入: nums = [5,7,7,8,8,10], target = 8输出: [3,4]示例 2:输入: nums ...

2019-09-09 10:08:01 105

原创 leetcode-33-搜索旋转排序数组

假设按照升序排序的数组在预先未知的某个点上进行了旋转。( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。搜索一个给定的目标值,如果数组中存在这个目标值,则返回它的索引,否则返回 -1 。你可以假设数组中不存在重复的元素。你的算法时间复杂度必须是 O(log n) 级别。示例 1:输入: nums...

2019-09-09 10:07:30 90

原创 leetcode-25-K 个一组翻转链表

给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表。k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。示例 :给定这个链表:1->2->3->4->5当 k = 2 时,应当返回: 2->1->4->3->5当 k ...

2019-09-09 10:06:59 86

原创 leetcode-24-两两交换链表中的节点

给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。示例:给定 1->2->3->4, 你应该返回 2->1->4->3.递归:因为要交换两个节点,所以当前节点或者当前节点的后继节点为空时就是递归的结束条件,取出当前节点的后继节点,让当前...

2019-09-07 20:11:31 139

原创 leetcode-23-合并K个排序链表

合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。示例:输入:[ 1->4->5, 1->3->4, 2->6]输出: 1->1->2->3->4->4->5->6采用分治法两两合并,链表数组有奇数或者偶数个,要平均分配,需要给它的数量进行加...

2019-09-07 20:10:47 76

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除