Rumah >Java >javaTutorial >Bagaimana untuk mengoptimumkan kod Java dan apakah petua praktikal yang tersedia di tempat kerja?
Contoh: Jika kaedah peribadi, padamkannya jika anda ingin memadamkannya
Jika a Kaedah public
service
, atau pembolehubah ahli awam, padamkannya tanpa berfikir panjang.
Komputer menggunakan perwakilan binari dan operasi anjakan akan meningkatkan prestasi dengan banyak.
> Anjakan kanan bersamaan dengan pembahagian dengan 2;
>>> membahagikan dengan 2, tetapi ia akan mengabaikan bit tanda dan mengisi bit kosong dengan 0s.
a = val << 3; b = val >> 1;
Kami tahu bahawa kaedah panggilan adalah mahal, termasuk mencipta bingkai tindanan, melindungi pemandangan semasa memanggil kaedah, memulihkan pemandangan, dsb.
//反例 for (int i = 0; i < list.size(); i++) { System.out.println("result"); } //正例 for (int i = 0, length = list.size(); i < length; i++) { System.out.println("result"); }
mengurangkan banyak penggunaan apabila list.size()
sangat besar.
RuntimeException tidak seharusnya ditangkap melalui kenyataan tangkapan, tetapi harus dielakkan menggunakan kaedah pengekodan.
Seperti yang ditunjukkan dalam kod berikut, tatasusunan di luar sempadan mungkin berlaku dalam senarai.
Sama ada ia di luar sempadan boleh dinilai terlebih dahulu melalui kod dan bukannya menunggu sehingga pengecualian berlaku untuk menangkapnya.
Nilai dengan cara ini lebih awal, kod akan menjadi lebih elegan dan cekap.
public String test1(List<String> list, int index) { try { return list.get(index); } catch (IndexOutOfBoundsException ex) { return null; } } //正例 public String test2(List<String> list, int index) { if (index >= list.size() || index < 0) { return null; } return list.get(index); }
Memandangkan sumber timbunan dikongsi oleh berbilang benang dan merupakan kawasan utama tempat pemungut sampah berfungsi, terlalu banyak objek akan menyebabkan tekanan GC , pembolehubah boleh diperuntukkan pada timbunan melalui pembolehubah tempatan. Dengan cara ini, pembolehubah akan dimusnahkan apabila pelaksanaan kaedah selesai, yang boleh mengurangkan tekanan pada GC.
Perhatikan skop pembolehubah dan minimumkan penciptaan objek.
Seperti yang ditunjukkan dalam kod di bawah, pembolehubah s akan dibuat setiap kali kaedah dimasukkan, dan ia boleh dialihkan ke dalam pernyataan if.
public void test(String str) { final int s = 100; if (!StringUtils.isEmpty(str)) { int result = s * s; } }
Cuba gunakan strategi pemuatan malas dan hanya buat apabila diperlukan
String str = "月伴飞鱼"; if (name == "公众号") { list.add(str); } if (name == "公众号") { String str = "月伴飞鱼"; list.add(str); }
Gunakan objek untuk mengakses pembolehubah statik Kaedah ini memerlukan operasi pengalamatan tambahan Anda perlu terlebih dahulu mencari kelas yang sepadan dengan pembolehubah, dan kemudian mencari pembolehubah yang sepadan dengan kelas.
// 反例 int i = objectA.staticMethod(); // 正例 int i = ClassA.staticMethod();
Untuk penyambungan rentetan, gunakan StringBuilder atau StringBuffer, jangan gunakan tanda +.
//反例 public class StringTest { @Test public void testStringPlus() { String str = "111"; str += "222"; str += "333"; System.out.println(str); } } //正例 public class TestMain { public static void main(String[] args) { StringBuilder sb = new StringBuilder("111"); sb.append("222"); sb.append(333); System.out.println(sb.toString()); } }
Tulis Semula Kod Hash objek, jangan hanya mengembalikan nilai tetap
Apabila sesetengah pelajar sedang membangunkan Kod Hash yang mengatasi dan Sama dengan kaedah, Nilai HashCode akan dikembalikan kepada 0 tetap, dan ini tidak sesuai
Apabila objek ini disimpan dalam HashMap, prestasi akan menjadi sangat rendah, kerana HashMap mengesan slot Hash melalui HashCode, dan terdapat konflik hanya apabila ini berlaku, senarai terpaut atau pokok merah-hitam digunakan untuk menyusun nod, dan 0 dikembalikan dengan tetap, yang bersamaan dengan membatalkan fungsi pengalamatan Hash.
Apabila memulakan koleksi seperti HashMap, nyatakan saiz nilai awal
Terdapat banyak objek seperti itu, seperti ArrayList, StringBuilder, dsb., dengan menyatakan nilai awal Saiz nilai boleh mengurangkan kehilangan prestasi yang disebabkan oleh pengembangan.
Pengiraan saiz nilai awal:
Di dalam gelung Jangan buat rujukan objek secara berterusan
//反例 for (int i = 1; i <= size; i++) { Object obj = new Object(); } //正例 Object obj = null; for (int i = 0; i <= size; i++) { obj = new Object(); }
Kaedah pertama akan menyebabkan rujukan objek objek wujud dalam memori Jika saiznya besar, memori akan digunakan
Menggunakan kaedah EntrySet, anda boleh terus mengembalikan objek yang ditetapkan dan menggunakannya secara terus semasa menggunakan kaedah KeySet, anda mendapat koleksi kunci, dan anda perlu melakukan yang lain dapatkan operasi, yang menambah satu lagi langkah operasi Oleh itu, lebih disyorkan untuk menggunakan kaedah EntrySet untuk melintasi Peta.
Set<Map.Entry<String, String>> entryseSet = nmap.entrySet(); for (Map.Entry<String, String> entry : entryseSet) { System.out.println(entry.getKey()+","+entry.getValue()); }
Benih kelas Rawak akan bersaing semasa akses serentak, menyebabkan penurunan prestasi Adalah disyorkan untuk menggunakan ThreadLocalRandom dalam pelbagai-. persekitaran berulir.
public static void main(String[] args) { ThreadLocalRandom threadLocalRandom = ThreadLocalRandom.current(); Thread thread1 = new Thread(()->{ for (int i=0;i<10;i++){ System.out.println("Thread1:"+threadLocalRandom.nextInt(10)); } }); Thread thread2 = new Thread(()->{ for (int i=0;i<10;i++){ System.out.println("Thread2:"+threadLocalRandom.nextInt(10)); } }); thread1.start(); thread2.start(); }
Operasi kenaikan automatik boleh mengawal keselamatan benang melalui gabungan synchronized
dan volatile
, atau anda juga boleh gunakan kelas atom (seperti AtomicLong).
Yang terakhir lebih cepat daripada yang pertama AtomicLong
Menggunakan CAS untuk perbandingan dan penggantian akan menyebabkan terlalu banyak putaran tidak sah apabila terdapat banyak utas boleh digunakan untuk menggantikan AtomicLong untuk peningkatan prestasi selanjutnya.
public class Test { public int longAdderTest(Blackhole blackhole) throws InterruptedException { LongAdder longAdder = new LongAdder(); for (int i = 0; i < 1024; i++) { longAdder.add(1); } return longAdder.intValue(); } }
Refleksi sangat berkuasa, tetapi ia dilaksanakan dengan menghurai bytecode, jadi prestasinya tidak begitu ideal.
Sebenarnya, terdapat banyak kaedah pengoptimuman untuk refleksi, seperti menyimpan cache proses pelaksanaan refleksi (seperti Kaedah) dan menggunakan pemultipleksan untuk mempercepatkan refleksi.
Selepas Java 7.0, pakej baharu java.lang.invoke
telah ditambahkan dan arahan kod bait JVM baharu yang invokedynamic telah ditambahkan untuk menyokong kaedah sasaran panggilan terus melalui rentetan daripada peringkat JVM.
Atas ialah kandungan terperinci Bagaimana untuk mengoptimumkan kod Java dan apakah petua praktikal yang tersedia di tempat kerja?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!