Miklix

Υπολογιστής κατακερματισμού MurmurHash3F

Δημοσιεύθηκε: 18 Φεβρουαρίου 2025 στις 12:27:49 π.μ. UTC
Τελευταία ενημέρωση: 12 Ιανουαρίου 2026 στις 1:31:14 μ.μ. UTC

Υπολογιστής κώδικα κατακερματισμού που χρησιμοποιεί τη συνάρτηση κατακερματισμού MurmurHash3F για τον υπολογισμό ενός κώδικα κατακερματισμού με βάση την εισαγωγή κειμένου ή την μεταφόρτωση αρχείου.

Αυτή η σελίδα μεταφράστηκε μηχανικά από τα αγγλικά, προκειμένου να είναι προσβάσιμη σε όσο το δυνατόν περισσότερους ανθρώπους. Δυστυχώς, η αυτόματη μετάφραση δεν είναι ακόμη μια τελειοποιημένη τεχνολογία, οπότε μπορεί να προκύψουν λάθη. Αν προτιμάτε, μπορείτε να δείτε την πρωτότυπη αγγλική έκδοση εδώ:

MurmurHash3F Hash Code Calculator

Το MurmurHash3 είναι μια μη κρυπτογραφική συνάρτηση κατακερματισμού που σχεδιάστηκε από τον Austin Appleby το 2008. Χρησιμοποιείται ευρέως για κατακερματισμό γενικής χρήσης λόγω της ταχύτητας, της απλότητας και των καλών ιδιοτήτων κατανομής. Οι συναρτήσεις MurmurHash είναι ιδιαίτερα αποτελεσματικές για δομές δεδομένων που βασίζονται σε κατακερματισμό, όπως πίνακες κατακερματισμού, φίλτρα bloom και συστήματα deduplication δεδομένων.

Η παραλλαγή που παρουσιάζεται σε αυτήν τη σελίδα είναι η παραλλαγή 3F, η οποία έχει βελτιστοποιηθεί για συστήματα 64 bit. Παράγει κωδικούς κατακερματισμού 128 bit (16 byte), οι οποίοι συνήθως αναπαρίστανται ως δεκαεξαδικός αριθμός 32 ψηφίων.

Πλήρης αποκάλυψη: Δεν έγραψα τη συγκεκριμένη υλοποίηση της συνάρτησης κατακερματισμού που χρησιμοποιείται σε αυτή τη σελίδα. Πρόκειται για μια τυπική συνάρτηση που περιλαμβάνεται στη γλώσσα προγραμματισμού PHP. Έφτιαξα μόνο τη διαδικτυακή διεπαφή για να την κάνω δημόσια διαθέσιμη εδώ για λόγους ευκολίας.


Υπολογισμός νέου κωδικού κατακερματισμού

Τα δεδομένα που υποβάλλονται ή τα αρχεία που μεταφορτώνονται μέσω αυτής της φόρμας θα διατηρηθούν στον διακομιστή μόνο για όσο χρονικό διάστημα απαιτείται για τη δημιουργία του ζητούμενου κωδικού κατακερματισμού. Θα διαγραφούν αμέσως πριν από την επιστροφή του αποτελέσματος στο πρόγραμμα περιήγησής σας.

Δεδομένα εισόδου:



Το υποβαλλόμενο κείμενο είναι κωδικοποιημένο με UTF-8. Δεδομένου ότι οι συναρτήσεις κατακερματισμού λειτουργούν με δυαδικά δεδομένα, το αποτέλεσμα θα είναι διαφορετικό από ό,τι αν το κείμενο ήταν σε άλλη κωδικοποίηση. Εάν πρέπει να υπολογίσετε ένα hash ενός κειμένου σε συγκεκριμένη κωδικοποίηση, θα πρέπει να ανεβάσετε ένα αρχείο.



Σχετικά με τον αλγόριθμο κατακερματισμού MurmurHash3F

Δεν είμαι μαθηματικός, αλλά θα προσπαθήσω να εξηγήσω αυτήν τη συνάρτηση κατακερματισμού χρησιμοποιώντας μια αναλογία που οι συνάδελφοί μου που δεν είναι μαθηματικοί μπορούν να κατανοήσουν. Αν προτιμάτε μια επιστημονικά σωστή, πλήρη μαθηματική εξήγηση, είμαι σίγουρος ότι μπορείτε να τη βρείτε αλλού ;-)

Τώρα, φανταστείτε ότι έχετε ένα μεγάλο κουτί με τουβλάκια LEGO. Κάθε φορά που τα τακτοποιείτε με έναν συγκεκριμένο τρόπο, τραβάτε μια φωτογραφία. Ανεξάρτητα από το πόσο μεγάλη ή πολύχρωμη είναι η διάταξη, η κάμερα σας δίνει πάντα μια μικρή φωτογραφία σταθερού μεγέθους. Αυτή η φωτογραφία αντιπροσωπεύει τη δημιουργία LEGO σας, αλλά σε συμπαγή μορφή.

Το MurmurHash3 κάνει κάτι παρόμοιο με τα δεδομένα. Λαμβάνει οποιοδήποτε είδος δεδομένων (κείμενο, αριθμούς, αρχεία) και τα συρρικνώνει σε μια μικρή, σταθερή τιμή "δακτυλικού αποτυπώματος" ή hash. Αυτό το δακτυλικό αποτύπωμα βοηθά τους υπολογιστές να αναγνωρίζουν, να ταξινομούν και να συγκρίνουν γρήγορα δεδομένα χωρίς να χρειάζεται να τα δουν ολόκληρα.

Μια άλλη αναλογία θα ήταν σαν να ψήνετε ένα κέικ και το MurmurHash3 είναι η συνταγή για να μετατρέψετε αυτό το κέικ σε ένα μικρό cupcake (το hash). Αυτή θα ήταν μια διαδικασία τριών βημάτων:

Βήμα 1: Κόψτε σε κομμάτια (Σπάζοντας τα δεδομένα)

  • Αρχικά, το MurmurHash3 κόβει τα δεδομένα σας σε ίσα κομμάτια, σαν να κόβει το κέικ σε ίσα τετράγωνα.

Βήμα 2: Ανακατέψτε σαν τρελό (Αναμειγνύοντας τα κομμάτια)

  • Κάθε κομμάτι περνάει από μια άγρια διαδικασία ανάμειξης: Αναστροφή: Όπως όταν γυρίζουμε μια τηγανίτα, αναδιατάσσει τα κομμάτια. Ανάδευση: Προσθέτει τυχαία συστατικά (μαθηματικές πράξεις) για να αναμειχθούν τα πράγματα. Σύνθλιψη: Συμπιέζει τα δεδομένα μεταξύ τους για να βεβαιωθεί ότι κανένα αρχικό κομμάτι δεν ξεχωρίζει.

Βήμα 3: Τελική Δοκιμή Γεύσης (Οριστικοποίηση)

  • Αφού αναμειχθούν όλα τα κομμάτια, το MurmurHash3 τα ανακατεύει για τελευταία φορά για να διασφαλίσει ότι ακόμη και η παραμικρή αλλαγή στα αρχικά δεδομένα θα αλλάξει εντελώς τη γεύση (το hash).

Περαιτέρω ανάγνωση

Αν σας άρεσε αυτή η ανάρτηση, ίσως σας αρέσουν και αυτές οι προτάσεις:


Μοιραστείτε το στο BlueskyΚοινή χρήση στο FacebookΚοινοποίηση στο LinkedInΜοιραστείτε το στο TumblrΚοινοποίηση στο XΚοινοποίηση στο LinkedInΚαρφιτσώστε στο Pinterest

Mikkel Christensen

Σχετικά με τον συγγραφέα

Mikkel Christensen
Ο Μιχαήλ είναι ο δημιουργός και ιδιοκτήτης του miklix.com. Έχει πάνω από 20 χρόνια εμπειρίας ως επαγγελματίας προγραμματιστής υπολογιστών/προγραμματιστής λογισμικού και σήμερα εργάζεται με πλήρη απασχόληση σε μια μεγάλη ευρωπαϊκή εταιρεία πληροφορικής. Όταν δεν ασχολείται με το ιστολόγιο, αφιερώνει τον ελεύθερο χρόνο του σε ένα ευρύ φάσμα ενδιαφερόντων, χόμπι και δραστηριοτήτων, τα οποία μπορεί σε κάποιο βαθμό να αντικατοπτρίζονται στην ποικιλία των θεμάτων που καλύπτονται σε αυτόν τον ιστότοπο.