java創建子類對象設置并調用父類的變量操作
通過子類調用父類的變量,有兩種方法:
1、把父類的變量設置成public:package triangle.opengl.wlz.stu.childusefathervariable; import android.util.Log; public class BasePublicVariable { private String TAG = getClass().getName(); public int data; public void ptData(){ Log.d(TAG, 'ptData: ' + data); }}
當我們這樣做時,需要時直接在對象中設置這個變量的值就可以了,子類不需要任何處理:
package triangle.opengl.wlz.stu.childusefathervariable; import triangle.opengl.wlz.stu.childusefathervariable.BasePublicVariable; public class ChildPublicVariable extends BasePublicVariable { }2、通過構造方法透傳:
package triangle.opengl.wlz.stu.childusefathervariable; import android.util.Log; public class BaseVariableInConstructed { private String TAG = getClass().getName(); private int data; public BaseVariableInConstructed(int data){ this.data = data; } public void ptData(){ Log.d(TAG, 'ptData: ' + data); }}
這時,子類可以使用super方法,調用父類的構造方法:
package triangle.opengl.wlz.stu.childusefathervariable; import android.util.Log; public class ChildVaralbleInConstructed extends BaseVariableInConstructed { public ChildVaralbleInConstructed(int data) { super(data); }}
最終的使用方式:
package triangle.opengl.wlz.stu.childusefathervariable; import android.support.v7.app.AppCompatActivity;import android.os.Bundle; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); test(); } private void test(){ ChildVaralbleInConstructed base = new ChildVaralbleInConstructed(100); base.ptData(); ChildPublicVariable base2 = new ChildPublicVariable(); base2.data = 10; base2.ptData(); }}
補充:Java子類訪問父類私有變量的思考
示例如下:
父類User,包含私有變量name和money;
以及兩個構造函數和基本的getter方法。
public class User { public User() { } public User(String name, int money) { this.name = name; this.money = money; } public String getName() { return name; } public int getMoney() { return money; }}
子類Manager繼承User
public class Manager extends User { public Manager() { } public Manager(String name, int money) { super(name, money); } private String name; private int money; public void show(){ System.out.println('我是'+this.name+',我有'+this.money+'元錢'); System.out.println('我是'+this.getName()+',我有'+this.getMoney()+'元錢'); System.out.println('我是'+super.getName()+',我有'+super.getMoney()+'元錢'); }}
主類ClassDemo新建一個Manager對象,并調用其show()函數。
public class ClassDemo { public static void main(String[] args) { Manager m=new Manager('q',1); m.show(); }}
結果如下
我是null,我有0元錢---1
我是q,我有1元錢------2
我是q,我有1元錢------3
其中結果1容易理解,本類中的兩個變量沒有初始化,返回的是默認值。
結果2一開始感覺很困惑,子類繼承了父類的getName()和getMoney(),可并沒有繼承私有變量name和money,這里返回的值是誰的呢?
之后了解了一下這一部分的內存原理,原來新建子類時,會先在堆中新建一個父類,父類的變量和方法,以及子類獨有的變量和方法,二者共同組成了子類空間。
所以,新建子類后,父類中的private變量雖然不能被子類繼承,但卻是真實存在的,只是不可被直接訪問,只能間接使用。
結果2中,Manager對象其實在創建時就已經在構造函數中通過super(name,money)給name和mongey這兩個父類私有變量賦值了。而在使用this.getName()方法時,該方法是從父類繼承,所以方法內使用的變量也是父類的這兩個私有變量,所以在結果2中返回的是自定義的兩個值。
結果3中,super()直接通過父類調用getter方法,返回值當然也是兩個父類私有變量。
不過,如果在子類Manager中重寫getter方法,結果2就發生了改變。
public class Manager extends User { public Manager() { } public Manager(String name, int money) { super(name, money); } /*****************************新增重寫方法***************************/ @Override public String getName() { return name; } @Override public int getMoney() { return money; } /*****************************************************************/ private String name; private int money; public void show(){ System.out.println('我是'+this.name+',我有'+this.money+'元錢'); System.out.println('我是'+this.getName()+',我有'+this.getMoney()+'元錢'); System.out.println('我是'+super.getName()+',我有'+super.getMoney()+'元錢'); }}
我是null,我有0元錢---1
我是null,我有0元錢---2
我是q,我有1元錢------3
因為現在本類Manager中已經有了getter()方法,所以方法內直接調用本類的兩個name,money變量,因此結果2返回的是兩個初始值。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章:
1. Java發送http請求的示例(get與post方法請求)2. JS繪圖Flot如何實現動態可刷新曲線圖3. springboot基于Redis發布訂閱集群下WebSocket的解決方案4. 關于探究python中sys.argv時遇到的問題詳解5. 基于android studio的layout的xml文件的創建方式6. CSS自定義滾動條樣式案例詳解7. 使用ProcessBuilder調用外部命令,并返回大量結果8. Intellij IDEA官方最完美編程字體Mono使用9. python使用requests庫爬取拉勾網招聘信息的實現10. IDEA項目的依賴(pom.xml文件)導入問題及解決
