Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
武汉红喜
whatsmars
提交
077b654a
W
whatsmars
项目概览
武汉红喜
/
whatsmars
通知
3
Star
0
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
W
whatsmars
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
077b654a
编写于
8月 31, 2019
作者:
武汉红喜
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
concurrent test
上级
e18d67bf
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
82 addition
and
0 deletion
+82
-0
whatsmars-common/src/test/java/org/hongxi/java/util/concurrent/DaemonThreadTest.java
...ava/org/hongxi/java/util/concurrent/DaemonThreadTest.java
+16
-0
whatsmars-common/src/test/java/org/hongxi/java/util/concurrent/DeadLockTest2.java
...t/java/org/hongxi/java/util/concurrent/DeadLockTest2.java
+49
-0
whatsmars-common/src/test/java/org/hongxi/java/util/concurrent/ThreadLocalTest.java
...java/org/hongxi/java/util/concurrent/ThreadLocalTest.java
+17
-0
未找到文件。
whatsmars-common/src/test/java/org/hongxi/java/util/concurrent/DaemonThreadTest.java
0 → 100644
浏览文件 @
077b654a
package
org.hongxi.java.util.concurrent
;
/**
* Created by shenhongxi on 2019-08-31.
*/
public
class
DaemonThreadTest
{
public
static
void
main
(
String
[]
args
)
{
Thread
thread
=
new
Thread
(()
->
{
for
(;;)
{}
});
thread
.
setDaemon
(
true
);
thread
.
start
();
System
.
out
.
println
(
"main thread is over"
);
}
}
whatsmars-common/src/test/java/org/hongxi/java/util/concurrent/DeadLockTest2.java
0 → 100644
浏览文件 @
077b654a
package
org.hongxi.java.util.concurrent
;
/**
* Created by shenhongxi on 2019-08-31.
*/
public
class
DeadLockTest2
{
private
static
Object
resourceA
=
new
Object
();
private
static
Object
resourceB
=
new
Object
();
public
static
void
main
(
String
[]
args
)
{
Thread
threadA
=
new
Thread
(()
->
{
synchronized
(
resourceA
)
{
System
.
out
.
println
(
Thread
.
currentThread
()
+
" get ResourceA"
);
try
{
Thread
.
sleep
(
1000
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
System
.
out
.
println
(
Thread
.
currentThread
()
+
"waiting get ResourceB"
);
synchronized
(
resourceB
)
{
System
.
out
.
println
(
Thread
.
currentThread
()
+
" get ResourceB"
);
}
}
});
Thread
threadB
=
new
Thread
(()
->
{
synchronized
(
resourceB
)
{
System
.
out
.
println
(
Thread
.
currentThread
()
+
" get ResourceB"
);
try
{
Thread
.
sleep
(
1000
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
System
.
out
.
println
(
Thread
.
currentThread
()
+
"waiting get ResourceA"
);
synchronized
(
resourceA
)
{
System
.
out
.
println
(
Thread
.
currentThread
()
+
" get ResourceA"
);
}
}
});
threadA
.
start
();
threadB
.
start
();
}
}
whatsmars-common/src/test/java/org/hongxi/java/util/concurrent/ThreadLocalTest.java
0 → 100644
浏览文件 @
077b654a
package
org.hongxi.java.util.concurrent
;
/**
* Created by shenhongxi on 2019-08-31.
*/
public
class
ThreadLocalTest
{
static
ThreadLocal
<
String
>
threadLocal
=
new
InheritableThreadLocal
<>();
public
static
void
main
(
String
[]
args
)
{
threadLocal
.
set
(
"hello world"
);
new
Thread
(()
->
System
.
out
.
println
(
"thread:"
+
threadLocal
.
get
())).
start
();
System
.
out
.
println
(
"main:"
+
threadLocal
.
get
());
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录