반응형
Thread는 가장 작은 작업 단위
자바스크립트 Single Thread: 한 순간에 단 하나의 작업만 실행한다.


1. Async theory
/**
* Async theory
*/
// function longWork() {
// const now = new Date();
// /**
// * milliseconds since epoch
// * 1970년도 1월 1일부터 지금 코드가 실행되는 순간까지의 시간을
// * 밀리초로 반환한다.
// */
// const milliseconds = now.getTime();
// const afterTwoSeconds = milliseconds + 2 * 1000;
// while(new Date().getTime() < afterTwoSeconds){
// }
// console.log('완료');
// }
// console.log('Hello');
// longWork();
// console.log('World');
function longWork(){
setTimeout(()=>{
console.log('완료');
}, 2000);
}
console.log('Hello');
longWork();
console.log('World');
// Hello
// Hello
// 완료

2. Callback
/**
* Callback
*/
function waitAndRun() {
setTimeout(() => {
console.log('끝');
}, 2000);
}
// waitAndRun();
function waitAndRun2() {
setTimeout(
() => {
console.log('1번 콜백 끝');
setTimeout(() => {
console.log('2번 콜백 끝');
setTimeout(() => {
console.log('3번 콜백 끝');
}, 2000);
}, 2000);
}, 2000);
}
// waitAndRun2();
//끝
//1번 콜백 끝
//2번 콜백 끝
//3번 콜백 끝
/**
* Promise
*/
const timeoutPromise = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('완료');
}, 2000);
});
// timeoutPromise.then((res) => {
// console.log('---then---');
// console.log(res);
// });
//--- then ---
// 완료
const getPromise = (seconds) => new Promise((resolve, reject) => {
setTimeout(() => {
// if(xxx){
// resolve('성공')
// }else{
// reject('에러');
// }
resolve('에러');
}, seconds * 1000);
});
// getPromise(3)
// .then((res) => {
// console.log('--- first then ---');
// console.log(res);
// })
// .catch((res)=>{
// console.log('--- first catch ---');
// console.log(res);
// })
// .finally(()=>{
// console.log('--- finally ---');
// });
Promise.all([
getPromise(1),
getPromise(4),
getPromise(1),
]).then((res)=>{
console.log(res);
});
3. Async / Await
/**
* Async / Await
*/
const getPromise = (seconds)=> new Promise((resolve, reject) => {
setTimeout(()=>{
resolve('에러');
}, seconds * 1000)
});
async function runner(){
try{
const result1 = await getPromise(1);
console.log(result1);
const result2 = await getPromise(2);
console.log(result2);
const result3 = await getPromise(1);
console.log(result3);
}catch(e){
console.log('---catch e---');
console.log(e);
}finally{
console.log('---finally---');
}
}
runner();
반응형
'개발자 > Web' 카테고리의 다른 글
| SQL 무료 입문 과정 WedataLab 강의 (5) | 2025.08.13 |
|---|---|
| 윅스(Wix) 홈페이지 만들기 상세 자료 (3) | 2025.01.05 |
| 자바스크립트 기본 문법 강의 5 객체의 모든 것 (11) | 2024.10.16 |
| 소스 코드가 포함된 50개의 자바스크립트 프로젝트 (3) | 2024.10.16 |
| 자바스크립트 기본 문법 강의 4 Class and OOP (3) | 2024.10.15 |
| 모든 자바스크립트 개발자가 알아야 할 33가지 기본 사항 (12) | 2024.10.15 |
| 50일 동안 50개의 프로젝트 - HTML/CSS 및 자바스크립트 (3) | 2024.10.01 |
| 모든 자바스크립트 개발자가 알아야 하는 33가지 개념 (8) | 2024.09.29 |
취업, 창업의 막막함, 외주 관리, 제품 부재!
당신의 고민은 무엇입니까? 현실과 동떨어진 교육, 실패만 반복하는 외주 계약,
아이디어는 있지만 구현할 기술이 없는 막막함.
우리는 알고 있습니다. 문제의 원인은 '명확한 학습, 실전 경험과 신뢰할 수 있는 기술력의 부재'에서 시작됩니다.
이제 고민을 멈추고, 캐어랩을 만나세요!
코딩(펌웨어), 전자부품과 디지털 회로설계, PCB 설계 제작, 고객(시장/수출) 발굴과 마케팅 전략으로 당신을 지원합니다.
제품 설계의 고수는 성공이 만든 게 아니라 실패가 만듭니다. 아이디어를 양산 가능한 제품으로!
귀사의 제품을 만드세요. 교육과 개발 실적으로 신뢰할 수 있는 파트너를 확보하세요.
캐어랩