▶GC란 무엇인가? GC는 자바의 메모리 관리 방법 중 하나이다. JVM의 Heap영역에서 동적으로 할당했던 메모리 영역 중 필요없게 된 메모리 영역을 주기적으로 삭제하는 프로세스이다. C/C++에서는 이러한 GC가 없기 때문에 개발자가 수동으로 메모리 할당과 해제를 일일히 해줘야한다. 이러한 언어를 Unmanaged 언어라고 한다. 반대로 자바같이 GC가 알아서 메모리를 관리해주는 언어를 Managed 언어라고 한다. 따라서, GC가 탑재되어 있는 JVM을 사용하는 Java는 메모리 관리를 다 해주기 때문에 개발자 입장에서는 메모리 관리, 메모리 누수(Memory Leak)문제에 대해 신경을 덜 써도 된다는 장점이 있다. 하지만 단점도 있는데, 개발자가 메모리가 언제 해제되는지 정확하게 알 수 없다. ..
전체 글
1.GitHub Repository 만들기 우측상단 NEW를 클릭해준다. 이름을 적어주고 이 Repository를 공개하고 싶으면 Public, 공개하고 싶지 않으면 Private로 체크하고 아래 Create repository를 눌러준다. 이미 깃으로 관리되고 있는 로컬 파일이 있으므로 "or push an existing repository from the command line"을 복사해준다. 그 후 git bash에 입력한다. 만약 성공적으로 입력했다면 이렇게 뜰 것이다. 그 후 github repository페이지를 새로고침하면 이런 화면으로 바뀌었을것이다. 2. 원격 Repository 사용하기 위 사진에서 CODE 버튼을 누르면 이렇게 복사할 수 있는 링크가 뜬다. 만약 이 Reposi..
▶배열이 나타난 이유 옛날옛날... 선배님들은 변수를 이용해서 메모리에 값을 할당하고 CPU에게 계산을 시켰다. 하지만 문제가 생겼다. 메모리에 저장해야하는 값이 많아지면서 변수의 수도 많아지게 된것이다. 예를들어 이번 달 사용한 식비를 구하고싶으면 이번달 1일부터 마지막날까지의 식비를 다 더해줘야하므로 대충 30개의 변수가 필요하다. 선배님들은 어떻게 하면 변수를 많이 안쓰고 같은 종류의 데이터를 쉽고 효율적으로 메모리에 저장할 수 있을지를 고민했고, 그렇게 나오게 된 개념이 배열임. ▶배열의 정의와 성질 배열은 같은 종류의 데이터를 모아서 메모리에 순서대로 저장하는 기법이다. 배열은 요소(element)와 인덱스로 구성되어있다. 요소는 배열안에 담겨있는 하나하나의 요소를 말한다. 배열의 성질 k번째 ..
▶자바 프로그래밍을 공부하는 이유 많고 많은 언어 중에 자바를 왜 공부해야 할까? 자바는 백엔드에서 가장 많이 쓰이는 언어이기 때문이다.(Spring Boot) Node.js, Next.js 등 자바스크립트 언어를 기반으로 한 백엔드도 요즘 매우 많지만 자바스크립트보다 자바의 역사가 더 오래되었고 안정성도 더 뛰어나기 때문에 대기업에서 많이 채택한다. ▶자바 언어의 특징 객체지향 언어 자바는 느리지만, 버전업이 되면서 다른 언어들의 장점들을 흡수하고 있다. 람다(Lambda) : 함수형 프로그래밍 Stream API : 람다 표현식과 메서드 참조 등의 기능과 결합해서 매우 복잡하고 어려운 데이터 처리 작업을 쉽게 조회하고 필터링하고 변환하고 처리할 수 있도록 한다. 병렬프로그래밍 : 여려개의 CPU코어에..
▶깃허브란? 깃허브는 소프트웨어 개발 프로젝트를 위한 소스코드를 관리해주는 원격 서비스이다. 즉, 깃을 활용해서 짠 코드를 공유할 수 있는 공간이다. 깃과 달리 깃허브는 웹그래픽 기반의 도구이기 때문에 서비스를 더 직관적으로 이해할 수 있다. ▷깃허브에서는 무엇을 할 수 있을까? 깃허브에는 소스코드 열람, 버전관리, SNS기능도 있다. 따라서 1. 원격 저장소에서 git을 사용가능하고 2. 인터넷만 연결 되어있다면 누구나 쉽게 소스코드에 접근할 수 있으므로 협업 프로젝트에 용이하고 3. 자신의 개발 이력을 깃허브에 남겨서 관리할 수 있고 4. 다른 사람의 소스를 살펴보고, 오픈소스에 참여 할 수도 있다. ▶GitHub 시작하기 GitHub를 시작하려면 우선 GitHub에 가입해야한다. https://gi..
▶충돌이 왜 발생해? 충돌이 발생하는 이유는 각각 branch에서 수정한 위치가 같아서 git이 둘중에 뭘로 받아들여야 할 지 몰라서 발생한다. 예를들어서 이렇게 main 브랜치에서 Tottenham의 라이벌팀 Arsenal뒤에 .을 붙여주고 커밋해주고 충돌1 브랜치로 switch하여 느낌표를 붙여주고 커밋 후 merge를 해주면 이런식으로 충돌이 일어나게된다. 컴퓨터가 뭘 받아들여야 할지 헷갈림. ▶merge 충돌 해결하기 이러한 충돌을 해결하는건 간단하다. 바로 컴퓨터한테 뭘 어떻게 할지를 알려주고 저장하면 된다. 위에 사진을 보면 4가지 선택지가 나타난다. 그 중 한가지를 골라 저장 후 커밋해주면 해결된다. 하나를 고르고 커밋해주면... 이렇게 main|MERGING 에서 main으로 다시 돌아오게..