cari
Rumahpembangunan bahagian belakangC++Mengapa Pengoptimuman Pengkompil Memecahkan Fungsi Swap 64-bit Ini?

Why Does Compiler Optimization Break This 64-bit Swap Function?

Mengapa Pengoptimuman Merendahkan Fungsi Ini

Dalam kuliah universiti mengenai kepakaran pengaturcaraan, seorang pensyarah menyampaikan fungsi yang membingungkan pelajar:

inline u64 Swap_64(u64 x)
{
    u64 tmp;
    (*(u32*)&tmp)       = Swap_32(*(((u32*)&x)+1));
    (*(((u32*)&tmp)+1)) = Swap_32(*(u32*) &x);

    return tmp;
}

Pada mulanya, fungsi ini beroperasi dengan lancar, tetapi setelah mendayakan tahap pengoptimuman yang tinggi, ia menjadi lengai. Sebab di sebalik tingkah laku ini terletak pada konsep peraturan pengalian yang ketat.

Pelanggaran Pengalian Tegas

Kod yang disediakan melanggar peraturan pengalian yang ketat, yang menentukan bahawa objek hanya perlu diakses melalui jenis penunjuk yang serasi. Dalam kes ini, penunjuk u32 dan u64 menunjukkan memori yang berpotensi bertindih, tetapi pengkompil menganggap ia mewakili objek yang berbeza. Andaian ini membenarkannya untuk mengoptimumkan tugasan kepada pembolehubah sementara tmp, menjadikan fungsi itu tidak berkesan.

Mengapa Pengoptimuman Berlaku

Pengkompil dibenarkan untuk mengoptimumkan kod berdasarkan andaian tentang tingkah laku penunjuk. Oleh kerana u32 dan u64 adalah jenis yang berbeza, pengkompil menganggap ia tidak menghala ke memori yang sama dan bahawa perubahan yang dibuat melalui penunjuk u32 tidak akan menjejaskan nilai tmp. Pengoptimuman ini membawa kepada gelagat yang diperhatikan.

Penyelesaian untuk Mengekalkan Gelagat Fungsi

Untuk mengelakkan kod daripada dioptimumkan, jenis penuding hendaklah sepadan dengan jenis data yang diakses. Satu pendekatan ialah menggunakan kesatuan untuk mengakses bit secara terus:

typedef union
{
  uint32_t u32;
  uint16_t u16[2];
} U32;

uint32_t swap_words(uint32_t arg)
{
  U32 in;
  uint16_t lo;
  uint16_t hi;

  in.u32    = arg;
  hi        = in.u16[0];
  lo        = in.u16[1];
  in.u16[0] = lo;
  in.u16[1] = hi;

  return (in.u32);
}

Dengan menggunakan kesatuan, kami memastikan bahawa penunjuk dan jenis data adalah serasi, menghalang pengkompil daripada mengoptimumkan perubahan yang dimaksudkan.

Atas ialah kandungan terperinci Mengapa Pengoptimuman Pengkompil Memecahkan Fungsi Swap 64-bit Ini?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Gulc: Perpustakaan C dibina dari awalGulc: Perpustakaan C dibina dari awalMar 03, 2025 pm 05:46 PM

GULC adalah perpustakaan C berprestasi tinggi yang mengutamakan overhead yang minimum, inlining agresif, dan pengoptimuman pengkompil. Sesuai untuk aplikasi kritikal prestasi seperti perdagangan frekuensi tinggi dan sistem tertanam, reka bentuknya menekankan kesederhanaan, modul

Apakah jenis nilai yang dikembalikan oleh fungsi bahasa C? Apa yang menentukan nilai pulangan?Apakah jenis nilai yang dikembalikan oleh fungsi bahasa C? Apa yang menentukan nilai pulangan?Mar 03, 2025 pm 05:52 PM

Butiran artikel ini C jenis pulangan fungsi, merangkumi asas (int, float, char, dan lain -lain), diperolehi (tatasusunan, petunjuk, struktur), dan jenis kekosongan. Pengkompil menentukan jenis pulangan melalui pengisytiharan fungsi dan pernyataan pulangan, menguatkuasakan

Apakah definisi dan peraturan panggilan fungsi bahasa C dan apakah ituApakah definisi dan peraturan panggilan fungsi bahasa C dan apakah ituMar 03, 2025 pm 05:53 PM

Artikel ini menerangkan perisytiharan fungsi C vs definisi, argumen lulus (dengan nilai dan penunjuk), nilai pulangan, dan perangkap umum seperti kebocoran memori dan jenis ketidakcocokan. Ia menekankan pentingnya pengisytiharan modularity dan provi

Langkah Format Fungsi Fungsi C Langkah Penukaran KesLangkah Format Fungsi Fungsi C Langkah Penukaran KesMar 03, 2025 pm 05:53 PM

Butiran artikel ini C berfungsi untuk penukaran kes rentetan. Ia menerangkan menggunakan ToUpper () dan Tolower () dari CType.H, meleleh melalui rentetan, dan mengendalikan terminator null. Perangkap biasa seperti melupakan ctype.h dan mengubahsuai literal rentetan adalah

Di manakah nilai pulangan fungsi bahasa C yang disimpan dalam ingatan?Di manakah nilai pulangan fungsi bahasa C yang disimpan dalam ingatan?Mar 03, 2025 pm 05:51 PM

Artikel ini mengkaji fungsi penyimpanan nilai pulangan C. Nilai pulangan kecil biasanya disimpan dalam daftar untuk kelajuan; Nilai yang lebih besar boleh menggunakan petunjuk untuk memori (timbunan atau timbunan), memberi kesan kepada seumur hidup dan memerlukan pengurusan memori manual. Secara langsung acc

Penggunaan dan perkongsian frasa yang berbezaPenggunaan dan perkongsian frasa yang berbezaMar 03, 2025 pm 05:51 PM

Artikel ini menganalisis kegunaan pelbagai kata sifat "berbeza," meneroka fungsi tatabahasa, frasa umum (mis., "Berbeza," "berbeza"), dan aplikasi bernuansa dalam formal vs tidak formal

Bagaimana Perpustakaan Templat St Standard (STL) berfungsi?Bagaimana Perpustakaan Templat St Standard (STL) berfungsi?Mar 12, 2025 pm 04:50 PM

Artikel ini menerangkan Perpustakaan Templat St Standard (STL), yang memberi tumpuan kepada komponen terasnya: bekas, iterator, algoritma, dan functors. Ia memperincikan bagaimana ini berinteraksi untuk membolehkan pengaturcaraan generik, meningkatkan kecekapan kod dan kebolehbacaan t

Bagaimanakah saya menggunakan algoritma dari STL (jenis, mencari, mengubah, dll) dengan cekap?Bagaimanakah saya menggunakan algoritma dari STL (jenis, mencari, mengubah, dll) dengan cekap?Mar 12, 2025 pm 04:52 PM

Artikel ini memperincikan penggunaan algoritma STL yang cekap dalam c. Ia menekankan pilihan struktur data (vektor vs senarai), analisis kerumitan algoritma (mis., Std :: Sort vs Std :: partial_sort), penggunaan iterator, dan pelaksanaan selari. Perangkap biasa seperti

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa