Mengapa Menghiris dengan Panjang Lebih Besar Daripada Kapasiti Menghasilkan Ralat Masa Jalan?
Apabila mencipta kepingan, adalah penting bahawa kapasiti, atau saiz tatasusunan asas, tidak kurang daripada panjang, atau bilangan elemen dalam kepingan. Percubaan untuk berbuat demikian, seperti yang dilihat dalam program Go yang disediakan, mencetuskan ralat masa jalan "makeslice: had out of range".
Punca kekangan ini terletak pada sifat hirisan. Slices bukanlah struktur data yang berdiri sendiri tetapi merujuk kepada bahagian tatasusunan asas. Mengikut takrifan, kapasiti kepingan adalah saiz tatasusunan sokongan ini. Jika panjang kepingan pernah melebihi kapasitinya, tidak akan ada memori yang sepadan untuk menyimpan unsur-unsur. Ketidakkonsistenan logik ini mengakibatkan ralat masa jalan.
Untuk mengekalkan konsistensi, pengkompil Go menguatkuasakan invarian:
0 <= len(s) <= cap(s)
untuk setiap kepingan s. Dalam kod yang disediakan, walau bagaimanapun, percubaan untuk mengakses elemen pada indeks 8 dengan kapasiti hanya 5 melanggar invarian ini, mencetuskan ralat masa jalan.
Adalah penting untuk ambil perhatian bahawa invarian ini tidak boleh sentiasa disahkan secara statik, seperti dalam kes di mana kapasiti dan panjang ditentukan pada masa jalan. Inilah sebabnya, dalam senario tertentu, ralat itu nyata sebagai ralat masa jalan dan bukannya ralat masa kompilasi.
Atas ialah kandungan terperinci Mengapa Melebihi Kapasiti Go Slice Menghasilkan \'makeslice: cap out of range\' Ralat Masa Jalan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!