// const printSimply = function () {console.log('you can make function simply!');}
const printSimply = () => console.log('you can make function simply!');
// const add = function (a, b) {
// console.log(a + b);
// console.log("end");
// }
const add = (a, b) => {
console.log(a + b);
console.log("end");
}
printSimply();
add(5, 4);
- [JavaScript] Arrow Function (애로우 함수) 2022.09.11
- [JavaScript] 논리 연산자 (null == undefined == 0 == '' == false) 2022.09.11
- [JavaScript] Object (객체), Object 복사[Copy], 합치기[Merge], key와 value추출하기, Object 키(key)에 변수 할당하기[Computed property](Object.assign, Object.keys, Object.values, Object.entries) [Deep Copy, Shallow Copy] 2022.09.11
- [JavaScript] user strict (JavaScript 디버그) 2022.09.11
- [CS 지식] 강타입, 약타입, MView, Base64, CI/CD, 쿠버네티스(k8s) 2022.09.11
- [Shell Script] 쉘 스크립트 변수에 리눅스명령어 담기 2022.09.04
- [Shell Script Code] 쉘 스크립트 \t, \r, 다중공백 지우기, 문자 치환 (sed) [Replace] 2022.09.04
- [Java Code] 파일 다운로드 구현하기 2022.09.04
- [Java Code] 현 OS의 CPU, MEMORY, HDD의 사용량 및 남은용량 구하기 2022.09.04
[JavaScript] Arrow Function (애로우 함수)
[JavaScript] 논리 연산자 (null == undefined == 0 == '' == false)
// logical operation
console.log('null == undefined ? ' + (null == undefined)); // true
console.log('null === undefined ? ' + (null === undefined)); // false
console.log('0 == false ? ' + (0 == false)); // true
console.log('0 === false ? ' + (0 === false)); // false
console.log('"" === false ? ' + ('' == false)); // true
console.log('"" === false ? ' + ('' === false)); // false
null == undefined == 0 == '' == false
'[JavaScript] > [JavaScript]' 카테고리의 다른 글
📝Object (객체)
var book ={
title : "채식주의자",
author : "한강",
price : "120000"
}
console.log(book.title); // 채식주의자
var book =[
{
title : "채식주의자",
author : "한강",
price : "120000"
},
{
title : "육식주의자",
author : "두강",
price : "130000"
}
] // 배열 + 객체
console.log(book[0].title); // 채식주의자
console.log(book[1].title); // 육식주의자
// 객체
자바스크립트는 객체를 지정할 수 있고 속성 : 속성값으로 이루어져있습니다. 또한 배열로 여러개를 만들 수도 있습니다.
// Object (you can change inner value even if const)
const person = {name : 'smith', age : 20};
console.log(`name : ${person.name}, age : ${person.age}`);
person.name = 'hommer'
console.log(`name : ${person.name}, age : ${person.age}`);
값에 직접 접근해 해당 내용의 값을 바꿀수도 있습니다.
📝Object Key를 변수로 할당하기 [Computed property]
// Computed property
let a = 'age';
const user1 = {
name : 'Mike',
// age : 30
[a] : 30 // "키"에 변수를 할당할 수 있다
}
console.log(user1); //{ name: 'Mike', age: 30 }
const user2 = {
[1 + 4] : 5,
["안녕" + "하세요"] : "Hello"
}
console.log(user2); // { '5': 5, '안녕하세요': 'Hello' }
📝Object 복사하기 (잘못된 버전) [주소복사]
const user = {
name : 'Mike',
age : 30
}
const cloneUser = user; // 주소 복사
/** 값 변화 **/
cloneUser.name = "Bob";
user.age = 10;
console.log(`name : ${user.name}, user.age : ${user.age}`); // name : Bob, user.age : 10
console.log(`name : ${cloneUser.name}, user.age : ${cloneUser.age}`); // name : Bob, user.age : 10
그냥 = 으로 퉁쳐버리면 값이 복사가 되는게 아니라 주소가 복사됩니다. 그래서 서로에게 영향을 끼치기 때문에 생각한대로 프로그램이 안 돌아갈 수 있습니다.
📝Object 복사하기 [값 복사]
const user = {
name : 'Mike',
age : 30
}
const realCloneUser = Object.assign({}, user);
realCloneUser.name = "Bob";
user.age = 10;
console.log(`name : ${user.name}, user.age : ${user.age}`); // name : Mike, user.age : 10
console.log(`name : ${realCloneUser.name}, user.age : ${realCloneUser.age}`); // name : Bob, user.age : 30
Object.assign( ${기존 객체 값 [없을 시 {} 빈 값]}, ${복사할 값}) 을 이용해 값을 복사할 수 있습니다
📝기존 Object에 값 추가 및 덮어씌우기(overwrtie) 및 객체 합치기
const user = {
name : 'Mike',
age : 30
}
/** --- Clone Json Object [add] --- **/
const cloneUser1 = Object.assign({gender:'male'}, user); // 복제 + 원하는 값 추가
console.log(cloneUser1); // { gender: 'male', name: 'Mike', age: 30 }
/** --- Clone Json Object [overwrite] --- **/
const cloneUser2 = Object.assign({name:'Bob'}, user); // 복제 + 원하는 값 추가
console.log(cloneUser2); // { gender: 'male', name: 'Mike', age: 30 }
/** --- Merge Json Object --- **/
const name = {name : 'Mike'}
const age = {age : 40}
const gender = {gender : 'female'}
const mergeUser = Object.assign(user, age, gender);
console.log(mergeUser); // { name: 'Mike', age: 40, gender: 'female' }
Object.assign( ${합칠 객체}, ${합칠 객체} ...) 을 이용해 객체를 합칠 수 있습니다
📝Object Key, Value 추출하기
const user = { name: 'Mike', age: 40, gender: 'female' }
/** --- Extract Json Keys, Values --- **/
const keys = Object.keys(user);
const values = Object.values(user);
console.log(keys); // [ 'name', 'age', 'gender' ]
console.log(values); // [ 'Mike', 40, 'female' ]
/** --- Extract Json Keys + Values --- **/
const entries = Object.entries(user);
console.log(entries); // [ [ 'name', 'Mike' ], [ 'age', 40 ], [ 'gender', 'female' ] ]
- Object.keys( ${키를 추출할 객체} ) 을 이용해 객체의 키를 배열로 추출할 수 있습니다.
- Object.keys( ${값을 추출할 객체} ) 을 이용해 객체의 값을 배열로 추출할 수 있습니다.
- Object.entries( ${키와 값을 추출할 객체} ) 을 이용해 객체의 키,값을 배열로 추출할 수 있습니다.
🔗 참고 및 출처
https://www.youtube.com/watch?v=6NZpyA64ZUU&list=PLZKTXPmaJk8JZ2NAC538UzhY_UNqMdZB4&index=3
'[JavaScript] > [JavaScript]' 카테고리의 다른 글
[JavaScript] Arrow Function (애로우 함수) (0) | 2022.09.11 |
---|---|
[JavaScript] 논리 연산자 (null == undefined == 0 == '' == false) (0) | 2022.09.11 |
[JavaScript] user strict (JavaScript 디버그) (0) | 2022.09.11 |
[JavaScript] 자바스크립트 [태그 조작 메소드] 태그 추가 및 삭제, 내용 추가 및 삭제 (empty, remove, html, innerText, innerHTML) (0) | 2022.03.12 |
[JavaScript] 이벤트 바인딩 (0) | 2021.06.29 |
[JavaScript] user strict (JavaScript 디버그)
// use strict
// 1. 동적타입 언어를 정적타입 언어로 바꾼다 → you can debug
// 2. 동적타입에 대한 처리를 안 한다 → system speed up
'use strict';
// a = 6; // 'a is not defined' Error occured
'[JavaScript] > [JavaScript]' 카테고리의 다른 글
[CS 지식] 강타입, 약타입, MView, Base64, CI/CD, 쿠버네티스(k8s)
📝약타입
다른 타입으로 변환이 가능하며 심지어 암묵적으로 변화을 해주기도 한다
int a = 1;
float b = 1.1f;
float c = a + b;
📝강타입
다른 타입으로 변환이 금지 되었고 명시적으로 타입을 선언해줘야한다
int a = 1;
String b = "Hello"
String c = a + b;
📝MView
물리적으로 존재하는 테이블로 데이터가 일정 공간을 차지한다는 특징이 있습니다
MView는 특정 결과를 생성하는 쿼리가 자주 사용되거나 실행 시간이 많이 소요되는 조인이나 복잡한 SQL에 대한 성능을 향상시키기 위해 사용한다
기존의 뷰(View)와는 달리, MView는 실제 데이터를 저장하고 있어 해당 값을 빠르게 조회 데이터 웨어하우 (Data Warehouse)나 대규모 데이터베이스 환경에서 효과적으로 사용될 수 있습니다
📝Base64
데이터를 64진법으로 표현하는 방식으로 2^6 =64 → 6bit로 문자 한개를 표현한다 (이진데이터 → 텍스트 형식 변환)
6bit를 4개씩 모아 변환하는데 이 때문에 비는 공간이 발생한다 빈공간은 = 문자로 채운다
Base64로 인코딩시 데이터의 크기는 33%증가하게 된다.
UTF-8하고 인코딩하는게 비슷해보이지만 UTF-8의 경우 문자 인코딩에 특화되어있어서 HTML, 텍스트 파일, 문자에 대해서는 사용되지만 엑셀, 이미지와 같은 이진데이터의 경우 Base64를 사용해서 보낼 수 있다
- UTF-8
- 문자열 → UTF-8 인코딩 → 이진형태로 변환 후 데이터 전송 → 이진형태 디코딩 → UTF-8 디코딩 → 문자열
- Base64 (엑셀파일 기준)
- 엑셀 파일 (데이터 이진 형태) → Base64 인코딩 문자열 전송 (이진형태로 데이터를 안 보내도 전송할 수 있게 설계되어있음) → Base64 디코딩 → 이진형태 Content Type에 맞게 해독
📝CI(Continuous Integration) / CD(Continuous Delivery, Continuous Deployment)
CI/CD 개념은 소프트웨어 개발 생명주기를 자동화하고 가속화하여 효율성을 높이고 신속한 소프트웨어 제공 가능
많이 사용하는 제품으로 Jenkins가 있다
📝CI (Continuous Integration)
CI는 "지속적 통합"을 나타내며 소프트웨어 개발에서 발생할 수 있는 문제를 조기에 감지하고 해결하기 위한 개발 방법론으로 개발자들이 코드를 중앙 저장소에 푸시할 때마다 자동으로 빌드 및 테스트를 수행합니다 이를 통해 코드 변경 사항의 통합이 지속적으로 이루어지며, 팀 내에서 코드 품질을 높이고 오류를 조기에 발견할 수 있습니다
💗장점
- 코드 퀄리티 향상 → 반드시 유닛테스트가 필요하기 때문에 그에 맞는 방향으로 개발해 실수를 줄인다.
- 즉각적인 버그 알림 → 유닛테스트 후 문제가 생긴 곳을 개발한 개발자에게 즉각 알림
📝CD (Continuous Delivery, Continuous Deployment)
CI를 기반으로 하는 지속적인 전달과 배포를 의미
- Continuous Delivery (CD):
- Continuous Integration에서 온 테스트 및 빌드 단계를 통과한 코드를 자동으로 운영 환경에 배포 가능한 상태로 만듭니다
- Continuous Deployment (CD):
- Continuous Integration에서 테스트 및 빌드를 통과한 코드가 자동으로 실제 운영 환경에 배포됩니다
📝쿠버네티스
컨테이너 관리 툴로서 나뉜 걸 배포하려고 할 때 수동으로 하나하나씩 올리기 힘들기 때문에 자동화 해주고 컨테이너를 모니터링해주고 죽은 즉시 바로 재시작을 시켜준다
컨테이너를 미리 카피하고 만들어 부하분산을 해준다.
🔗 참고 및 출처
https://www.youtube.com/watch?v=4oSS6xZ_fuM
'[CS 지식]' 카테고리의 다른 글
[CS 지식] MIME타입, 싱글톤(SingleTon) 패턴, Chunk 지향 처리, APM, 메모리디비 (0) | 2022.09.27 |
---|---|
[CS 지식] 검색엔진, 엘라스틱(Elastic), Solar, 검색엔진 동작 방식 (역인덱싱), BM25(TF, IDF) (0) | 2022.09.12 |
[CS 지식] 개발자 종류 [1] (프론트엔드 개발자, 백엔드(서버쪽), 모바일개발자, 애플리케이션개발자, 게이밍 플레이 개발자, 게이밍 엔진 개발자, 보안 개발자, 백엔드 시스템 플랫폼 개발자) (0) | 2022.09.04 |
[CS 지식] SGML, XML, DTD (0) | 2022.09.04 |
[CS 지식] 서버, DNS 플러시, 데이터의 이동, 웹 방화벽, 방화벽, IDS, IPS (0) | 2022.09.04 |
[Shell Script] 쉘 스크립트 변수에 리눅스명령어 담기
`cat /home/search/template.txt` # `리눅스 명령어` → 백틱을 이용해 쉘스크립에서 리눅스 명령어 실행 가능
'[Linux] > [Shell Script]' 카테고리의 다른 글
[Shell Script Code] 쉘 스크립트 \t, \r, 다중공백 지우기, 문자 치환 (sed) [Replace] (0) | 2022.09.04 |
---|---|
[Shell Script] 쉘 스크립트 경로, 파일 이름, 확장자, 파일명.확장자 구하기, 파일의 확장자명 제거, 파일 내용 읽어서 변수에 담기 (0) | 2022.02.21 |
[Shell Script Code] 쉘 스크립트 \t, \r, 다중공백 지우기, 문자 치환 (sed) [Replace]
mappings=`echo ${mappings} | grep -v File | sed -e "s/\t/ /g"` # \t
mappings=`echo ${mappings} | grep -v File | sed -e "s/\r/ /g"` # \r
mappings=`echo ${mappings} | grep -v File | sed -e "s/\ \+/ /g"` # 다중공백
# \t , \r, \+ 을 하나의 공백으로 변경
# sed -e /${현재내용}/${바꿀내용}/g
sed -i "s/기존문자/바꿀문자/g" 파일명
예) sed -i "s/abc/ttt/g" test.txt → text.txt의 abc문자열을 ttt로 변경한다.
'[Linux] > [Shell Script]' 카테고리의 다른 글
[Shell Script] 쉘 스크립트 변수에 리눅스명령어 담기 (0) | 2022.09.04 |
---|---|
[Shell Script] 쉘 스크립트 경로, 파일 이름, 확장자, 파일명.확장자 구하기, 파일의 확장자명 제거, 파일 내용 읽어서 변수에 담기 (0) | 2022.02.21 |
[Java Code] 파일 다운로드 구현하기
@RequestMapping(value = "/downloadManual", method = RequestMethod.GET)
public void downloadManual(HttpServletResponse response) throws Exception {
FileInputStream fileInputStream = null;
OutputStream out = null;
try {
String path = linuxRootPath + "Manual.docx"; // 경로에 접근할 때 역슬래시('\') 사용
File file = new File(path);
response.setHeader("Content-Disposition", "attachment;filename=" + file.getName());
// 다운로드 되거나 로컬에 저장되는 용도라는 정보를 알려주는 헤더
fileInputStream = new FileInputStream(path); // 파일 읽어오기
out = response.getOutputStream();
int read = 0;
byte[] buffer = new byte[1024];
while ((read = fileInputStream.read(buffer)) != -1) { // 1024바이트씩 계속 읽으면서 outputStream에 저장, -1이 나오면 더이상 읽을
out.write(buffer, 0, read);
}
fileInputStream.close();
out.close();
} catch (Exception e) {
fileInputStream.close();
out.close();
throw new Exception("download error");
} finally {
fileInputStream.close();
out.close();
}
}
'[Java] > [Java Code]' 카테고리의 다른 글
[Java Code] ini 설정 파일 읽기 (0) | 2022.11.05 |
---|---|
[Java Code] OS, HostName(호스트네임), IP(아이피) 구하기 (1) | 2022.10.11 |
[Java Code] 현 OS의 CPU, MEMORY, HDD의 사용량 및 남은용량 구하기 (0) | 2022.09.04 |
[Java Code] https 통신하기 (SSL 인증 무시하고 작동시키기) (0) | 2022.09.03 |
[Java Code] HashMap 을 JSONObject로 변환 / ArrayList를JSONArray 로 변환 (0) | 2022.08.02 |
[Java Code] 현 OS의 CPU, MEMORY, HDD의 사용량 및 남은용량 구하기
@SuppressWarnings("restriction")
@RequestMapping(value = "/pie", method = RequestMethod.POST)
public @ResponseBody void getServerInfo(HttpServletRequest request, HttpServletResponse response)
throws IOException {
OperatingSystemMXBean osBean = (com.sun.management.OperatingSystemMXBean) ManagementFactory
.getOperatingSystemMXBean();
double load = 0;
load = osBean.getSystemCpuLoad();
File f = new File("/");
JSONObject systemInfoJson = new JSONObject();
/** CPU **/
systemInfoJson.put("cpuUsage", Math.round(load * 100.0)); // 사용량
systemInfoJson.put("cpuIdle", (100 - Math.round(load * 100.0))); // 남은 용량
/** HDD **/
systemInfoJson.put("hddUsage", Math.round((f.getTotalSpace() - f.getUsableSpace()) / (1024 * 1024) / 1000.0)); // 사용량
systemInfoJson.put("hddIdle", Math.round((f.getFreeSpace()) / (1024 * 1024) / 1000.0)); // 남은 용량
/** MEMORY **/
systemInfoJson.put("memoryTotal", Math.round(osBean.getTotalPhysicalMemorySize() / (1024 * 1024) / 1000.0)); // 사용량
systemInfoJson.put("memoryFree", Math.round(osBean.getFreePhysicalMemorySize() / (1024 * 1024) / 1000.0)); // 남은 용량
response.setContentType("application/json; charset=UTF-8");
PrintWriter writer = null;
writer = response.getWriter();
writer.print(systemInfoJson);
writer.flush();
}
'[Java] > [Java Code]' 카테고리의 다른 글
[Java Code] OS, HostName(호스트네임), IP(아이피) 구하기 (1) | 2022.10.11 |
---|---|
[Java Code] 파일 다운로드 구현하기 (0) | 2022.09.04 |
[Java Code] https 통신하기 (SSL 인증 무시하고 작동시키기) (0) | 2022.09.03 |
[Java Code] HashMap 을 JSONObject로 변환 / ArrayList를JSONArray 로 변환 (0) | 2022.08.02 |
[Java Code] 특정 단어 모든 위치 찾기 (0) | 2022.08.01 |