Nah, sebenarnya terdapat banyak perkara yang boleh anda lakukan melalui kaedah, terutamanya apabila digabungkan dengan idea OO - Jenis ialah maklumat penting.
Selain itu, ini adalah piawaian Java Bean hanya itu "operasi biasa" bagi banyak rangka kerja dan perpustakaan pihak ketiga (yang paling terkenal ialah Spring) juga bergantung pada. ini. Anda boleh mencari artikel yang berkaitan dengan "kacang Jawa di Empayar Jawa".
Bantah sekeras-kerasnya jawapan seperti Logik penulisan penetap. Kod sedemikian sangat mengelirukan. Orang yang berpengalaman tahu bahawa anda tidak boleh menulis logik pada lapisan "bean" (biasanya sepadan dengan lapisan Model), tetapi sekurang-kurangnya pada lapisan Perkhidmatan (mengikut seni bina tiga lapisan biasa). Oleh itu, Setter dalam kes ini tidak begitu penting. Kesimpulannya, jawapan tentang menulis logik dalam Setter semuanya tidak betul.
Akhirnya, izinkan saya mengulas orang yang mengatakan Kewujudan itu munasabah Saya harap dia dapat memahami apa yang "Kewujudan itu munasabah".
Saya ingin membalas secara rasmi kepada orang yang mengkritik saya——Ada beberapa orang yang bercakap tentang logik dalam Setter, dan ada juga orang yang bergantung pada "teori fallacious" Seorang yang datang untuk memujuk orang lain.
Cerita saya, semasa saya mula-mula datang ke komuniti setahun yang lalu. Saya pernah melihat papan tanda yang ditulis oleh master dengan markah yang agak tinggi Rubbish SF! , saya perhatikan rekod reputasinya (pada masa itu, rekod reputasi agak serupa dengan rekod komit GitHub, tetapi ia tidak selama setahun), hampir semua isu telah ditolak undian , jelas sekali ——Ini berniat jahat.
Setelah berada dalam komuniti selama lebih daripada setahun, saya kadang-kadang menghadapi situasi seperti ini. Tetapi kaedahnya tidak begitu buruk, saya akui bahawa saya masih sangat mahir dalam beberapa isu, saya mungkin akan mengelirukan orang lain.
Sekarang keadaan ini tidak dapat saya tahan - jika anda salah, anda salah, Saya masih perlu menyesatkan orang lain. Sayang sekali jika orang lain ditapis kerana gagal soalan asas dalam temuduga !
Akhir sekali, saya ingin memberitahu semua:
Saya tidak akan meninggalkan komuniti hanya kerana saya tidak disukai, walaupun ia tidak disukai dengan niat jahat. Kerana saya perlu menjawab lebih banyak soalan untuk mengelakkan lebih ramai orang baru daripada disesatkan oleh "pemula yang dahsyat". Begitu juga, untuk mengekalkan kualiti komuniti, saya tidak akan pernah melepaskan jawapan yang sangat mengelirukan.
Jika anda tidak percaya saya, sila beritahu penemuduga semasa temuduga bahawa anda sering menulis logik dalam Setter of Java Bean!
Saya mengimbas semua jawapan dengan teliti tadi.
+1 mata untuk menjawab, dan hanya 1 mata untuk mengikuti arah aliran. Dipijak adalah 2 mata. Dan kerana semakin banyak jawapan seperti ini, kualiti komuniti akan menjadi lebih buruk dan lebih buruk Pada masa itu, walaupun anda mempunyai reputasi 1W, jika anda mengatakannya dengan bangga apabila anda berbual atau berkomunikasi, orang lain hanya akan mengejek: Bahawa Kualiti masyarakat tidak tinggi, semuanya hanya mengikut trend.
Setiap bahasa mempunyai falsafah yang berbeza. Java sepenuhnya berorientasikan objek dan menggalakkan fleksibiliti dan skalabiliti tinggi kod apabila mengekod . Bahasa seperti Go menyokong kesederhanaan utama kod, jadi anda hanya perlu mentakrifkan struct seperti berikut.
type S struct {
A string
B int
}
Tetapi dalam Java anda harus tetap mematuhi spesifikasi dan menentukan kaedah javabean untuk get/set, kerana anda mematuhi spesifikasi untuk menikmati faedah yang dibawa oleh spesifikasi kepada anda. Contohnya, apabila anda mengakses perpustakaan pihak ketiga, Apabila menggunakan reflect untuk mengendalikan javabean, kebanyakan mereka menggunakan kaedah get/set. Jika javabean anda tidak mempunyai kaedah get/set pada masa ini, jelas sekali anda tidak boleh menggunakan pustaka ini.
Berdasarkan pengalaman peribadi, kesederhanaan kod adalah lebih penting daripada fleksibiliti dan kebolehskalaan kod. Oleh itu, kit alat seperti java juga muncul dalam lombok, yang boleh memudahkan kod dengan baik.
Orang di atas telah berkata begitu banyak, tetapi mereka telah terlepas satu perkara Kaedah adalah polimorfik, tetapi atribut bukan polimorfik. Sebagai contoh, Person ialah kelas induk, Man ialah subkelas, kedua-dua kelas induk dan subkelas mempunyai atribut Nama (walaupun ini sangat jarang berlaku), dan nama dalam kelas induk dan subkelas kedua-duanya adalah awam. Sila lihat kod berikut:
Person p = new Man();
p.name = "person";
Print(p.name);
Print(p.getName());
Ini soalan yang bagus! Mengapa tidak kita umumkan sahaja bidang persendirian ini daripada menggunakan setter dan getter yang menyusahkan? Terdapat beberapa sebab:
Jangan sekali-kali mempercayai input pelanggan
Mari kita anggap kelas ini:
class Bicycle {
public int speed;
// ...
}
public class BicycleTest{
public static void main(String[] args){
Bicycle b = new Bicycle();
b.speed = 300000; //什么?自行车这么快?不科学啊?自行车车速不超过120吧。
// 可是作为程序员的我怎么办呢?只能在文档里告诉用这个类的人:超过120罚款?
// WTF!写这个类的程序员该死。
b.speed = -30; // 这个?负的速度,高中物理?我勒个去。
}
}
Adakah lebih baik jika kita menukarnya kepada ini:
class Bicycle {
private int speed;
public int setSpeed(int speed) {
if(speed > 120){
this.speed = 120;
} else if(speed < 0){
this.speed = 0;
} else{
this.speed = speed;
}
}
public int getSpeed() {
return speed;
}
}
public class BicycleTest{
public static void main(String[] args){
Bicycle b = new Bicycle();
b.speed = 300000;
System.out.println(b.getSpeed()); // 显示120
}
}
Mudah diubah suai
Andaikan kelajuan kini diperlukan antara 0-40. Tanpa getter dan setter, semua kod perlu ditulis semula, dan mustahil untuk diselesaikan dalam masa kurang dari satu jam. Dengan setter ini, ia adalah mudah, hanya menukar logik setter Jika ia tidak selesai dalam 1 minit, pengaturcara boleh memulakannya.
Pemahaman saya ialah kebaikan dan keburukan adalah relatif Untuk "program kecil", tidak ada keburukan, kerana anda dan penyelenggara lain boleh melihat dan mengawal dengan jelas perubahan dalam nilai parameter Pada masa ini, kerana anda Ia boleh mengawal sepenuhnya setiap sudut program, public malah "kebaikan melebihi keburukan", kerana tanpa setter&getter, banyak kod dikurangkan. Tetapi apabila program itu "besar" pada skala tertentu, patutkah kita mempertimbangkan kebolehselenggaraan program Contohnya, jika a.money dan a.getMoney() tiba-tiba menambah faktor a.action pada 影响money suatu hari nanti, apakah yang perlu kita lakukan? lakukan? Pastikan setiap pemanggil money dapat mengetahui peraturan pengaruh faktor, jelas sekali 直接a.money就不那么可靠. Dari perspektif menulis program, anda harus menulis lebih banyak kaedah Inilah yang diajar oleh guru pengaturcaraan komputer universiti saya. Dari perspektif berorientasikan objek, objek harus menyediakan kaedah untuk mengendalikan objek, jadi ia masih kaedah dan setter和getter merangkumi idea ini. Dari segi ciri Java, setter和getter merangkumi idea ciri pengkapsulan Dalam contoh di atas, apabila pengguna wang lain perlu menghubungi money, pemanggil tidak perlu tahu bahawa terdapat faktor tindakan di sana, dia. hanya perlu getMoney()Cukup dapatkan money yang betul Pembolehubah adalah peribadi dan menyediakan kaedah awam untuk pembolehubah pengendalian. Pada masa ini, kelebihan mengatasi kelemahan. Mereka yang mempunyai sedikit bakat dan sedikit pengetahuan, bercakap dari keluarga yang sama, dan menerima kritikan dan pembetulan jika mereka memahami sesuatu yang tidak sesuai.
Selain itu, mengenai masalah logik dalam setter&getter, saya fikir ia adalah persoalan "sepatutnya", dan bukannya soalan "bolehkah ia dilakukan". Bagi yang pertama, anda perlu menimbang kebaikan dan keburukan Apabila logik program dan kawalan risiko anda baik, anda akan senang untuk menulis. Rangka kerja yang sangat baik itu tidak ditulis dengan cara ini, dan ia mesti berdasarkan kebaikan dan keburukan (pengembangan, dsb.) Adalah perkara biasa untuk meletakkan logik dalam lapisan pemprosesan logik.
Tetapi adakah anda benar-benar perlu memikirkan masa depan?
Malah, sebab utama anda tidak melakukan ini adalah kerana ia sangat menyusahkan.
Tetapi sebenarnya, anda akan mempunyai medan (medan, atribut) yang mesti menggunakan penetap pengambil, seperti medan baca sahaja, jadi 1⃣️, untuk ketekalan kod keseluruhan, adalah lebih baik menggunakan semua pengambil dan penetap . 2⃣️, menggunakan bantuan idea sebenarnya tidak memerlukan banyak usaha untuk diselesaikan. 3⃣️, ini pada dasarnya adalah perkara normatif, tidak perlu memikirkan sama ada perlu melakukan ini. 4⃣️, dalam beberapa kes, getter dan setter memang tidak diperlukan Jika anda yakin bahawa data di sini sangat mudah, hanya buat ia umum secara langsung.
Mengenai soalan lain
Jika medan peribadi menyediakan getter dan setter, maka ia dianggap awam, yang tidak konsisten dan awam
harus digunakan.
Apakah tujuannya
Pertama sekali, medan peribadi mungkin hanya mempunyai pengambil dan penetap, yang secara semula jadi tidak dianggap awam. Jika terdapat kedua-dua setter dan getter, ia tidak semudah yang anda fikirkan. Kerana penyetel pengambil yang anda tulis sendiri tidak mempunyai sebarang logik pemprosesan, tetapi anda menganggap ini
private String name;
public void setName(String name) {
this.name = name.trim();
}
public String getName() {
return name;
}
Jika anda mempunyai keperluan yang sama seperti contoh ini, anda perlu mengalih keluar ruang tambahan semasa menyimpan nama. (Dengan cara ini, saya tidak dapat menjamin bahawa sintaks kod di atas adalah betul. Saya sudah lama tidak menulis Java.
Berkenaan dengan persoalan sama ada panggilan medan terbuka lebih selesa, sebenarnya medan terbuka ular sawa yang anda sebutkan bukan medan terbuka, bukan? Medan storan sebenar ialah _name, dan getter dan setter ialah nama Ini hanya berbeza dalam sintaks daripada Java, tetapi intipatinya adalah sama.
Saya akan meletakkan dua keping kod lagi untuk menunjukkan manfaat getter dan setter.
private int userId;
public User getUser();
public void setUser(user);
Contoh lain
private Map data;
public User getUser();
public int getStatus();
class GoodDog {
private int size;
public int getSize() {
return size;
}
public void setSize(int s){
size = s;
}
}
Terdapat isu enkapsulasi dan kawalan di sini. Katakan anda mengakses terus harta goodDog.size secara tiba-tiba suatu hari nanti, anda mungkin perlu menapis sesuatu untuk setiap saiz, atau untuk saiz tertentu, apakah yang perlu anda lakukan? Kemudian anda perlu menambah mekanisme penapisan di mana-mana sahaja di mana goodDog.size muncul. Jika anda menggunakan kaedah getSize(), maka saya akan menapisnya dalam kaedah ini dan ia akan menjadi OK. Sebenarnya, idea keseluruhan adalah untuk melakukan sesuatu dari perspektif berorientasikan objek Jika anda mahukan sesuatu, beritahu saya dan saya akan datang ke rumah untuk mendapatkannya, tetapi anda tidak boleh masuk terus ke dalam rumah untuk mendapatkannya. ia. Sekiranya anda tidak biasa dengan rumah saya. Apakah yang perlu saya lakukan jika keluarga saya kacau?
Jika goodDog .size=12 ditetapkan secara langsung, ia tidak selamat. Bagaimana jika nilai saiz kurang daripada 10 Adakah perlu untuk mengesahkan setiap tetapan atribut untuk mengelakkan perkara ini berlaku, Java menukar nilai secara seragam dan mengawal julat semasa kaedah yang ditetapkan, supaya apabila keperluan berubah pada masa hadapan, anda tidak perlu mencari tempat di seluruh dunia untuk menggunakan goodDog .size
Kaedah dengan parameter dan kaedah tanpa parameter bergantung pada penggunaan kaedah tertentu Kaedah set dan kaedah get adalah untuk mencerminkan idea pengkapsulan pengaturcaraan berorientasikan objek ditetapkan kepada peribadi dan hanya boleh diubah suai dan diakses melalui kaedah khusus untuk memastikan keselamatan program .
Terdapat juga jawapan di atas, seperti kacang java atau hibernate, apabila mengalih keluar atribut, ia tidak mengambil saiz atribut yang anda tentukan, tetapi mengambil getSize anda, dan kemudian mengalih keluar huruf kecil S kaedah get untuk mendapatkan saiz.
Atau jika anda masih tidak faham, ingat ini: Kewujudan adalah munasabah Suatu hari, apabila menulis sekeping kod, anda akan tiba-tiba menyedarinya.
Awam boleh digunakan dalam senario mudah Penyetel dan pengambil terutamanya tertutup kepada dunia luar Anda boleh menambah beberapa pemprosesan bersatu pada penyetel dan pengambil, yang juga mudah untuk pembinaan semula.
Saya ingin menambah bahawa untuk menyembunyikan keterlihatan, kaedah setter dan getter tidak semestinya mengakses nilai secara langsung, dan beberapa logik pemprosesan juga boleh ditambah.
Nah, sebenarnya terdapat banyak perkara yang boleh anda lakukan melalui kaedah, terutamanya apabila digabungkan dengan idea OO - Jenis ialah maklumat penting.
Selain itu, ini adalah piawaian Java Bean hanya itu "operasi biasa" bagi banyak rangka kerja dan perpustakaan pihak ketiga (yang paling terkenal ialah Spring) juga bergantung pada. ini. Anda boleh mencari artikel yang berkaitan dengan "kacang Jawa di Empayar Jawa".
Bantah sekeras-kerasnya jawapan seperti Logik penulisan penetap. Kod sedemikian sangat mengelirukan. Orang yang berpengalaman tahu bahawa anda tidak boleh menulis logik pada lapisan
"bean"
(biasanya sepadan dengan lapisan Model), tetapi sekurang-kurangnya pada lapisan Perkhidmatan (mengikut seni bina tiga lapisan biasa). Oleh itu, Setter dalam kes ini tidak begitu penting. Kesimpulannya, jawapan tentang menulis logik dalam Setter semuanya tidak betul.Akhirnya, izinkan saya mengulas orang yang mengatakan Kewujudan itu munasabah Saya harap dia dapat memahami apa yang "Kewujudan itu munasabah".
Saya ingin membalas secara rasmi kepada orang yang mengkritik saya——Ada beberapa orang yang bercakap tentang logik dalam Setter, dan ada juga orang yang bergantung pada "teori fallacious" Seorang yang datang untuk memujuk orang lain.
Cerita saya, semasa saya mula-mula datang ke komuniti setahun yang lalu. Saya pernah melihat papan tanda yang ditulis oleh master dengan markah yang agak tinggi Rubbish SF! , saya perhatikan rekod reputasinya (pada masa itu, rekod reputasi agak serupa dengan rekod komit GitHub, tetapi ia tidak selama setahun), hampir semua isu telah ditolak undian , jelas sekali ——Ini berniat jahat.
Setelah berada dalam komuniti selama lebih daripada setahun, saya kadang-kadang menghadapi situasi seperti ini. Tetapi kaedahnya tidak begitu buruk, saya akui bahawa saya masih sangat mahir dalam beberapa isu, saya mungkin akan mengelirukan orang lain.
Sekarang keadaan ini tidak dapat saya tahan - jika anda salah, anda salah, Saya masih perlu menyesatkan orang lain. Sayang sekali jika orang lain ditapis kerana gagal soalan asas dalam temuduga !
Akhir sekali, saya ingin memberitahu semua:
Saya tidak akan meninggalkan komuniti hanya kerana saya tidak disukai, walaupun ia tidak disukai dengan niat jahat. Kerana saya perlu menjawab lebih banyak soalan untuk mengelakkan lebih ramai orang baru daripada disesatkan oleh "pemula yang dahsyat". Begitu juga, untuk mengekalkan kualiti komuniti, saya tidak akan pernah melepaskan jawapan yang sangat mengelirukan.
Jika anda tidak percaya saya, sila beritahu penemuduga semasa temuduga bahawa anda sering menulis logik dalam Setter of Java Bean!
Saya mengimbas semua jawapan dengan teliti tadi.
+1 mata untuk menjawab, dan hanya 1 mata untuk mengikuti arah aliran. Dipijak adalah 2 mata. Dan kerana semakin banyak jawapan seperti ini, kualiti komuniti akan menjadi lebih buruk dan lebih buruk Pada masa itu, walaupun anda mempunyai reputasi 1W, jika anda mengatakannya dengan bangga apabila anda berbual atau berkomunikasi, orang lain hanya akan mengejek: Bahawa Kualiti masyarakat tidak tinggi, semuanya hanya mengikut trend.
Setiap bahasa mempunyai falsafah yang berbeza. Java sepenuhnya berorientasikan objek dan menggalakkan fleksibiliti dan skalabiliti tinggi kod apabila mengekod . Bahasa seperti
Go
menyokong kesederhanaan utama kod, jadi anda hanya perlu mentakrifkanstruct
seperti berikut.Tetapi dalam
Java
anda harus tetap mematuhi spesifikasi dan menentukan kaedahjavabean
untukget/set
, kerana anda mematuhi spesifikasi untuk menikmati faedah yang dibawa oleh spesifikasi kepada anda. Contohnya, apabila anda mengakses perpustakaan pihak ketiga, Apabila menggunakanreflect
untuk mengendalikanjavabean
, kebanyakan mereka menggunakan kaedahget/set
. Jikajavabean
anda tidak mempunyai kaedahget/set
pada masa ini, jelas sekali anda tidak boleh menggunakan pustaka ini.Berdasarkan pengalaman peribadi, kesederhanaan kod adalah lebih penting daripada fleksibiliti dan kebolehskalaan kod. Oleh itu, kit alat seperti
java
juga muncul dalamlombok
, yang boleh memudahkan kod dengan baik.Orang di atas telah berkata begitu banyak, tetapi mereka telah terlepas satu perkara Kaedah adalah polimorfik, tetapi atribut bukan polimorfik. Sebagai contoh, Person ialah kelas induk, Man ialah subkelas, kedua-dua kelas induk dan subkelas mempunyai atribut Nama (walaupun ini sangat jarang berlaku), dan nama dalam kelas induk dan subkelas kedua-duanya adalah awam. Sila lihat kod berikut:
Jawapan akan mengeluarkan
orang
null
Ini soalan yang bagus! Mengapa tidak kita umumkan sahaja bidang persendirian ini daripada menggunakan setter dan getter yang menyusahkan? Terdapat beberapa sebab:
Jangan sekali-kali mempercayai input pelanggan
Mari kita anggap kelas ini:
Adakah lebih baik jika kita menukarnya kepada ini:
Mudah diubah suai
Andaikan kelajuan kini diperlukan antara 0-40. Tanpa getter dan setter, semua kod perlu ditulis semula, dan mustahil untuk diselesaikan dalam masa kurang dari satu jam. Dengan setter ini, ia adalah mudah, hanya menukar logik setter Jika ia tidak selesai dalam 1 minit, pengaturcara boleh memulakannya.
Pemahaman saya ialah kebaikan dan keburukan adalah relatif Untuk "program kecil", tidak ada keburukan, kerana anda dan penyelenggara lain boleh melihat dan mengawal dengan jelas perubahan dalam nilai parameter Pada masa ini, kerana anda Ia boleh mengawal sepenuhnya setiap sudut program,
public
malah "kebaikan melebihi keburukan", kerana tanpasetter&getter
, banyak kod dikurangkan. Tetapi apabila program itu "besar" pada skala tertentu, patutkah kita mempertimbangkan kebolehselenggaraan program Contohnya, jikaa.money
dana.getMoney()
tiba-tiba menambah faktora.action
pada影响money
suatu hari nanti, apakah yang perlu kita lakukan? lakukan? Pastikan setiap pemanggilmoney
dapat mengetahui peraturan pengaruh faktor, jelas sekali直接a.money就不那么可靠
. Dari perspektif menulis program, anda harus menulis lebih banyak kaedah Inilah yang diajar oleh guru pengaturcaraan komputer universiti saya. Dari perspektif berorientasikan objek, objek harus menyediakan kaedah untuk mengendalikan objek, jadi ia masih kaedah dansetter和getter
merangkumi idea ini. Dari segi ciri Java,setter和getter
merangkumi idea ciri pengkapsulan Dalam contoh di atas, apabila pengguna wang lain perlu menghubungimoney
, pemanggil tidak perlu tahu bahawa terdapat faktor tindakan di sana, dia. hanya perlugetMoney()
Cukup dapatkanmoney
yang betul Pembolehubah adalah peribadi dan menyediakan kaedah awam untuk pembolehubah pengendalian. Pada masa ini, kelebihan mengatasi kelemahan. Mereka yang mempunyai sedikit bakat dan sedikit pengetahuan, bercakap dari keluarga yang sama, dan menerima kritikan dan pembetulan jika mereka memahami sesuatu yang tidak sesuai.Selain itu, mengenai masalah logik dalam setter&getter, saya fikir ia adalah persoalan "sepatutnya", dan bukannya soalan "bolehkah ia dilakukan". Bagi yang pertama, anda perlu menimbang kebaikan dan keburukan Apabila logik program dan kawalan risiko anda baik, anda akan senang untuk menulis. Rangka kerja yang sangat baik itu tidak ditulis dengan cara ini, dan ia mesti berdasarkan kebaikan dan keburukan (pengembangan, dsb.) Adalah perkara biasa untuk meletakkan logik dalam lapisan pemprosesan logik.
Pertama sekali, terjemahan kaedah ialah kaedah.
Kalau begitu biar saya faham kekeliruan anda
Malah, sebab utama anda tidak melakukan ini adalah kerana ia sangat menyusahkan.
Tetapi sebenarnya, anda akan mempunyai medan (medan, atribut) yang mesti menggunakan penetap pengambil, seperti medan baca sahaja, jadi 1⃣️, untuk ketekalan kod keseluruhan, adalah lebih baik menggunakan semua pengambil dan penetap .
2⃣️, menggunakan bantuan idea sebenarnya tidak memerlukan banyak usaha untuk diselesaikan.
3⃣️, ini pada dasarnya adalah perkara normatif, tidak perlu memikirkan sama ada perlu melakukan ini.
4⃣️, dalam beberapa kes, getter dan setter memang tidak diperlukan Jika anda yakin bahawa data di sini sangat mudah, hanya buat ia umum secara langsung.
Mengenai soalan lain
Pertama sekali, medan peribadi mungkin hanya mempunyai pengambil dan penetap, yang secara semula jadi tidak dianggap awam. Jika terdapat kedua-dua setter dan getter, ia tidak semudah yang anda fikirkan. Kerana penyetel pengambil yang anda tulis sendiri tidak mempunyai sebarang logik pemprosesan, tetapi anda menganggap ini
Jika anda mempunyai keperluan yang sama seperti contoh ini, anda perlu mengalih keluar ruang tambahan semasa menyimpan nama. (Dengan cara ini, saya tidak dapat menjamin bahawa sintaks kod di atas adalah betul. Saya sudah lama tidak menulis Java.
Berkenaan dengan persoalan sama ada panggilan medan terbuka lebih selesa, sebenarnya medan terbuka ular sawa yang anda sebutkan bukan medan terbuka, bukan? Medan storan sebenar ialah _name, dan getter dan setter ialah nama Ini hanya berbeza dalam sintaks daripada Java, tetapi intipatinya adalah sama.
Saya akan meletakkan dua keping kod lagi untuk menunjukkan manfaat getter dan setter.
Contoh lain
Terdapat isu enkapsulasi dan kawalan di sini. Katakan anda mengakses terus harta goodDog.size secara tiba-tiba suatu hari nanti, anda mungkin perlu menapis sesuatu untuk setiap saiz, atau untuk saiz tertentu, apakah yang perlu anda lakukan? Kemudian anda perlu menambah mekanisme penapisan di mana-mana sahaja di mana goodDog.size muncul. Jika anda menggunakan kaedah getSize(), maka saya akan menapisnya dalam kaedah ini dan ia akan menjadi OK. Sebenarnya, idea keseluruhan adalah untuk melakukan sesuatu dari perspektif berorientasikan objek Jika anda mahukan sesuatu, beritahu saya dan saya akan datang ke rumah untuk mendapatkannya, tetapi anda tidak boleh masuk terus ke dalam rumah untuk mendapatkannya. ia. Sekiranya anda tidak biasa dengan rumah saya. Apakah yang perlu saya lakukan jika keluarga saya kacau?
Jika goodDog .size=12 ditetapkan secara langsung, ia tidak selamat. Bagaimana jika nilai saiz kurang daripada 10
Adakah perlu untuk mengesahkan setiap tetapan atribut untuk mengelakkan perkara ini berlaku, Java menukar nilai secara seragam dan mengawal julat semasa kaedah yang ditetapkan, supaya apabila keperluan berubah pada masa hadapan, anda tidak perlu mencari tempat di seluruh dunia untuk menggunakan goodDog .size
Kaedah dengan parameter dan kaedah tanpa parameter bergantung pada penggunaan kaedah tertentu Kaedah set dan kaedah get adalah untuk mencerminkan idea pengkapsulan pengaturcaraan berorientasikan objek ditetapkan kepada peribadi dan hanya boleh diubah suai dan diakses melalui kaedah khusus untuk memastikan keselamatan program .
Terdapat juga jawapan di atas, seperti kacang java atau hibernate, apabila mengalih keluar atribut, ia tidak mengambil saiz atribut yang anda tentukan, tetapi mengambil getSize anda, dan kemudian mengalih keluar huruf kecil S kaedah get untuk mendapatkan saiz.
Atau jika anda masih tidak faham, ingat ini: Kewujudan adalah munasabah Suatu hari, apabila menulis sekeping kod, anda akan tiba-tiba menyedarinya.
Awam boleh digunakan dalam senario mudah Penyetel dan pengambil terutamanya tertutup kepada dunia luar Anda boleh menambah beberapa pemprosesan bersatu pada penyetel dan pengambil, yang juga mudah untuk pembinaan semula.
Saya ingin menambah bahawa untuk menyembunyikan keterlihatan, kaedah
setter
dangetter
tidak semestinya mengakses nilai secara langsung, dan beberapa logik pemprosesan juga boleh ditambah.