일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- JS
- TypeScript
- coding
- Servlet
- node
- 반응형 페이지
- cleancode
- CSS
- 코딩테스트
- 자바문제풀이
- node.js
- 변수
- react-router-dom
- 코드업
- HTML
- JavaScript
- react
- 그럼에도 불구하고
- redux
- git
- github
- 프론트엔드
- java
- @media
- 자바
- max-width
- frontend
- webpack
- media query
- 그럼에도불구하고
- Today
- Total
그럼에도 불구하고
[React] useMemo와 useCallback 이란? 본문
오늘은 useMemo와 useCallback에 대해 알아보겠습니다. :)
[ 메모이제이션 (memoization) ]
메모이제이션 (memoization)이란 기존에 수행한 연산의 결괏값을 어딘가에 저장해 두고 동일한 입력이 들어오면 재활용하는 프로그래밍 기법을 말합니다. momoization을 잘 적용하면 중복 연산을 피할 수 있기 때문에 메모리를 조금 더 쓰더라도 애플리케이션의 성능을 최적화할 수 있습니다.
[ useMemo ]
useMemo는 React 컴포넌트에서 계산 비용이 큰 연산을 최적화하는 데 사용되는 Hook입니다.
useMemo는 이전에 계산된 값을 기억하고, 해당 값이 변경되지 않은 경우에는 이전 값을 재사용합니다.
즉 , 메모이제이션된 '값'을 반환합니다.
useMemo(() => fn, deps);
useMemo는 deps가 변한다면, () => fn이라는 함수를 실행하고, 그 함수의 반환 값을 반환합니다. deps는 dependency이며, useMemo가 이 deps라는 것에 '의존'한다는 뜻입니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | import React, { useState, useCallback, useMemo } from "react"; export default function App() { const [ex1, setEx1] = useState(0); const [ex2, setEx2] = useState(0); // useMemo 사용하기 useMemo(() => {console.log(ex1)}, [ex1]); // 두 개의 버튼을 설정하고, X버튼만이 ex1를 변화시킵니다. return ( <> <button onClick={() => setEx1((curr1) => (curr1 + 1))}>X</button> <button onClick={() => setEx2((curr2) => (curr2 + 1))}>Y</button> </> ); } | cs |
위와 같은 버튼이 있을 때 X라는 버튼을 클릭하면 'ex'라는 상태값이 변화합니다.
useMemo(() => {console.log(ex)},[ex])
위 코드에서 deps는 [ex]입니다. 즉, ex가 변할 때만 () => {console.log(ex)} 가 실행됩니다. 따라서 X 버튼을 누를 때만 콘솔 창에 ex 값이 출력됩니다.
여기서 Y 버튼을 누르더라도 APP이라는 함수 컴포넌트가 전부 재실행(리렌더링) 되지만, ex라는 값은 변하지 않기 때문에 useMemo에는 아무런 변화가 없습니다.
[ useCallback ]
useCallback은 React 컴포넌트에서 함수를 메모이제이션하여 성능을 최적화하는 데 사용되는 Hook입니다.
useCallback은 이전에 생성된 함수를 기억하고, 해당 함수를 재사용합니다.
즉 , 메모이제이션된 '함수'를 반환합니다.
useCallback(fn, deps)
useCallback은 deps가 변한다면 fn이라는 새로운 함수를 반환합니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | import React, { useState, useCallback, useMemo } from "react"; export default function App() { const [ex1, setEx1] = useState(0); const [ex2, setEx2] = useState(0); // useCallback이 () => {console.log(ex2)}라는 함수를 반환합니다. const useCallbackReturn = useCallback(() => {console.log(ex2)}, [ex1]); // useCallback이 담겨있는 함수를 실행 useCallbackReturn(); return ( <> <button onClick={() => setEx1((curr1) => (curr1 + 1))}>X</button> <button onClick={() => setEx2((curr2) => (curr2 + 1))}>Y</button> </> ); } | cs |
위의 코드는 처음 예시와 같은 버튼을 클릭할 때 이벤트가 발생하는 코드입니다.
위의 useCallback은 () => {console.log(ex2)}라는 함수를 반환해주고 있습니다.
useCallback은 다음의 순서로 진행됩니다.
1. 처음 컴포넌트가 시작될 때 실행 () => {console.log(0)}
2. ex1이 변할 때까지 함수는 () => {console.log(0)}
3. ex1이 변한다면 그때 ex2의 값을 가져와서 () => {console.log(새로운 값)}
예를 들어 Y버튼을 다섯 번 누른다고 가정했을 때, Y 버튼이 눌리면 'ex2'라는 상태의 값이 1씩 증가합니다.
하지만, 출력 값은 계속 0이 나오게 됩니다. (실제로는 ex2의 값은 1씩 증가하고 있습니다.) 그러다가 X 버튼을 누르면 ex1의 deps가 변하자마자, () => {console.log(5)}를 반환합니다.
즉, deps가 변해야 함수 컴포넌트와 상태 값(ex2)을 공유하는 것입니다.
따라서 useCallback은 함수와는 상관없는 상태 값이 변할 때, 함수 컴포넌트에서 불필요하게 함수를 업데이트하는 것을 방지해 줍니다.
[ useMemo vs useCallback ]
- useMemo는 계산 비용이 큰 연산의 결과를 메모이제이션하여 재사용하고, useCallback은 함수를 메모이제이션하여 재사용합니다.
- useMemo는 연산 결과를 반환하고, useCallback은 함수를 반환합니다.
- useMemo는 값을 메모이제이션하고, useCallback은 함수를 메모이제이션합니다.
- useMemo는 값을 계산하는 로직을 콜백 함수에 작성하고, useCallback은 함수를 생성하는 로직을 콜백 함수에 작성합니다.
- useMemo는 계산 비용이 큰 연산을 최적화하는 데 사용됩니다. 예를 들어, 배열이나 객체와 같은 큰 데이터를 가공하거나 복잡한 계산을 수행하는 경우에 사용됩니다.
- useCallback은 자주 렌더링되는 컴포넌트에서 함수를 최적화하고, 불필요한 함수 재생성을 방지하는 데 사용됩니다. 예를 들어, 자식 컴포넌트에 전달되는 콜백 함수를 최적화하고 싶은 경우에 사용됩니다.
- 의존성 배열(dependencyArray)을 사용하여 어떤 값이 변경되었을 때에만 메모이제이션된 값이나 함수를 갱신하도록 설정할 수 있습니다. 이를 통해 불필요한 갱신을 방지하고, 성능을 향상할 수 있습니다.
- useMemo와 useCallback은 렌더링 결과에 영향을 주지 않는 경우에는 불필요한 메모이제이션을 방지하고, 최적화를 위해 사용되어야 합니다.
- useMemo와 useCallback은 성능 최적화를 위한 강력한 도구로 사용되며, 필요에 따라 적절하게 사용하여 React 애플리케이션의 성능을향상할수 있습니다.
'React > React basics' 카테고리의 다른 글
[React] immer란? (0) | 2023.05.05 |
---|---|
[React] props의 defaultProps란? (0) | 2023.04.28 |
[React] Context API란? (0) | 2023.04.10 |
[React] useReducer란? (0) | 2023.04.08 |
[React] useEffect란? (0) | 2023.04.07 |