오늘 한 일

  • 오늘은 지난 주에 이어 Go를 더 봤다.
  • 별 문제 없이 잘 흘러가고 있다 싶을 때, 슬라이스를 만났고.. 처음에는 이해가 좀 된다 싶었다. 이 링크를 만나기 전까지는.
  • (이건 나 혼자만 이해할 수 있는 끄적임..ㅠㅠ) 슬라이스의 length와 capacity가 어떻게 다른지, 무슨 차이가 있는지도 알겠고, append 할 때 append 하려는 요소의 개수가 슬라이스의 capacity를 초과하는 경우 capacity가 기존의 2배로 늘어난다는 것도 알겠다. 그런데 length = 0, capacity = 0 인 슬라이스에 0, 1, 2, 3, 4를 append 하면 왜 갑자기 length = 5, capacity = 6이 되냐고.. 0, 1, 2, 3을 append 할 때까지는 length와 capacity가 같은데. 마침 허들을 걸어주신 Kei님께 여쭤봤더니, 메모리 단편화를 지양하고 메모리 최적화를 달성하기 위한 Go만의 방법이 작용한 결과일 것이라는 답변을 받았다. 그리고 지금 당장 깊게 파고들어야 하는 문제도 아닌 것. 그래서 여기다 keep 하고 넘어간다 ㅠ.ㅠ 날코딩이긴 한데 미래의 나에게 맡긴다 흑흑.. 애초에 궁금했던 건 아래 코드 중 2번 케이스에 해당한다(capacity가 1 -> 2 -> 3 -> 4 -> 6 -> 8 순서로 늘어난다). 1번은 2번처럼 날코딩이 아닌 방식으로 해보려고 배열의 배열을 생성해서 시작했더니 capacity가 1 -> 2 -> 4 -> 8 순서로 늘어난다. 미래의 내가 다시 돌아왔을 때 '얘는 뭐 이런 쉬운 걸 고민해ㅋㅋ'라고 했으면 좋겠다. 제발
// https://go-tour-ko.appspot.com/moretypes/15
// https://go.dev/play/p/OKtCFskbp2t

package main

import "fmt"

func main() {

	fmt.Println("##### 1번 케이스 #####")

	var array [8][]int
	for i := 0; i < 8; i++ {
		for j := 0; j <= i; j++ {
			array[i] = append(array[i], j)
		}
		printSlice(array[i])
	}

	/*
	len=1 cap=1 [0]
	len=2 cap=2 [0 1]
	len=3 cap=4 [0 1 2]
	len=4 cap=4 [0 1 2 3]
	len=5 cap=8 [0 1 2 3 4]
	len=6 cap=8 [0 1 2 3 4 5]
	len=7 cap=8 [0 1 2 3 4 5 6]
	len=8 cap=8 [0 1 2 3 4 5 6 7]
	*/

	fmt.Println("##### 2번 케이스 #####")
	var a, b, c, d, e, f, g, h []int

	a = append(a, 0)
	printSlice(a)
	
	b = append(b, 0, 1)
	printSlice(b)

	c = append(c, 0, 1, 2)
	printSlice(c)

	d = append(d, 0, 1, 2, 3)
	printSlice(d)

	e = append(e, 0, 1, 2, 3, 4)
	printSlice(e)

	f = append(f, 0, 1, 2, 3, 4, 5)
	printSlice(f)

	g = append(g, 0, 1, 2, 3, 4, 5, 6)
	printSlice(g)

	h = append(h, 0, 1, 2, 3, 4, 5, 6, 7)
	printSlice(h)

	/*
	len=1 cap=1 [0]
	len=2 cap=2 [0 1]
	len=3 cap=3 [0 1 2]
	len=4 cap=4 [0 1 2 3]
	len=5 cap=6 [0 1 2 3 4]
	len=6 cap=6 [0 1 2 3 4 5]
	len=7 cap=8 [0 1 2 3 4 5 6]
	len=8 cap=8 [0 1 2 3 4 5 6 7]
	*/
}

func printSlice(s []int) {
	fmt.Printf("len=%d cap=%d %v\n", len(s), cap(s), s)
}
  • Kei님의 제안으로 태초마을 주민이 되었다. 나도 이제 포켓몬 트레이너...!? 이것과 관련해서 내일 미팅부터 시작해서 뭔가 펼쳐질 것 같은데 재밌을 것 같아 기대도 되고, 내가 뭐라도 할 수 있을까 싶어 걱정도 된다.
  • 전화영어 신청했다! 영어 공부도 할 거야, 이제.. 나만 영어 못할 수 없어ㅠㅠ

오늘 배운 것

  • 궁금한 게 있으면 바로 질문하고, 이걸 지금 계속 고민할 필요가 있는 것인지 짚고 넘어가도록 하자.

오늘 한 일

  • 오늘 아침은 어제 업무 설명을 들은 팀의 스크럼에 참여했다. 줌이나 구글밋이 아닌 미로에서 스크럼 보드를 보면서 바로 진행하는 방식이었는데, 접속부터가 잘 안 돼서 애를 먹었다. 결국 크롬을 버리고 사파리로 갈아탔더니 극적으로 2분 늦게 들어갈 수 있었다.
  • 미로는 스크럼 보드도 보고 때로는 작성도 하면서 미팅도 하고, 이걸 한 번에 다 할 수 있다는 장점이 있었지만 한 가지 불편한 건 줌에서처럼 말하고 있는 사람의 카메라에 포커스 되는 기능이 없었다는 점이었다. 아직 어느 분이 어떤 목소리를 가졌는지 파악하지 못한 나로서는 입을 움직이고 있는 주인공을 찾아다니느라 스크럼 내내 혼자 바빴다. 뉴비의 고충
  • 어제 뷰 공부하다가 남겨둔 한 챕터를 마저 봤다. 부모 컴포넌트에서 자식 컴포넌트로는 데이터를 props로 넘기고, 자식이 부모의 데이터를 변경하려면 emit을 사용하면 된다. 하지만 만약 자식이 부모를 거치지 않고 더욱 상위의 조상 컴포넌트가 가진 데이터를 건드리려고 한다면? 자식에게서 발생한 이벤트를 eventBus에 태우고, 조상 컴포넌트가 eventBus로부터 해당 이벤트를 감지하여 꺼내오면 된다.
  • 그리고 좀 더 심화 자료를 찾아볼까 생각하던 찰나, 세훈님이 앞으로 공부하면 좋을 키워드들을 던져주셨다. 어차피 한 번쯤 만져봐야 하는 것들이라면 이번 기회에 조금씩이라도 봐 놓는 게 좋을 것 같아서 패기 넘치게 바로 Go로 넘어갔다. 패기가 과해
  • Go를 설치한 후 구글링해 가면서 환경변수도 적당히 설정했다. 연습용 프로젝트 파일을 생성한 후 vscode 터미널에서 go run main.go 명령어로 실행하려니 자꾸 GOPATH, 또는 GOPATH와 GOROOT 관련한 에러가 떴다. 그런데 특이한 건 맥 터미널에서 같은 경로로 들어가 똑같은 명령어를 입력하면 내가 원하는 결과가 문제없이 출력되었다. vscode extension도 건드려보고, 환경변수도 다시 이리저리 바꿔보고, .mod 파일을 만들었다 없앴다 디렉토리를 바꿔봤다가 별 짓을 다 해봐도 계속 똑같았다. 맥 터미널에서는 돌아가는데 vscode 터미널에서는 돌아가지 않았다.
  • 하다하다 지쳐서 처음부터 다시 해보기로 했다. 프로젝트 디렉토리와 ~/go 디렉토리를 전부 삭제해버렸다. 상현님이 노마드 코더 강의 영상이 잘 되어 있다고 해서 원래는 영상 내용을 볼 생각으로 들어갔다가 거기 달린 코멘트 하나를 보고 무심코 따라했는데 성공해버렸다. vscode에서 설치하라는 extension들을 안 깔아서 그랬던 건지 아직 정확히는 원인을 파악하지 못했다.
  • Go를 심폐소생하기 전에, 시니어 분들이 진행하시는 테크 세션에 참석했다가 또 다른, 셀러들이 쉽고 직관적으로 서비스를 이용할 수 있도록 전체적인 프로세스를 관리하는 팀의 업무 설명을 들었고, 그러다 보니 나의 죽어가던 Go를 겨우 살려냈을 때는 이미 오후 6시였다..
  • 남은 한 시간 동안 공식문서를 들여다 봤는데, 자바스크립트랑은 문법이 비슷하면서도 다른 면이 있어서 오히려 신기하고 재밌었다.

오늘 배운 것

  • 아래 링크 코멘트의 2번까지는 이미 잘 되었으므로 나는 3번부터 순서대로 시도했다. 2번에서 go env를 입력하면 나오는 GOPATH는 '/Users/[username]/go', GOROOT는 '/usr/local/go'였다.
 

All Courses – 노마드 코더 Nomad Coders

초급부터 고급까지! 니꼬쌤과 함께 풀스택으로 성장하세요!

nomadcoders.co

오늘 한 일

  • 오늘은 어제 업무 소개를 들었던 팀의 스크럼에 참석했다. 사무실에서 온라인 스크럼이라니 새로웠다. Miro에 현황판 같은 게 있고 각자가 프로그레스를 나타내는 상황판을 가지고 있었다. 아직 자세한 내용은 잘 모르지만 체계적으로 진행되는 것 같았다.
  • 그리고 어제에 이어, 오늘은 셀러들의 디지털 마케팅과 온보딩을 담당하는 팀의 업무 설명을 들었다. PO님이 재택 중이셔서 미팅룸에 다같이 모여서 온라인으로 미팅을 했다. 어제와는 확연히 다른 종류의 업무가 진행되는 걸로 보아 팀별로 색깔이 확실해 보였다.
  • 어제 Docker로 돌려본 vms(가 무슨 뜻인지 모르겠네 그러고 보니.. 내일 물어봐야지) 페이지를 좀 더 들여다보려고 했는데, 뷰 예습하려고 문서 잠깐 들여다보다가 너무 재밌어서 그만 하루종일 시간을 홀랑!
  • 뷰 공부를 하려면 Vue.js devtools부터 깔고 시작하라는 귀중한 조언을 받들어 일단 설치를 했다. 처음에는 리액트 개발자 도구랑 비슷한 역할일 테니 안 켜보고 있었다. 그러다 부모 컴포넌트가 가진 데이터를 자식이 함수로 건드리는(emit) 순간부터 그때그때 데이터를 확인하는 게 좋을 것 같아 열어봤는데, 왜인지 크롬 개발자 도구에 모두가 가지는 그 Vue 탭이 없었다. 나만 없어 Vue...
  • 당황도 잠시, 급한 대로 구글링을 시작했는데 생각보다 같은 문제를 가진 사람들이 많았다. 크롬을 껐다 켜라, 껐다 켜서 강력 새로고침을 해라, 몇 번 더 껐다 켜라, 개발자도구에 적용한 테마를 풀고 Light로 바꾼 다음 개발자도구를 새로고침해라 등등... 쭉 읽어보면 그다지 실행하기 까다로운 방법들은 아니었지만 나는 그냥 안 먹혔다.

오늘 배운 것

  • 시간이 흘러흘러 겨우겨우 찾은 해결책은 이랬다: 1. 적용한 뷰 CDN이 개발 버전이 아니라 상용 버전이었으므로 해당 url을 개발 버전으로 바꿔주고, 2. 개발자 도구의 톱니바퀴 모양 설정 버튼을 눌러서 Preferences > Appearance > Theme을 System preference가 아닌 Light로 바꿔주고, 3. Settings를 x 버튼을 눌러 종료하고 나서 Reload하라는 배너가 떠 있으면 버튼을 클릭해 새로고침해주고, 4. 크롬을 강력 새로고침(맥 기준 command + shift + r) 해준다. 그러면 모두가 있고 나만 없던 Vue 탭이 짜잔! Vue 탭이 생긴 걸 확인한 다음에는 다시 테마를 system preference로 바꿔도 무방하다.
 

Vue.js is detected but the Vue Panel is not showing · Issue #1209 · vuejs/devtools

Version 5.3.3 Browser and OS info Chrome 83.0.4103.97 / Windows 10 Steps to reproduce After enter the page Vue.js is detected on this page. The message "Open DevTools and look for the Vue pane...

github.com

오늘 한 일

  • 오늘도 계속해서 기본 환경 설정을 진행했다. (터미널에 oh-my-zsh, agnoster theme 적용하기 포함)
  • 터미널에 vi 명령어를 입력하면 터미널에서 바로 에디터를 사용할 수 있다는 건 알고는 있었다. 하지만 지금까지는 에디터를 사용해야 할 때 vscode로 해당 파일을 열어서 편집했으므로 구체적으로 vi 명령어로 어떻게 할 수 있다는 건지는 몰랐다. 오늘 온보딩 가이드를 따라가다가 vscode로는 열기가 어려워 vi 명령어를 통해 처음으로 vim 에디터를 사용해 보았다.
  • 그리고 아주아주 기본적일지언정 말로만 듣던 바로 그 Docker를 실행해보게 되었다. 프론트 서버 딱 하나만 localhost:3000 포트로 돌려본 나에게, Docker로 서버와 DB를 한 번에 돌리는 신기하고 놀라운 일이 일어났다. 심지어 고래 너무 귀여워 윽
  • 그리고 또 오늘은 셀러들의 편의 증진 및 옴니채널에 주력하는 팀의 업무와 구성에 대한 설명을 들었다. 정말 너무 상세하고 친절하게 설명해주신 PO님, 설명만 하셨을 뿐인데 너무 멋지셨다. 질문 있냐고 하셨는데, 제 블로그니까 감히 뒤늦게 고백하는 거지만, 속으로 감탄하느라 바빠서 질문거리 생각도 못했어요..

오늘 배운 것

  • oh-my-zsh는 맥의 기본 터미널에 바로 적용해줄 수도 있고, iTerm2라는 터미널을 설치한 후 적용해줄 수도 있다. 나는 오늘 회사에서는 iTerm2를 설치해서 적용했지만 어떤 링크를 참고해서 했는지를 다시 찾지 못해서, 내 개인 맥북에 iTerm2 없이 기본 터미널에 적용했을 때 참고한 링크를 가져와 봤다. 반드시 적용해야 하는 건 아니지만 한번 적용하고 나면 다시는 내 마음이 이전으로는 돌아갈 수 없다. 갑자기 생각났는데, 누구라고 말은 안 하겠지만 누군가에게 공유했을 때 욕과 칭찬을 동시에 들었다. 왜 이제 알려줬냐, 너무 마음에 든다
 

Terminal. 근데 이제 Oh-My-Zsh을 곁들인

ㅎ ㅡ ㅁ......딱히 불편함을 느끼고 있던건 아니어서..그냥 살고 있었는데..!! 그냥 갑자기 '그래 그 유명하다던 oh-my-zsh을 사용해봐야겠다'라는 생각이 들어..사용해보려고 합니다. 카탈리나부터

zeddios.tistory.com

  • 터미널에서 vi 명령어로 에디터를 실행했다면, 편집 모드로 들어가기 위해서는 i 또는 o 등등 명령어를 다시 한 번 입력해줘야 한다. 편집이 완료되면 저장 후 종료할 때는 :wq 입력 후 enter.
 

[리눅스, 유닉스]vi (vim) 편집기 기본 사용법, 명령어, 단축키, 동작법 & 문제

[리눅스 / 유닉스 / 셸 프로그래밍 완전 정복 목차 바로가기 ] 가장 많이 사용되고, 꼭 알아야 하는 ~ vi 편집기 사용하기 vi는 다른 편집기들과는 다르게 모드형 편집기라는 특징이 있습니다. (명

jhnyang.tistory.com

  • Docker가 도대체 뭐냐, 한 마디로 정의하고 싶다 할 때 참고할 만한 AWS의 설명이다.
 

Docker란 무엇입니까? | AWS

Q: Docker로 어떤 작업을 할 수 있습니까? Docker를 사용하면 환경에 구애받지 않고 애플리케이션을 신속하게 배포 및 확장할 수 있으며 코드가 문제없이 실행될 것임을 확신할 수 있습니다. 이는 Doc

aws.amazon.com

  • Docker로 실행할 여러 개의 컨테이너를 docker-compose.yml 파일 안에 정의하면, 작성 후 docker compose up 명령어로 실행할 수 있다. 해당 파일의 작성 포맷은 아래 공식문서를 참고하면 된다.
 

Overview of Docker Compose

 

docs.docker.com

  • 아, 그리고 로지텍 마우스 사용하다가 마우스 휠이 갑자기 안 먹는 경우 배터리가 얼마 안 남아서 그런 게 아니라면 맥의 Activity Monitor app 실행 후 Logitech Options Daemon 프로세스 종료하고 스크롤 되는지 테스트해보기.

오늘 한 일

  • 일주일 잘 쉬고 다른 회사로 출근했다.
  • 첫날이라 신분증을 가지고 출근해야 하는데, 늦을까 봐 일찍 일어났는데도 집에서 나서려니까 지갑이 없어져서 아침부터 난리난리 북새통이었다. 결국 지갑은 못 찾은 채, 서랍에 넣어뒀던 면허증이 생각나서 그거 하나 달랑 챙겨서 겨우 집을 나섰다. 근데 지갑 화장대에 떡하니 있었고..(말잇못)
  • 새로운 환경에 적응하느라 모든 게 새롭고 정신 없는 가운데 느낀 점: 많은 분이 계셔도 사무실이 조용하다. 제 키보드 소리 왜 이렇게 크게 들리죠...?
  • 모니터와 기타 등등 설치하면서 사무실 자리다운 모습을 갖추고, 맥북 사용을 위한 기본적인 세팅을 하고, 온보딩 가이드를 읽으면서 회사 이메일로 각종 계정을 생성하고, 오늘은 그렇게 시간을 보냈다.
  • 옆 자리에 계신, 오늘 나와 같이 첫 출근한 디자이너 분과 같이 퇴근하게 되었는데 알고 보니 동네 사람...!!!? "어느 쪽으로 가세요?" ➡️ "어? 저도.." ➡️ "어디 사세요?" ➡️ "???저돈데" ➡️ "뭐 타세요?" ➡️ "????????저도.."

오늘 배운 것

  • 모르는 게 있으면 상현님한테 다 물어봐 버리자. ㅎㅎ

지금까지 한 일

  • 가장 최근 게시글 작성일자가 1월 13일? 나 정말 오래 쉬었구나 TIL 그동안 많은 일이 있었지만, 일단 가장 중요한 일로는 퇴사를 꼽을 수 있겠다. 별 이유는 없는데 퇴사를 앞두고는 차마 TIL을 쓸 수가 없었다. 첫 사회생활은 아니었지만 개발자로서는 첫 번째 회사였고, 그런 만큼 여러 모로 애착을 가졌었다.
  • 설 연휴를 겸해 꼬박 일주일을 쉬고 내일이면 새로운 회사로 간다. 막 엄청난 인싸가 아니라서 또 헤매며 적응해 나가야 할 텐데, 완전히 새로운 환경에서, 또 얼마나 더 화려한 삽질을 하게 될지 벌써부터 기대가 된다 엉엉ㅠㅠ
  • 일주일 쉬면서 본격적인 정보처리기사 필기 공부에 착수했다. 사실 이 시험 준비의 계기는 저번 회사에 있다. 그런데 어쩌다 보니 '좋아, 시험 준비를 해야겠다!' → '좋아, 이직을 해야겠다!' → '?...시험 준비 시작...?' → '?!...이직 실행...?!' 순서가 되었다. 그래서 어쩐지 약간 꼬인 것처럼 보인다는 게 함정
  • 공부를 하다 보니 느낀 건데, 언뜻 보면 그냥 이론 공부인데 개념 정리를 하다 보니 '아니, 이게 사실은 이거라고!?' 싶은 것들이 있다. 예를 들면 저번 회사에서 매일 했던 '스크럼' 같은 것들. 그렇다고 이제는 완전히 깨달았다, 이런 건 절대절대절대 아님..어휴 나는 멀었지 멀었어
  • 아무튼 당분간 또 정신없이 보내지 않을까 싶다. 배우는 게 많을 테니 한편으로는 기대도 된다.

오늘 한 일

  • 회사에서는 여전히 디자인 작업 마무리 단계에 머물러 있다. 내일까지 끝...내야 하는데 제발...
  • 퇴근하고 도착한 집에는 맥북이 와 있었다. 일하면서 처음 사용해 본 맥북에 아직 다 적응하지는 못했지만 일단 여러 모로 너무 좋다는 걸 알았기 때문에, 큰맘 먹고 하나 질렀다. 물론 이걸로 주로 코딩을 하겠고, 이제 집에 있던 윈도우 데스크탑은 맥북에서 안 돌아가는 기능을 쓸 때나(증명서 출력...?) 맥북에서 확인하지 못하는 오류를 찾아내고자 할 때나 쓸 것 같다.
  • 맥북을 다시 처음부터 세팅하면서, 그때그때 환경설정하는 방법을 A부터 Z까지 다 적어놔야겠다. 하다가 에러 나면 그것도 적어두고. 분명 몇 달 전 회사 맥북 처음 받고서 거쳐 본 절차이지만 다시 하려니 또 버벅였다. 역시 기록을 해놔야 돼...

여담

  • 나도 Today I Learned 말고 Today I Lived 써 볼 거야!

오늘 한 일

  • 여전히 새로 나온 디자인대로 페이지를 갈아 엎는 중이다. 드롭다운 메뉴 같은 것들이 참 다양한 형태로 여기저기에 만들어지고, 태블릿에서는 각각 따로 나눠진 페이지였던 것들이 모바일에서는 하나로 붙어 나오는 등 갖가지 변화무쌍함을 온몸으로 체감하고 있다.
  • 헤매다 길 잃기 딱 좋은 때로는 구면인데 초면 같은 나의 코드 정리도 좀 해야 되는데 내 손이 느린 건지 할 게 많은 건지 그럴 틈이 안 난다.

오늘 배운 것

  • 오늘은 쉬어가는 의미(이유는 없다)에서 변수명 짓기 사이트 링크를 올린다. 회사 서버 개발자 분이 알려주셨다. 뭐 무조건 검색해서 확인해보고 이대로 변수명을 지어야 한다기보다는, 가끔 단어가 생각이 안 나거나 이런 변수명을 붙여서 이 뜻을 나타내고자 하는 게 괜찮은가 싶을 때 아니면 심심할 때 참고하기 좋다. 검색해보고도 여기서 알려주는 단어를 안 쓸 때도 있다ㅋㅋ 히스토리를 보니 로그가 안 남겨진 지 1년 정도 됐는데 아직 유지보수가 이루어지고 있는 건지는 잘 모르겠다.
 

Curioustore

변수명 짓기, 컬럼명 짓기, 영어약자, 変数名 つけ方, カラム名建てる, 英語の略語, 命名变量, 命名该列, 英文缩写

www.curioustore.com

+ Recent posts