Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
3b0afae3
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
3b0afae3
编写于
1月 08, 2018
作者:
Y
Yang Yu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add more comments
上级
bdc82956
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
19 addition
and
19 deletion
+19
-19
paddle/framework/details/cow_ptr.h
paddle/framework/details/cow_ptr.h
+19
-15
paddle/framework/details/cow_ptr_test.cc
paddle/framework/details/cow_ptr_test.cc
+0
-4
未找到文件。
paddle/framework/details/cow_ptr.h
浏览文件 @
3b0afae3
...
...
@@ -25,13 +25,14 @@ class ThreadUnsafeOwnershipFlags {
public:
ThreadUnsafeOwnershipFlags
(
bool
flag
)
:
flag_
(
flag
)
{}
ThreadUnsafeOwnershipFlags
(
const
ThreadUnsafeOwnershipFlags
&
o
)
=
delete
;
ThreadUnsafeOwnershipFlags
&
operator
=
(
const
ThreadUnsafeOwnershipFlags
&
o
)
=
delete
;
ThreadUnsafeOwnershipFlags
(
ThreadUnsafeOwnershipFlags
&&
o
)
=
default
;
ThreadUnsafeOwnershipFlags
(
const
ThreadUnsafeOwnershipFlags
&
o
ther
)
=
delete
;
ThreadUnsafeOwnershipFlags
&
operator
=
(
const
ThreadUnsafeOwnershipFlags
&
other
)
=
delete
;
ThreadUnsafeOwnershipFlags
(
ThreadUnsafeOwnershipFlags
&&
o
ther
)
=
default
;
void
SetOwnership
(
bool
flag
)
{
flag_
=
flag
;
}
// Invoke the callback if it is not owned.
template
<
typename
Callback
>
void
AcquireOwnershipOnce
(
Callback
acquire
)
{
if
(
!
flag_
)
{
...
...
@@ -44,7 +45,7 @@ class ThreadUnsafeOwnershipFlags {
bool
flag_
;
};
// Copy
On
Write pointer.
// Copy
-On-
Write pointer.
// It will hold a T* pointer, and only copy once when `MutableData` is invoked.
//
// The template parameter OwnershipFlags should have:
...
...
@@ -52,6 +53,8 @@ class ThreadUnsafeOwnershipFlags {
// * SetOwnership(bool flag).
// * AcquireOwnershipOnce(Callback). It will invoke the callback if it is not
// owned.
//
// https://en.wikipedia.org/wiki/Copy-on-write
template
<
typename
T
,
typename
OwnershipFlags
=
ThreadUnsafeOwnershipFlags
>
class
COWPtr
{
public:
...
...
@@ -59,33 +62,34 @@ class COWPtr {
explicit
COWPtr
(
T
*
ptr
)
:
payload_
(
ptr
),
ownership_
{
true
}
{}
// Move methods. Steal ownership from origin
COWPtr
(
COWPtr
&&
o
)
:
payload_
(
o
.
payload_
),
ownership_
{
std
::
move
(
o
.
ownership_
)}
{}
COWPtr
(
COWPtr
&&
o
ther
)
:
payload_
(
o
ther
.
payload_
),
ownership_
{
std
::
move
(
other
.
ownership_
)}
{}
COWPtr
&
operator
=
(
COWPtr
&&
origin
)
=
default
;
// Copy methods. Not own payload
COWPtr
(
const
COWPtr
&
o
)
:
payload_
(
o
.
payload_
),
ownership_
{
false
}
{}
COWPtr
&
operator
=
(
const
COWPtr
&
o
)
{
payload_
=
o
.
payload_
;
COWPtr
(
const
COWPtr
&
o
ther
)
:
payload_
(
other
.
payload_
),
ownership_
{
false
}
{}
COWPtr
&
operator
=
(
const
COWPtr
&
o
ther
)
{
payload_
=
o
ther
.
payload_
;
ownership_
.
SetOwnership
(
false
);
return
*
this
;
}
// Access read only data.
const
T
&
Data
()
const
{
return
*
payload_
;
}
// Access mutable data. If the data is not owned, the data will be copied
// before.
T
*
MutableData
()
{
ownership_
.
AcquireOwnershipOnce
(
[
this
]
{
payload_
.
reset
(
new
T
(
*
payload_
));
});
return
payload_
.
get
();
}
void
Reset
()
{
ownership_
.
AcquireOwnershipOnce
([
this
]
{
payload_
.
reset
();
});
payload_
.
reset
(
new
T
());
}
private:
// Actual data pointer.
std
::
shared_ptr
<
T
>
payload_
;
// Ownership flag.
OwnershipFlags
ownership_
;
};
...
...
paddle/framework/details/cow_ptr_test.cc
浏览文件 @
3b0afae3
...
...
@@ -28,10 +28,6 @@ TEST(COWPtr, all) {
*
ptr2
.
MutableData
()
=
10
;
ASSERT_EQ
(
ptr
.
Data
(),
0
);
ASSERT_EQ
(
ptr2
.
Data
(),
10
);
auto
ptr_before
=
ptr2
.
MutableData
();
ptr2
.
Reset
();
ASSERT_NE
(
ptr2
.
MutableData
(),
ptr_before
);
}
}
// namespace details
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录