作者gn00618777 (非常念旧)
看板java
标题[问题] 关於一个 Thread safe的程式
时间Sat Jan 6 10:17:50 2018
板友早安
class Test{
public void test1()
{
int xx;
int 00;
..
..
}
public static void test2()
{
int xx;
int 00;
..
..
}
}
我们都知道一个 thread safe 的程式都是尽量宣告local不要static
第一个method假设有两条 thread,运行的变数都存在自己thread的记忆体。
那第二个method呢? 他是属於 class 的 method 不是物件的,但里面又是区域变数
假设有两个物件,同时呼叫static的method,里面是区域变数,是各自属於thread的
记忆体吗? 还是因为是static的,所有都是同属记忆体,里面的运算内容会影响到呢?
谢谢指教
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 119.14.189.37
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/java/M.1515205074.A.975.html
1F:推 mars90226: 变数就是看变数的生命周期,跟他所在的method无关 01/06 10:39
2F:→ ssccg: static跟thread-safe没关系... 01/06 15:30
3F:→ ssccg: method里的local变数都在stack上,不管是不是static method 01/06 15:31
4F:→ ssccg: static只影响执行method时的context是static还是有this 01/06 15:32
5F:→ ssccg: 如果是class变数的话,不管是static还是instance都在heap 01/06 15:33
6F:→ ssccg: 都有可能被别的thread存取的,所以static根本就无关 01/06 15:33
7F:→ ssccg: 当然以上是指primitive变数,如果是reference变数,只要能 01/06 15:34
8F:→ ssccg: 取得reference就能改,即使一开始是local也是能把reference 01/06 15:34
9F:→ ssccg: 传到别的地方 01/06 15:34
10F:→ ssccg: 修正一下,能取得reference就能改reference到的物件,原变 01/06 15:36
11F:→ ssccg: 数当然还是local就local 01/06 15:36
12F:→ gn00618777: 我资工白读==,刚刚恶补了一下 stack 和 heap 的差别 01/06 17:26
13F:→ gn00618777: static 会有可能有多条 thread 存取,那...这样会影响 01/06 17:27
14F:→ gn00618777: method 里面 xxoo的运算吗? 01/06 17:27
15F:→ gn00618777: 比如说假设我thread1要印出 oo ,然後 thread2刚好初 01/06 17:35
16F:→ gn00618777: 始化。会不会有可能印出初始化的值呢 01/06 17:36
18F:→ gn00618777: 以上连结内容跟S大奖的满类似的 01/06 18:50
20F:→ ssccg: 你要先知道最基本的一件事,java的每个thread有自己的stack 01/06 22:52
21F:→ ssccg: 所以不同thread呼叫同一个method时,只共用程式码,不会共 01/06 22:53
22F:→ ssccg: 用任何local变数,不管method是不是static 01/06 22:53
23F:→ ssccg: 不知道你的static会被多thread存取这观念是哪个语言来的但 01/06 22:54
24F:→ ssccg: 在java(或说jvm环境下)static跟这件事没关系 01/06 22:54
25F:→ gn00618777: 了解了,感谢你们的指教 :) 01/07 09:58
26F:→ gn00618777: 我的意思是一个 class 宣告 static 方法,然後用此 01/07 09:59
27F:→ gn00618777: class 宣告的物件,都是用同一个static方法,所以常 01/07 10:00
28F:→ gn00618777: 有可能多条 thread 存取到此方法的情况 01/07 10:01
29F:→ gn00618777: p大,感谢你的连结。从上面回答来看意思是说 01/07 10:25
30F:→ gn00618777: Test t = new Test(), t代表一个物件参考,是存在 01/07 10:26
31F:→ gn00618777: stack上的,而new Test()是存在 shared的heap上。 01/07 10:28
32F:→ gn00618777: 所以,当相同object物件被呼叫时,被参考的物件就有 01/07 10:33
33F:→ gn00618777: 同步的问题,不知道这样理解对不对呢 01/07 10:33
34F:→ ssccg: Test t = new Test()如果是在method里面(不管是不是static) 01/07 15:05
35F:→ ssccg: 只要没有把t传(复制)到会被别的thread存取的地方就没问题 01/07 15:07
36F:→ ssccg: Test t = new Test()如果是个class的static变数或instance 01/07 15:07
37F:→ ssccg: 变数,因为透过同个object或class能存取,较可能有同步问题 01/07 15:08
38F:→ ssccg: 结论还是跟static没有关系 01/07 15:09
39F:→ ssccg: "用此class宣告的物件,都是用同一个static方法"<这有点错 01/07 15:10
40F:→ ssccg: 方法的程式码本来就只有一份,跟是否static、从哪呼叫无关 01/07 15:11
41F:→ ssccg: 同步问题是看会不会同时存取同一份资料(变数),方法没差 01/07 15:16
42F:→ gn00618777: 好的 谢谢s大 01/07 22:31