Go (프로그래밍 언어)

위키백과, 우리 모두의 백과사전.
이동: 둘러보기, 검색
Go
Golang.png
패러다임 컴파일 언어, 병행 프로그래밍, 명령형 언어, 구조적 언어
발표년도 2009년 11월
설계자 로버트 그리즈머
롭 파이크
켄 톰슨
개발자 구글
최근 버전 1.8
자료형 체계 strong, static typing
주요 구현체 gc (8g, 6g, 5g), gccgo
영향을 받은 언어 C, Limbo, Modula, Newsqueak, Oberon, 파스칼
운영 체제 리눅스, OS X, FreeBSD, MS 윈도, 플랜 9
라이선스 BSD 라이선스
웹사이트 http://golang.org

Go는 구글이 개발한 프로그래밍 언어이다. 가비지 컬렉션 기능이 있고, 병행성(concurrent)을 잘 지원하는 컴파일 언어다.

Go의 초기 디자인은 2007년 9월 21일에 로버트 그리즈머, 롭 파이크, 켄 톰슨인페르노 분산 운영체제와 관련된 작업을 하다가 시작되었다. 화이트 보드에 새로운 언어에 대한 스케치를 하면서 초기 20% 파트타임 프로젝트로 시작하였다가 2008년 1월 켄 톰슨이 C 코드를 만들어내는 컴파일러를 만들기 시작했고, 2008년 중반 풀타임 프로젝트로 승격되었다. 2008년 5월 이안 테일러가 Go 스펙의 초안을 이용해서 GCC 프론트엔드를 만들기 시작했고, 2008년 말 러스 콕스가 참여하면서 프로토타입에서 실질적인 언어와 라이브러리들을 만들기 시작했다. 2009년 11월 10일에 리눅스Mac OS X 플랫폼을 대상으로 공식 발표되었다. Go가 처음 런칭되었을 때는 실무적인 소프트웨어를 만들기에는 준비가 좀 덜 된 상태였지만, 2010년 5월 롭 파이크는 구글에서 실제로 사용되고 있는 부분이 있다고 공개적으로 알리게 되었다.

역사[편집]

2009년 11월에 Go가 발표되었다. 구글의 생산 시스템 중 일부 및 기타 기업들에 사용되고 있다. [1]

2개의 주요 구현체가 존재한다:

gc 툴체인은 버전 1.5 이후로 셀프 호스팅되고 있다.[5]

Go는 다른 언어의 긍정적인 특징들을 유지하면서 공통이 되는 문제들을 해결할 새로운 프로그래밍 언어를 설계하기 위해 구글의 엔지니어 Robert Griesemer, Rob Pike, 켄 톰프슨에 의해 실험적으로 시작되었다. 이 새로운 언어는 다음의 기능을 포함할 작정이었다:[6]

  • 정적 타이핑 및 대형 시스템으로의 스케일 가능할 것 (마치 자바C++처럼)
  • 너무 많은 필수적인 키워드와 반복 없이도 생산적이고 가독성이 좋을 것[7] (동적 언어와 같이 가벼움)
  • 통합 개발 환경이 필요하지 않지만 지원도 가능할 것
  • 네트워킹 및 다중 처리를 지원할 것

나중의 인터뷰에서, 언어 설계자 3명 모두 자신들이 C++의 복잡성을 싫어하며 이로 인해 새로운 언어를 설계하는 계기가 되었다고 언급하였다.[8][9][10]

Go 1.0은 2012년 3월에 출시되었다.[11]

목적[편집]

Go는 정적 타입 컴파일 언어의 효율성과 동적 언어처럼 쉬운 프로그래밍을 할 수 있도록 하는 것을 목표로 한다. 또다른 목적은:

  • 안전성 : 타입 안전성과 메모리 안전성
  • 병행성과 통신을 위한 훌륭한 지원
  • 효과적인 가비지 컬렉션
  • 빠른 컴파일

설명[편집]

Go의 문법은 대체로 C와 비슷하다: 코드 블록들은 중괄호로 둘러싸고 for, switch, if를 포함한 일반적인 제어구조를 가지고 있다. C와 다르게, 한 라인 끝의 세미콜론은 필수가 아닌 옵션이다. 변수 선언은 다르게 작성되고 대개 옵션이다. 형변환은 명시적으로 해야 한다. 병행성 프로그래밍을 다루기 위해 goselect 키워드가 사용된다. 새로운 타입은 map, 유니코드 문자열, 배열 slice, 그리고 내부 쓰레드 통신을 위한 channel이 있다.

Go는 그리 좋지 않은 하드웨어에서도 빠르게 컴파일될 수 있도록 디자인되었다. Go는 가비지 컬렉션이 되는 언어이다. 병행성(concurrency)와 관련된 Go의 구조적인 규칙들(channel과 선택적인 channel input들)은 Tony Hoare의 CSP로부터 가져온 것이다.

C++이나 Java에 있는 기능들 중 타입 상속, 제너릭, assertions, 메서드 오버로딩, 포인터 연산은 Go에서 포함하고 있지 않다. Go를 만들고 있는 개발자들은, 제너릭 등은 급하진 않지만 어느 시점에는 기능이 들어갈 거라고 한다.

병행성[편집]

Go를 이용해 프로그램들이 서로 소통하면서 상태를 공유하는 동시성(concurrency) 프로그램을 쉽게 만들 수 있다. [12][13][14] 동시성이란 멀티쓰레딩, 병렬 컴퓨팅 뿐 아니라, 비동기성 입출력 또한 포함한다. 예를 들어, 이벤트 기반 서버와 같이, 데이터베이스나 네트워크 작업과 같이 시간이 많이 걸리는 연산을 하는 동안 프로그램이 다른 일을 하는 것을 말한다. [15]

언어 도구[편집]

Go는 수많은 언어 배포판들과 동일한 종류의 디버깅, 테스트, 코드 검사 도구들을 포함하고 있다. 그 중에 Go 배포판은 다음을 포함한다:

  • go build: 소스 파일 자체의 정보만을 사용하여 Go 바이너리를 빌드한다. 별도의 makefile은 없다.
  • go test: 유닛 테스트 및 마이크로벤치마크
  • go fmt: 코드 서식 지정
  • go get: 원격 패키지의 검색 및 설치
  • go vet: 코드 내의 잠재적인 오류를 찾아내는 정적 분석기
  • go run: 코드를 빌드하고 실행하는 바로 가기
  • godoc: 문서를 표시. HTTP를 통해 문서 확인.
  • gorename: 변수, 함수 등을 형 안전(type-safe) 방식으로 이름 변경
  • go generate: 코드 생성기를 호출하는 표준 방식

프로파일링 및 디버깅 지원, 런타임 인스트루먼테이션(이를테면 가비지 컬렉션 일시 정지 등을 위해) 및 레이스 컨디션 테스터(race condition tester)도 포함한다.

예제[편집]

아래는 Go로 만든 Hello, World 프로그램이다.

package main
 
import "fmt"
 
func main() {
        fmt.Println("Hello, World")
}

Go는 for loop과 같은 경우 각 항목을 구분하는 용도로 세미콜론(;)을 사용하고 그 외에는 대부분 자동으로 세미콜론이 컴파일 시 들어가게 된다. 중요한 것은 if와 같은 경우 if가 있는 그 라인에 중괄호({)가 반드시 같이 들어가야 한다는 것이다.

병행의 예[편집]

package main

import (
    "fmt"
    "time"
)

func readword(ch chan string) {
    fmt.Println("Type a word, then hit Enter.")
    var word string
    fmt.Scanf("%s", &word)
    ch <- word
}

func timeout(t chan bool) {
    time.Sleep(5 * time.Second)
    t <- true
}

func main() {
    t := make(chan bool)
    go timeout(t)

    ch := make(chan string)
    go readword(ch)

    select {
    case word := <-ch:
        fmt.Println("Received", word)
    case <-t:
        fmt.Println("Timeout.")
    }
}

Go를 사용하는 프로젝트[편집]

Go로 작성된 일부 저명한 오픈 소스 소프트웨어는 다음과 같다:

  • 라이트닝 네트워크: 비트코인 네트워크.
  • CockroachDB: SQL 데이터베이스.
  • 도커: 리눅스 컨테이너를 배치시키는 도구들의 집합
  • Doozer: 매니지드 호스팅 제공자 헤로쿠의 락 서비스
  • Geth 소프트웨어: 이더리움 프로토콜 블록체인 기술을 이용한 golang 구현체로서, 전 세계 공유 컴퓨팅 플랫폼을 구현한다.[16]
  • Gogs: 셀프 호스팅 Git 서비스.[17]
  • InfluxDB: 고가용성과 고성능 요구사항을 필요로 하는 오픈 소스 데이터베이스.
  • Juju: 캐노니컬이 주관하는 서비스 오케스트레이션 도구. (우분투 리눅스의 패키저)
  • Kubernetes 컨테이너 관리 소프트웨어
  • 오픈시프트: 클라우드 컴퓨팅 플랫폼 (레드햇이 서비스함)
  • 패커(Packer): 여러 플랫폼을 대상으로 하나의 소스 구성을 통해 동일한 머신 이미지를 만드는 도구.
  • 스내피(Snappy): 우분투 터치용 패키지 관리자 (캐노니컬 제작)
  • Syncthing: 오픈 소스 파일 동기화 클라이언트/서버 애플리케이션

Go를 사용한 일부 저명한 오픈 소스 소프트웨어 프레임워크는 다음과 같다:

  • Beego: 고성능 웹 프레임워크
  • Martini: 웹 애플리케이션/서비스용 패키지.
  • 고릴라: Go용 웹 툴킷.
  • Enduro/X ASG: 클러스터 미들웨어, 애플리케이션 서버, 분산 트랜잭션, 멀티 프로세싱 프레임워크.

이 밖에도 Go를 사용하는 저명한 기업 및 사이트는 다음과 같다(일반적으로 다른 언어와 함께 사용):[18][19]

각주[편집]

  1. “Go FAQ: Is Google using Go internally?”. 2013년 3월 9일에 확인함. 
  2. “Google’s In-House Programming Language Now Runs on Phones”. 《wired.com》. 2015년 8월 19일. 
  3. “FAQ: Implementation”. 《golang.org》. 2010년 1월 16일. 2010년 1월 18일에 확인함. 
  4. “Installing GCC: Configuration”. 2011년 12월 3일에 확인함. Ada, Go and Objective-C++ are not default languages 
  5. “Go 1.5 Release Notes”. 2016년 1월 28일에 확인함. The compiler and runtime are now implemented in Go and assembler, without C. 
  6. Pike, Rob (2010년 4월 28일). “Another Go at Language Design”. 《Stanford EE Computer Systems Colloquium》. Stanford University.  Video available.
  7. “Frequently Asked Questions (FAQ) - The Go Programming Language”. 《golang.org》. 2016년 2월 26일에 확인함. 
  8. Andrew Binstock (2011년 5월 18일). “Dr. Dobb's: Interview with Ken Thompson”. 2014년 2월 7일에 확인함. 
  9. Pike, Rob (2012). “Less is exponentially more”. 
  10. Robert Griesemer (2015). “The Evolution of Go”. 
  11. “Release History”. 
  12. Share by communicating - Effective Go
  13. Andrew Gerrand, Share memory by communicating
  14. Andrew Gerrand, Codewalk: Share memory by communicating
  15. Rob Pike의 Concurrency is not Parallelism 참고.
  16. Hayes, Adam. “How to Mine Ethereum on Your Computer”. 
  17. “Gogs - Go Git Service - a painless self-hosted Git service”. 
  18. Erik Unger, The Case For Go
  19. Andrew Gerrand, Four years of Go, The Go Blog
  20. Hugues Bruant. “AeroFS - A little golang way”. 《AeroFS》. 
  21. “Chango”. 《GitHub》. 
  22. John Graham-Cumming, Go at CloudFlare
  23. John Graham-Cumming, What we've been doing with Go
  24. “Go at CoreOS”. 
  25. “Couchbase”. 《GitHub》. 
  26. Patrick Lee, Open Sourcing Our Go Libraries, 7 July 2014.
  27. “dl.google.com: Powered by Go”. 《golang.org》. 
  28. Matt Welsh, Rewriting a Large Production System in Go
  29. David Symonds, High Performance Apps on Google App Engine
  30. “Mongo DB”. 《GitHub》. 
  31. “The Netflix Tech Blog: Application data caching using SSDs”. 
  32. “Google+ post by Don Dwoske”. 《Google+》 (영어). 2017년 1월 21일에 확인함. 
  33. Steven Sacks. “Search & Advances”. 《plug.dj tech blog》. 
  34. “ReplicatedHQ”. 《GitHub》. 
  35. Tim Jenkins. “How to Convince Your Company to Go With Golang”. 《SendGrid's Email Deliverability Blog》. 
  36. Peter Bourgon, Go at SoundCloud
  37. “Go at Google I/O and Gopher SummerFest - The Go Blog”. 《golang.org》. 
  38. TWSTRIKE. “CoyIM”. 《ThoughtWorks STRIKE team》. 
  39. Rhys Hiltner, Go’s march to low-latency GC, 5 July 2016.
  40. “How We Built Uber Engineering’s Highest Query per Second Service Using Go”. 《Uber Engineering Blog》 (영어). 2016년 3월 2일에 확인함. 

바깥 고리[편집]