標籤:值拷貝 簡單 ref 代碼區 char 改變 常量 嚴格 拷貝
頭痛頭痛之一:
java裡面,本質上來說,一個類是一個程式員定義的類型,類是一種參考型別(reference type),這意味著該類類型的變數都可以引用該類的一個執行個體。從表面上,對象引用變數中似乎存放了一個對象,但事實上,它只是包含了對該對象的引用。嚴格來講,對象引用變數和對象是不同的,對象(new Person()),對象引用變數(Person p)。但大多數情況下,這種差異是可以忽略的。因此,可以簡單地說p是一個Person對象,而不用冗長地描述說,p是一個包含對Person對象引用的變數。-----java基礎篇P278
所以,Person p; p.a = 2; 這樣是不行的,因為這個時候p還沒指向任何記憶體。是null
所以需要Person p = new Person();
相反,C++直接 Person p; 即可調用p.a = 2;
頭痛頭痛之二:
java裡面的方法,
public void fuck(final StringBuilder str) { str.append("haha"); }
這樣的final只是說,不能改變str,也就是str不能指向其他地方,還是可以修改它指向的內容的。比如上面是ok的,會修改的
但是C++
void fun(const char * str)
就已經表明,str的內容是不可變的,至於指向,本來就是值拷貝,改變了對我影響不到的。只是在函數中臨時改變
再比如
void fun(char * const str) { str[0] = ‘0‘;}
指標常量,表明這個指標是一個常量,不可以再改變指向了,但是這個時候還是可以修改它指向的那塊記憶體的值的。
注意:這個時候那塊記憶體需要存在,如果你的是char * str = "liuweiming",這樣它一更改還是會報錯的,因為不能更改字串常量
字串常量儲存在代碼區
所以很大的區別就是final string str,表明的和const char * str不同
void fun(char * const str) { str[0] = ‘0‘;}
我想和你們說說java和C++