golang copy

package main

import (

    "fmt"

    "io"

    "os"

    "path/filepath"

    "strconv"

)

var BUFFERSIZE int64

func Copy1(src, dst string, BUFFERSIZE int64) error {

    sourceFileStat, err := os.Stat(src)

    if err != nil {

        return err

    }

    if !sourceFileStat.Mode().IsRegular() {

        return fmt.Errorf("%s is not a regular file", src)

    }

    source, err := os.Open(src)

    if err != nil {

        return err

    }

    defer source.Close()

    _, err = os.Stat(dst)

    if err == nil {

        return fmt.Errorf("file %s already exists", dst)

    }

    destination, err := os.Create(dst)

    if err != nil {

        return err

    }

    defer destination.Close()

    if err != nil {

        panic(err)

    }

    buf := make([]byte, BUFFERSIZE)

    for {

        n, err := source.Read(buf)

        if err != nil && err != io.EOF {

            return err

        }

        if n == 0 {

            break

        }

        if _, err := destination.Write(buf[:n]); err != nil {

            return err

        }

    }

    return err

}

func Copy(src, dst string) (int64, error) {

    sourceFileStat, err := os.Stat(src)

    if err != nil {

        return 0, err

    }

    if !sourceFileStat.Mode().IsRegular() {

        return 0, fmt.Errorf("%s is not a regular file", src)

    }

    source, err := os.Open(src)

    if err != nil {

            return 0, err

    }

    defer source.Close()

    destination, err := os.Create(dst)

    if err != nil {

        return 0, err

    }

    defer destination.Close()

    nBytes, err := io.Copy(destination, source)

    return nBytes, err

}

func main() {

    if len(os.Args) != 4 {

        fmt.Printf("usage: %s source destination BUFFERSIZE\n",

            filepath.Base(os.Args[0]))

        os.Exit(1)

    }

    source := os.Args[1]

    destination := os.Args[2]

    BUFFERSIZE, _ = strconv.ParseInt(os.Args[3], 10, 64)

    fmt.Printf("Copying %s to %s\n", source, destination)

    err := Copy1(source, destination, BUFFERSIZE)

    if err != nil {

        fmt.Printf("File copying failed: %q\n", err)

    }

}


作者:holdtom
鏈接:https://www.imooc.com/article/271446
來源:慕課網(wǎng)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • The go is passing by value.That is, if I doa = ba is a co...
    Sea_Shore閱讀 699評(píng)論 0 0
  • 之前用 copy 不多,本以為它是個(gè)很方便的函數(shù),沒想到在做練習(xí)題時(shí)竟還是被它坑了。是我對(duì)他期望太多了。 基本認(rèn)識(shí)...
    Robin92閱讀 22,046評(píng)論 1 6
  • 將兩個(gè)slice合并到一個(gè)總的slice過程中使用copy 輸出: 發(fā)現(xiàn)這個(gè)有問題,不是自己想要的:代碼修改為: ...
    TTWP_8閱讀 1,442評(píng)論 0 1
  • golang copy函數(shù)用于在兩個(gè)slice之間進(jìn)行拷貝數(shù)據(jù),其拷貝數(shù)據(jù)的長(zhǎng)度為 len(dst)與len(sr...
    sanerersan閱讀 7,987評(píng)論 0 0
  • 注:本文是對(duì)golang-101-hacks中文翻譯。內(nèi)置函數(shù)copy定義如下: func copy(dst, s...
    _羊羽_閱讀 133評(píng)論 0 0

友情鏈接更多精彩內(nèi)容