💻 Dev

처음부터 만드는 Once — 함수를 딱 한 번만 실행하는 5줄 구현

초기화, DB 연결, 이벤트 리스너 등 딱 한 번만 실행되어야 하는 함수가 있습니다. 아무리 여러 번 호출해도 처음 한 번만 실행하고 그 결과를 반환하는 패턴입니다.

기본 구현


```javascript
function once(fn) {
let called = false;
let result;
return function(...args) {
if (!called) {
called = true;
result = fn(...args);
}
return result;
};
}
// 사용
const init = once(() => {
console.log('초기화 시작');
return 'initialized';
});
init(); // 초기화 시작 → 'initialized'
init(); // (실행 안 됨) → 'initialized' (이전 결과 반환)
init(); // (실행 안 됨) → 'initialized'
```

실전 예제


```javascript
// DB 연결 초기화
const connectDB = once(async () => {
const conn = await pool.connect();
console.log('DB 연결됨');
return conn;
});
// 여러 곳에서 호출해도 처음 한 번만 연결됨
await connectDB();
await connectDB();
await connectDB();
```

심화: 비동기 처리


```javascript
function once(fn) {
let called = false, calling = false;
let result, error;

return async function(...args) {
if (!called && !calling) {
calling = true;
try {
result = await fn(...args);
called = true;
} catch (e) {
error = e;
called = true;
}
}
if (error) throw error;
return result;
};
}
```
참고: Lodash [_.once](https://lodash.com/docs/#once), Underscore [_.once](https://underscorejs.org/#once)
사용 케이스: 앱 초기화, 싱글톤 생성, 구독 등록, 마이그레이션 실행 등
💬 0
👁 0 views

Comments (0)

💬

No comments yet.

Be the first to comment!