ความแตกต่างระหว่าง GZIP และ BZIP2 ความแตกต่างระหว่าง

Anonim

GZIP และ BZIP2

GNU zip (หรือที่เรียกว่า GZIP) เป็นโปรแกรมซอฟต์แวร์ที่มีวัตถุประสงค์เพื่อบีบอัด ไฟล์ เดิมทีตั้งใจจะแทนที่โปรแกรมบีบอัดที่ใช้ในระบบ Unix ต้น - เพื่อใช้ในโครงการ GNU (โครงการซอฟต์แวร์เสรี)

BZIP2 เป็นอัลกอริทึมการบีบอัดข้อมูลแบบ lossless แบบโอเพ่นซอร์ส - โดยทั่วไปคลาสของอัลกอริทึมการบีบอัดข้อมูลซึ่งจะทำให้ข้อมูลต้นฉบับของไฟล์บีบอัดสามารถสร้างขึ้นใหม่จากข้อมูลที่ถูกบีบอัดได้

GZIP ใช้อัลกอริทึมที่เรียกว่า DEFLATE นี่เป็นขั้นตอนวิธีการบีบอัดข้อมูลแบบ lossless ใช้ทั้ง LZ77 algorithm และ Huffman coding GZIP หมายถึงรูปแบบไฟล์ที่มีชื่อเดียวกัน รูปแบบนี้เป็นส่วนหัว 10 ไบต์ซึ่งมีจำนวนมายากล (ซึ่งหมายถึงค่าตัวเลขหรือข้อความที่ไม่เคยเปลี่ยนแปลงและใช้เพื่อระบุรูปแบบไฟล์หรือโปรโตคอลค่าตัวเลขที่ไม่มีชื่อซึ่งไม่เคยเปลี่ยนแปลงหรือค่าที่แตกต่างกันซึ่งไม่สามารถเข้าใจผิดได้ สำหรับส่วนอื่น ๆ) ส่วนหัวพิเศษที่อาจจำเป็นหรือไม่จำเป็นจริง (เช่นชื่อไฟล์ต้นฉบับเป็นต้น) เนื้อความที่มีข้อมูลการบีบอัดที่ถูกบีบอัด (ซึ่งเป็นข้อมูลที่ส่วนหัวมี) และส่วนท้าย 8 ไบต์ ซึ่งประกอบด้วยการตรวจสอบ CRC-32 ตลอดจนความยาวจริงของข้อมูลที่ไม่มีการบีบอัดต้นฉบับ

มีเทคนิคการบีบอัดที่หลากหลายซึ่งรูปแบบ BZIP2 ใช้ซึ่งจะเรียงซ้อนอยู่บนยอดอีกหลายชั้น พวกเขาเกิดขึ้นในลำดับที่โดดเด่นมาก: การเข้ารหัสแบบยาว (ซึ่งเป็นลำดับสี่ถึง 255 สัญลักษณ์ที่ซ้ำกันซึ่งถูกแทนที่ด้วยสัญลักษณ์สี่ตัวแรกและความยาวของรหัสที่ซ้ำระหว่าง 0 ถึง 251) การแปลง Burrows-Wheeler ซึ่งเป็นบล็อกแบบย้อนกลับที่จัดเรียงเป็นแกนหลักของ BZIP2) ย้ายไปด้านหน้า (ปล่อยให้ขนาดของบล็อกที่ผ่านการประมวลผลไม่เปลี่ยนแปลง), การเข้ารหัสแบบ Run-length (ซึ่งประกอบด้วยเส้นยาวของสัญลักษณ์ซึ่งโดยปกติจะเป็นศูนย์) ซ้ำในเอาท์พุทและจะถูกแทนที่ด้วยทั้งสัญลักษณ์และลำดับของรหัสสอง), การเข้ารหัส Huffman (ซึ่งเป็นกระบวนการที่จะแทนที่ความยาวคงที่สัญลักษณ์ของไบต์ 8 บิตด้วยการเปลี่ยนรหัสความยาว), การเข้ารหัสหลายฮอฟแมน (ซึ่งประกอบด้วย ตาราง Hoffman หลายขนาดเท่ากัน), Unary base 1 encoding, Delta encoding และ Sparse bit array

สรุป:

1. GZIP เป็นโปรแกรมฟรีที่ใช้ในการบีบอัดไฟล์ BZIP2 เป็นอัลกอริทึมการบีบอัดข้อมูลแบบ lossless แบบโอเพ่นซอร์สซึ่งทำให้สามารถดึงข้อมูลต้นฉบับของไฟล์บีบอัดได้

2 GZIP ประกอบด้วยส่วนหัว 10 ไบต์ส่วนหัวที่เลือกเนื้อหาและส่วนท้าย 8 ไบต์; BZIP2 ประกอบด้วยเทคนิคการบีบอัดข้อมูลไม่น้อยกว่าเก้าชั้น