Maison développement back-end Golang Comment Golang gère les fichiers volumineux

Comment Golang gère les fichiers volumineux

Apr 27, 2023 am 09:11 AM

En développement, nous rencontrons souvent des situations où nous devons traiter des fichiers volumineux. En tant que langage efficace et adapté au traitement simultané, le langage Go impliquera naturellement le traitement de fichiers volumineux. Que vous lisiez, écriviez ou modifiiez des fichiers volumineux, vous devez prendre en compte certains problèmes, tels que : Comment éviter les fuites de mémoire ? Comment y faire face efficacement ? Dans cet article, nous présenterons plusieurs méthodes de traitement de fichiers volumineux et nous concentrerons sur la façon de gérer les fichiers trop volumineux pour éviter les plantages du programme.

  1. Utilisez le traitement de segmentation

En général, que vous lisiez, écriviez ou modifiiez des fichiers volumineux, vous devez réfléchir à la manière d'éviter les fuites de mémoire et les plantages de programmes. Afin de traiter efficacement des fichiers volumineux, le traitement fractionné est souvent utilisé pour diviser le gros fichier en plusieurs petits fichiers, puis lire et écrire les petits fichiers.

En langage Go, nous pouvons diviser des fichiers via les méthodes io.LimitReader() et io.MultiReader() pour diviser un gros fichier en plusieurs petits fichiers. Utilisez multi. -enfilage. io.LimitReader()io.MultiReader()方法来分割文件,将大文件分割成多个小文件,运用多线程处理。

通过以下代码的方式读取超过 500MB 的大文件:

var (
    maxSize int64 = 100 * 1024 * 1024 //100MB
)
func readBigFile(filename string) (err error) {
    file, err := os.Open(filename)
    if err != nil {
        return err
    }
    defer file.Close()

    fileInfo, err := file.Stat()
    if err != nil {
        return err
    }

    if fileInfo.Size() <= maxSize {
        _, err = io.Copy(os.Stdout, file)
    } else {
        n := (fileInfo.Size() + (maxSize - 1)) / maxSize
        var err error
        for i := int64(0); i < n; i++ {
            eachSize := maxSize
            if i == n-1 {
                eachSize = fileInfo.Size() - (n-1)*maxSize
            }
            sectionReader := io.NewSectionReader(file, i*maxSize, eachSize)
            _, err = io.Copy(os.Stdout, sectionReader)
            if err != nil {
                return err
            }
        }
    }
    return nil
}
Copier après la connexion

在上述代码中,当读取到的文件大小超过最大允许值时,会使用复合读取方式,将大文件分成大小相同的多个区块进行读取,最后合并成最终结果。

以上的方式当然是针对读取大文件过程做优化,有的时候我们也会有文件写入方面的需求。

  1. 写入大文件

Go中写入大文件有一个最简单的方法,就是使用bufio.NewWriterSize()函数包裹上os.File(),并在Write前判断当前缓冲区是否已经满,满了之后调用Flush()方法将缓冲区中的数据写入到硬盘中。这种写入大文件的方式实现简单易行,适合大文件的写入。

    writer := bufio.NewWriterSize(file, size)
    defer writer.Flush()
    _, err = writer.Write(data)
Copier après la connexion
  1. 处理大型CSV文件

除了读取和写入大文件,我们还可能会处理大型CSV文件。在处理CSV文件时,如果文件过大,会导致一些程序崩溃的问题,因此我们需要使用一些工具来处理这些大型CSV文件。Go 语言提供了一种名为 goroutine 和 channel 的机制,可以同时处理多个文件,从而达到快速处理大型CSV文件的目的。

在 Go 语言中,我们可以使用csv.NewReader()csv.NewWriter()方法分别构建读取和写入 CSV 文件的处理器,然后按照行扫描文件以读取数据。在 CSV 文件中使用一个管道来处理数据按照行存储的方式。

func readCSVFile(path string, ch chan []string) {
    file, err := os.Open(path)
    if err != nil {
        log.Fatal("读取文件失败:", err)
    }
    defer file.Close()
    reader := csv.NewReader(file)
    for {
        record, err := reader.Read()
        if err == io.EOF {
            break
        } else if err != nil {
            log.Fatal("csv文件读取失败:", err)
        }
        ch <- record
    }
    close(ch)
}

func writeCSVFile(path string, ch chan []string) {
    file, err := os.Create(path)
    if err != nil {
        log.Fatal("创建csv文件失败:", err)
    }
    defer file.Close()
    writer := csv.NewWriter(file)
    for record := range ch {
        if err := writer.Write(record); err != nil {
            log.Fatal("csv文件写入失败: ", err)
        }
        writer.Flush()
    }
}
Copier après la connexion

在上述代码中,使用csv.NewReader()

Lisez les fichiers volumineux dépassant 500 Mo via le code suivant :

rrreee

Dans le code ci-dessus, lorsque la taille du fichier lu dépasse la valeur maximale autorisée, la méthode de lecture composée sera utilisée pour diviser le fichier volumineux en fichiers multiples de taille égale. les blocs sont lus et finalement fusionnés dans le résultat final.

La méthode ci-dessus est bien sûr optimisée pour le processus de lecture de fichiers volumineux. Parfois, nous avons également des besoins en écriture de fichiers.

    Écrire des fichiers volumineux

    🎜Le moyen le plus simple d'écrire des fichiers volumineux dans Go est d'utiliser la fonction bufio.NewWriterSize() pour envelopper le système d'exploitation . File() et déterminez si le tampon actuel est plein avant d'écrire. Une fois qu'il est plein, appelez la méthode Flush() pour écrire les données du tampon sur le disque dur. Cette méthode d’écriture de fichiers volumineux est simple et facile à mettre en œuvre et convient à l’écriture de fichiers volumineux. 🎜rrreee
      🎜Gestion des gros fichiers CSV🎜🎜🎜En plus de lire et d'écrire des fichiers volumineux, nous pouvons également traiter des fichiers CSV volumineux. Lors du traitement de fichiers CSV, si le fichier est trop volumineux, cela entraînera des plantages du programme, nous devons donc utiliser certains outils pour traiter ces gros fichiers CSV. Le langage Go fournit un mécanisme appelé goroutine et canal, qui peut traiter plusieurs fichiers en même temps pour atteindre l'objectif de traitement rapide de gros fichiers CSV. 🎜🎜En langage Go, nous pouvons utiliser les méthodes csv.NewReader() et csv.NewWriter() pour construire des processeurs pour lire et écrire des fichiers CSV respectivement, puis scanner le fichier ligne par ligne pour lire les données. Utilisez un pipeline dans le fichier CSV pour traiter la façon dont les données sont stockées ligne par ligne. 🎜rrreee🎜Dans le code ci-dessus, utilisez la méthode csv.NewReader() pour parcourir le fichier, stocker chaque ligne de données dans un tableau, puis envoyer le tableau au canal. Lors de la lecture du fichier CSV, nous avons utilisé des goroutines et des canaux pour analyser l'intégralité du fichier simultanément. Après la lecture, nous fermons le canal pour montrer que nous avons fini de lire le fichier. 🎜🎜Grâce à la méthode ci-dessus, il n'est plus nécessaire de lire l'intégralité des données dans la mémoire lors du traitement de fichiers volumineux, ce qui évite les fuites de mémoire et les plantages du programme, et améliore également l'efficacité du fonctionnement du programme. 🎜🎜Résumé : 🎜🎜Dans l'introduction ci-dessus, nous avons exploré certaines méthodes de traitement de fichiers volumineux, notamment l'utilisation du traitement fractionné, l'écriture de fichiers volumineux et le traitement de gros fichiers CSV. Dans le développement réel, nous pouvons choisir une manière appropriée de traiter des fichiers volumineux en fonction des besoins de l'entreprise afin d'améliorer les performances et l'efficacité du programme. Dans le même temps, lors du traitement de fichiers volumineux, nous devons nous concentrer sur les problèmes de mémoire, planifier raisonnablement l'utilisation de la mémoire et éviter les fuites de mémoire. 🎜🎜Lorsque nous utilisons le langage Go pour traiter des fichiers volumineux, nous pouvons utiliser pleinement les fonctionnalités du langage Go, telles que la goroutine et le canal, afin que le programme puisse traiter efficacement les fichiers volumineux et éviter les fuites de mémoire et les plantages du programme. Bien que cet article présente un contenu relativement basique, ces méthodes peuvent être appliquées au traitement de fichiers volumineux pendant le développement, améliorant ainsi les performances et l'efficacité du programme. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelles sont les vulnérabilités de Debian OpenSSL Quelles sont les vulnérabilités de Debian OpenSSL Apr 02, 2025 am 07:30 AM

OpenSSL, en tant que bibliothèque open source largement utilisée dans les communications sécurisées, fournit des algorithmes de chiffrement, des clés et des fonctions de gestion des certificats. Cependant, il existe des vulnérabilités de sécurité connues dans sa version historique, dont certaines sont extrêmement nocives. Cet article se concentrera sur les vulnérabilités et les mesures de réponse communes pour OpenSSL dans Debian Systems. DebianopenSSL CONNUTS Vulnérabilités: OpenSSL a connu plusieurs vulnérabilités graves, telles que: la vulnérabilité des saignements cardiaques (CVE-2014-0160): cette vulnérabilité affecte OpenSSL 1.0.1 à 1.0.1F et 1.0.2 à 1.0.2 Versions bêta. Un attaquant peut utiliser cette vulnérabilité à des informations sensibles en lecture non autorisées sur le serveur, y compris les clés de chiffrement, etc.

Comment utilisez-vous l'outil PPROF pour analyser les performances GO? Comment utilisez-vous l'outil PPROF pour analyser les performances GO? Mar 21, 2025 pm 06:37 PM

L'article explique comment utiliser l'outil PPROF pour analyser les performances GO, notamment l'activation du profilage, la collecte de données et l'identification des goulots d'étranglement communs comme le processeur et les problèmes de mémoire. COMMANDE: 159

Comment rédigez-vous des tests unitaires en Go? Comment rédigez-vous des tests unitaires en Go? Mar 21, 2025 pm 06:34 PM

L'article traite des tests d'unité d'écriture dans GO, couvrant les meilleures pratiques, des techniques de moquerie et des outils pour une gestion efficace des tests.

Comment écrire des objets et des talons simulés pour les tests en Go? Comment écrire des objets et des talons simulés pour les tests en Go? Mar 10, 2025 pm 05:38 PM

Cet article montre la création de simulations et de talons dans GO pour les tests unitaires. Il met l'accent sur l'utilisation des interfaces, fournit des exemples d'implémentations simulées et discute des meilleures pratiques telles que la tenue de simulations concentrées et l'utilisation de bibliothèques d'assertion. L'articl

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go? Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go? Mar 10, 2025 pm 03:20 PM

Cet article explore les contraintes de type personnalisé de Go pour les génériques. Il détaille comment les interfaces définissent les exigences de type minimum pour les fonctions génériques, améliorant la sécurité du type et la réutilisabilité du code. L'article discute également des limitations et des meilleures pratiques

Comment utilisez-vous des tests basés sur la table dans GO? Comment utilisez-vous des tests basés sur la table dans GO? Mar 21, 2025 pm 06:35 PM

L'article discute de l'utilisation de tests basés sur la table dans GO, une méthode qui utilise un tableau des cas de test pour tester les fonctions avec plusieurs entrées et résultats. Il met en évidence des avantages comme une amélioration de la lisibilité, une duplication réduite, l'évolutivité, la cohérence et un

Expliquez le but du package de réflexion de Go. Quand utiliseriez-vous la réflexion? Quelles sont les implications de performance? Expliquez le but du package de réflexion de Go. Quand utiliseriez-vous la réflexion? Quelles sont les implications de performance? Mar 25, 2025 am 11:17 AM

L'article traite du package de réflexion de Go, utilisé pour la manipulation d'exécution du code, bénéfique pour la sérialisation, la programmation générique, etc. Il met en garde contre les coûts de performance comme une exécution plus lente et une utilisation de la mémoire plus élevée, conseillant une utilisation judicieuse et la meilleure

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

See all articles