作者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/m.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