안녕하세요 @jwsohn입니다. 이번 포스팅에서는 코딩을 할 때 쓰는 고정폭 폰트(fixed-width font) 선택에 대해 알아보도록 하겠습니다.
<h2>고정폭 폰트의 필요성 <p dir="auto">코딩을 할 때는 기본적으로 글자의 가로 폭이 일정한 고정폭 폰트(fixed-width font)를 씁니다. 그 이유는 아무래도 터미널(terminal)에서 고정폭 폰트로 코딩을 하던 관습의 영향이 크겠습니다만 고정폭 폰트가 들여쓰기(indentation)와 같은 특성을 가진 소스 코드의 가독성을 높여준다는 이유도 있겠습니다. <p dir="auto">그리고 코딩용 폰트는 1, i, l, | 이나 o, O, 0, @ 등과 같이 비슷하게 생긴 영문자, 숫자, 특수기호의 구분을 명확히 해야 하는 특성이 있습니다. 이것은 코딩을 할 때 한 글자만 틀려도 결과가 다르게 나오는 코딩의 특성 때문입니다. 실제 제 경우 학부시절에 <code>for (j = i + 1; j < n; ++j)를 <code>for (j = 1 + 1; j < n; ++j)로 잘못 적었다가 i와 1을 구분못해 디버깅에 일주일 가까이를 날려 버렸던 경험이 있습니다. <h3>고정폭 폰트의 대표적 예: Courier <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/courier-new.png" alt="Courier New" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/courier-new.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/courier-new.png 2x" /> <p dir="auto">윈도우 운영체제에서 기본으로 제공되는 코딩용 고정폭 폰트는 Courier 폰트가 있습니다. (Courier, Courier new) 타자기(typewriter)에 대표적으로 쓰이는 폰트입니다. <p dir="auto">하지만 아쉽게도 Courier 폰트의 컴퓨터 화면 가독성은 그다지 좋지 않습니다. 그래서 코딩용으로는 Courier외에 다른 폰트들이 많이 쓰이는 편입니다. <h2>고정폭 폰트 소개 <p dir="auto">그렇다면 Courier 이외의 가독성이 좋은 고정폭 폰트는 어떤 것이 있을까요? 여러가지 폰트 중에서 일단 무료, 혹은 상용이지만 쉽게 구할 수 있는 폰트를 우선적으로 알아보도록 하겠습니다. <h3>Dejavu Sans Mono <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/dejavu-sans-mono.png" alt="Dejavu Sans Mono" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/dejavu-sans-mono.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/dejavu-sans-mono.png 2x" /> <p dir="auto">리눅스 시스템에 거의 기본으로 들어가 있는 고정폭 폰트입니다. 원래는 Bitstream 회사에서 개발한 Vera 폰트를 기반으로 하고 있는데 라이센스가 Bitstream Vera 폰트보다 좀 더 자유롭다고 알려져 있습니다. <p dir="auto">무료로 구할 수 있는 고정폭 폰트 중에서는 거의 최상의 가독성을 갖추고 있고, 유니코드까지 지원하는 장점이 있습니다. <ul> <li><span>URL: <a href="https://dejavu-fonts.github.io/" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://dejavu-fonts.github.io/ <li>Ubuntu에서 설치 방법: <code>sudo apt install fonts-dejavu <h4>Hack <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/hack.png" alt="Hack" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/hack.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/hack.png 2x" /> <p dir="auto">Dejavu Sans Mono의 변종입니다. 폰트에 큰 차이는 없지만 0이나 , ; 같은 특수문자의 가독성을 높여서 좀 더 코딩에 특화된 폰트입니다. 제 경우 이 폰트를 코딩 주력으로 쓰고 있습니다. <ul> <li><span>URL: <a href="https://github.com/source-foundry/Hack" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/source-foundry/Hack <li>Ubuntu에서 설치 방법: <code>sudo apt install fonts-hack <h3>Noto Mono <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/noto-mono.png" alt="Noto Mono" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/noto-mono.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/noto-mono.png 2x" /> <p dir="auto">Android 운영체제를 위해 만들어진 Droid, Roboto 폰트 패밀리의 가장 최근 발전형입니다. 역시 무료로 사용 가능합니다. 참고로 Noto 폰트는 구글에서 진행하고 있는 Unicode 전체를 커버하는 폰트 프로젝트의 산물입니다. 안드로이드 스마트폰에서 볼 수 있는 한글 폰트가 Noto CJK (Chinese, Japanese, Korean) 폰트입니다. <p dir="auto">Noto Mono 폰트는 전체적으로 Dejavu Sans Mono와 비슷하게 생겼습니다만 i, l 과 같은 글자들이 다르게 생겼습니다. <ul> <li><span>URL: <a href="https://www.google.com/get/noto/" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://www.google.com/get/noto/ <li>Ubuntu에서 설치 방법: <code>sudo apt install fonts-noto-mono <h3>Inconsolata <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/inconsolata.png" alt="Inconsolata" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/inconsolata.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/inconsolata.png 2x" /> <p dir="auto">Microsoft의 Office나 Visual Studio 패키지를 설치하면 추가되는 고정폭 폰트가 Consolas 폰트입니다. 그런데 Consolas 폰트는 상용이라 배포가 자유롭지 못한 불편이 있습니다. Inconsolata 폰트는 이름에서 엿볼 수 있듯이 Consolas 폰트의 영향을 받은 무료 폰트로 처음부터 해상도가 높은 화면에서 더 깨끗하게 출력되는 고품질의 코딩용 폰트 개발을 지향했다는 특성이 있습니다. <ul> <li><span>URL: <a href="http://levien.com/type/myfonts/inconsolata.html" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">http://levien.com/type/myfonts/inconsolata.html <li>Ubuntu에서 설치 방법: <code>sudo apt install fonts-inconsolata <h3>Consolas <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/consolas.png" alt="Consolas" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/consolas.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/consolas.png 2x" /> <p dir="auto">Incosolata에서 말씀드렸듯이 Microsoft의 Office나 Visual Studio 패키지를 설치하면 추가되는 가독성이 좋은 고정폭 폰트입니다. <ul> <li><span>URL: <a href="https://docs.microsoft.com/en-us/typography/font-list/consolas" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://docs.microsoft.com/en-us/typography/font-list/consolas <h3>Cousine font <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/cousine.png" alt="Cousine" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/cousine.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/cousine.png 2x" /> <p dir="auto">Chrome OS의 Core 폰트 시리즈에 포함되어 배포되는 고정폭 폰트입니다. Courier new와의 자간 metric 호환에 신경을 썼다고 합니다. Chromebook을 쓰면 디폴트로 볼 수 있는 폰트가 되겠습니다. <ul> <li><span>URL: <a href="https://github.com/powerline/fonts/tree/master/Cousine" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/powerline/fonts/tree/master/Cousine <li>Ubuntu에서 설치 방법: <code>sudo apt install fonts-croscore <h2>한글 고정폭 폰트 <h3>D2Coding 폰트 <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/d2coding.png" alt="D2Coding" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/d2coding.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/d2coding.png 2x" /> <p dir="auto">오랫동안 가독성 좋은 한글 고정폭 폰트 구하기가 참 어려웠는데요. D2Coding 폰트가 나오면서 이 문제가 상당부분 해결된 느낌입니다. 한글 폰트가 나눔바른고딕에 기반하고 있어서 아주 미려하고 가독성 역시 좋습니다. 특히, 영문 폰트도 미려해서 영문 폰트를 주력으로 쓰는 분들에게도 추천할만한 폰트입니다. 개인적으로 적극 추천하고 싶은 폰트입니다. 마침 Ubuntu 18.04 최신버전부터는 패키지로 다운로드 없이 직접 설치가 가능해졌습니다. <ul> <li><span>URL: <a href="https://github.com/naver/d2codingfont" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/naver/d2codingfont <li>Ubuntu에서 설치 방법: <code>sudo apt install font-naver-d2coding <h3>나눔 코딩 <p dir="auto"><img src="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/nanum-gothic-coding.png" alt="Nanum Gothic Coding" srcset="https://images.hive.blog/768x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/nanum-gothic-coding.png 1x, https://images.hive.blog/1536x0/http://nekocloud.com/~jwsohn/assets/2018-05-01-computing-for-scieng-students-08/nanum-gothic-coding.png 2x" /> <p dir="auto">D2Coding 폰트가 나오기 전에 많이 쓰였던 한글 고정폭 폰트입니다. 나눔 고딕 코딩도 좋은 폰트이지만 전체적으로 서체가 너무 가늘고 고해상도 화면에서는 D2Coding이 더 나은 출력 품질을 보여 줍니다. <ul> <li><span>URL: <a href="https://github.com/naver/nanumfont/blob/master/README.md" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://github.com/naver/nanumfont/blob/master/README.md <li>Ubuntu에서 설치 방법: <code>sudo apt install font-nanum-coding <h2>고정폭 폰트 소개를 마치면서 <p dir="auto">지금까지 코딩에 적합한 가독성 좋은 고정폭 폰트에 대해 알아보았습니다. 개인적으로 볼 때 전체적으로 Dejavu Sans Mono 계열 폰트들이 가독성이 좋고 무난한 느낌이며 한글 고정폭 폰트로는 D2Coding 폰트가 상당히 뛰어나다고 생각합니다. <p dir="auto">폰트 선택은 주관적인 취향이 작용하기 때문에 위에 열거한 폰트 이외에 다른 선택을 하셔도 좋겠습니다. 다만, 코딩을 할 때에는 고정폭 폰트가 아닌 일반 가변폭 폰트 (variable-width font)를 쓰지는 마시기를 부탁드립니다.
5월 다시 파이팅해요!
호출에 감사드립니다!
와주셔서 감사합니다~
@resteemator is a new bot casting votes for its followers. Follow @resteemator and vote this comment to increase your chance to be voted in the future!
:)
Gracias!
pairplay 가 kr-dev 컨텐츠를 응원합니다! :)
감사합니다!