Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
touzizhuo03
Dubbo
提交
1f13da57
D
Dubbo
项目概览
touzizhuo03
/
Dubbo
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Dubbo
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
1f13da57
编写于
4月 02, 2018
作者:
Y
YunaiV
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
美滋滋
标记这个类,看完了
上级
4c90f914
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
41 addition
and
20 deletion
+41
-20
dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/buffer/ChannelBuffers.java
...ava/com/alibaba/dubbo/remoting/buffer/ChannelBuffers.java
+11
-0
dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/buffer/DynamicChannelBuffer.java
...m/alibaba/dubbo/remoting/buffer/DynamicChannelBuffer.java
+30
-20
未找到文件。
dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/buffer/ChannelBuffers.java
浏览文件 @
1f13da57
...
...
@@ -19,6 +19,9 @@ package com.alibaba.dubbo.remoting.buffer;
import
java.nio.ByteBuffer
;
/**
* Buffer 工具类
*/
public
final
class
ChannelBuffers
{
public
static
final
ChannelBuffer
EMPTY_BUFFER
=
new
HeapChannelBuffer
(
0
);
...
...
@@ -26,19 +29,23 @@ public final class ChannelBuffers {
private
ChannelBuffers
()
{
}
// DynamicChannelBuffer ,实际是 HeapChannelBuffer
public
static
ChannelBuffer
dynamicBuffer
()
{
return
dynamicBuffer
(
256
);
}
// DynamicChannelBuffer ,实际是 HeapChannelBuffer
public
static
ChannelBuffer
dynamicBuffer
(
int
capacity
)
{
return
new
DynamicChannelBuffer
(
capacity
);
}
// DynamicChannelBuffer ,实际是 HeapChannelBuffer
public
static
ChannelBuffer
dynamicBuffer
(
int
capacity
,
ChannelBufferFactory
factory
)
{
return
new
DynamicChannelBuffer
(
capacity
,
factory
);
}
// HeapChannelBuffer
public
static
ChannelBuffer
buffer
(
int
capacity
)
{
if
(
capacity
<
0
)
{
throw
new
IllegalArgumentException
(
"capacity can not be negative"
);
...
...
@@ -49,6 +56,7 @@ public final class ChannelBuffers {
return
new
HeapChannelBuffer
(
capacity
);
}
// HeapChannelBuffer
public
static
ChannelBuffer
wrappedBuffer
(
byte
[]
array
,
int
offset
,
int
length
)
{
if
(
array
==
null
)
{
throw
new
NullPointerException
(
"array == null"
);
...
...
@@ -58,6 +66,7 @@ public final class ChannelBuffers {
return
wrappedBuffer
(
dest
);
}
// HeapChannelBuffer
public
static
ChannelBuffer
wrappedBuffer
(
byte
[]
array
)
{
if
(
array
==
null
)
{
throw
new
NullPointerException
(
"array == null"
);
...
...
@@ -68,6 +77,7 @@ public final class ChannelBuffers {
return
new
HeapChannelBuffer
(
array
);
}
// HeapChannelBuffer || ByteBufferBackedChannelBuffer
public
static
ChannelBuffer
wrappedBuffer
(
ByteBuffer
buffer
)
{
if
(!
buffer
.
hasRemaining
())
{
return
EMPTY_BUFFER
;
...
...
@@ -79,6 +89,7 @@ public final class ChannelBuffers {
}
}
// ByteBufferBackedChannelBuffer
public
static
ChannelBuffer
directBuffer
(
int
capacity
)
{
if
(
capacity
==
0
)
{
return
EMPTY_BUFFER
;
...
...
dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/buffer/DynamicChannelBuffer.java
浏览文件 @
1f13da57
...
...
@@ -22,14 +22,22 @@ import java.io.InputStream;
import
java.io.OutputStream
;
import
java.nio.ByteBuffer
;
/**
* 动态的 ChannelBuffer 实现类
*/
public
class
DynamicChannelBuffer
extends
AbstractChannelBuffer
{
/**
* 工厂
*/
private
final
ChannelBufferFactory
factory
;
/**
* Buffer
*/
private
ChannelBuffer
buffer
;
public
DynamicChannelBuffer
(
int
estimatedLength
)
{
this
(
estimatedLength
,
HeapChannelBufferFactory
.
getInstance
());
this
(
estimatedLength
,
HeapChannelBufferFactory
.
getInstance
());
// 默认 HeapChannelBufferFactory
}
public
DynamicChannelBuffer
(
int
estimatedLength
,
ChannelBufferFactory
factory
)
{
...
...
@@ -39,7 +47,9 @@ public class DynamicChannelBuffer extends AbstractChannelBuffer {
if
(
factory
==
null
)
{
throw
new
NullPointerException
(
"factory"
);
}
// 设置 `factory`
this
.
factory
=
factory
;
// 创建 `buffer`
buffer
=
factory
.
getBuffer
(
estimatedLength
);
}
...
...
@@ -65,12 +75,12 @@ public class DynamicChannelBuffer extends AbstractChannelBuffer {
buffer
=
newBuffer
;
}
@Override
public
int
capacity
()
{
return
buffer
.
capacity
();
}
@Override
public
ChannelBuffer
copy
(
int
index
,
int
length
)
{
DynamicChannelBuffer
copiedBuffer
=
new
DynamicChannelBuffer
(
Math
.
max
(
length
,
64
),
factory
());
copiedBuffer
.
buffer
=
buffer
.
copy
(
index
,
length
);
...
...
@@ -78,67 +88,67 @@ public class DynamicChannelBuffer extends AbstractChannelBuffer {
return
copiedBuffer
;
}
@Override
public
ChannelBufferFactory
factory
()
{
return
factory
;
}
@Override
public
byte
getByte
(
int
index
)
{
return
buffer
.
getByte
(
index
);
}
@Override
public
void
getBytes
(
int
index
,
byte
[]
dst
,
int
dstIndex
,
int
length
)
{
buffer
.
getBytes
(
index
,
dst
,
dstIndex
,
length
);
}
@Override
public
void
getBytes
(
int
index
,
ByteBuffer
dst
)
{
buffer
.
getBytes
(
index
,
dst
);
}
@Override
public
void
getBytes
(
int
index
,
ChannelBuffer
dst
,
int
dstIndex
,
int
length
)
{
buffer
.
getBytes
(
index
,
dst
,
dstIndex
,
length
);
}
@Override
public
void
getBytes
(
int
index
,
OutputStream
dst
,
int
length
)
throws
IOException
{
buffer
.
getBytes
(
index
,
dst
,
length
);
}
@Override
public
boolean
isDirect
()
{
return
buffer
.
isDirect
();
}
@Override
public
void
setByte
(
int
index
,
int
value
)
{
buffer
.
setByte
(
index
,
value
);
}
@Override
public
void
setBytes
(
int
index
,
byte
[]
src
,
int
srcIndex
,
int
length
)
{
buffer
.
setBytes
(
index
,
src
,
srcIndex
,
length
);
}
@Override
public
void
setBytes
(
int
index
,
ByteBuffer
src
)
{
buffer
.
setBytes
(
index
,
src
);
}
@Override
public
void
setBytes
(
int
index
,
ChannelBuffer
src
,
int
srcIndex
,
int
length
)
{
buffer
.
setBytes
(
index
,
src
,
srcIndex
,
length
);
}
@Override
public
int
setBytes
(
int
index
,
InputStream
src
,
int
length
)
throws
IOException
{
return
buffer
.
setBytes
(
index
,
src
,
length
);
}
@Override
public
ByteBuffer
toByteBuffer
(
int
index
,
int
length
)
{
return
buffer
.
toByteBuffer
(
index
,
length
);
}
...
...
@@ -173,17 +183,17 @@ public class DynamicChannelBuffer extends AbstractChannelBuffer {
return
super
.
writeBytes
(
in
,
length
);
}
@Override
public
byte
[]
array
()
{
return
buffer
.
array
();
}
@Override
public
boolean
hasArray
()
{
return
buffer
.
hasArray
();
}
@Override
public
int
arrayOffset
()
{
return
buffer
.
arrayOffset
();
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录