개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.09 16:31

Array의 forEach와 map의 차이점에 대해 설명해 주세요.

목록
  • 디버깅의신 11일 전 2025.07.09 16:31 인기
  • 218
    1
제가 Array의 forEach와 map의 차이점을 이해하지 못해 질문합니다. forEach는 callback 함수를 하나씩 호출하고, map은 새로운 Array를 반환하는 것 같은데 어떤 차이가 있을까요?

예를 들어, Array [1, 2, 3]을 forEach와 map으로 처리한 결과가 어떻게 다른지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  11일 전



    Array의 forEach와 map의 차이점은 다음과 같습니다.

    - forEach는 callback 함수를 하나씩 호출하여 Array의 각 요소를 처리합니다. 그러나 결과는 Array 자체가 변경되거나 새로운 Array를 반환하지 않습니다.
    - map은 callback 함수를 하나씩 호출하여 Array의 각 요소를 처리하고, 새로운 Array를 반환합니다. 새로운 Array의 요소는 callback 함수의 반환값으로 결정됩니다.

    예를 들어, Array [1, 2, 3]을 forEach와 map으로 처리한 결과는 다음과 같습니다.

    #hostingforum.kr
    javascript
    
    let arr = [1, 2, 3];
    
    
    
    // forEach
    
    arr.forEach((value) => console.log(value));
    
    // 결과: 1, 2, 3
    
    
    
    // map
    
    let newArr = arr.map((value) => value * 2);
    
    console.log(newArr);
    
    // 결과: [2, 4, 6]
    
    


    forEach는 Array 자체를 변경하지 않기 때문에 newArr를 arr에 할당하면 arr의 요소가 변경되지 않습니다.

    #hostingforum.kr
    javascript
    
    let arr = [1, 2, 3];
    
    
    
    // forEach
    
    arr.forEach((value) => value *= 2);
    
    console.log(arr);
    
    // 결과: [1, 2, 3]
    
    
    
    // map
    
    let newArr = arr.map((value) => value * 2);
    
    console.log(newArr);
    
    // 결과: [2, 4, 6]
    
    


    map은 새로운 Array를 반환하기 때문에 newArr를 arr에 할당하면 arr의 요소가 변경됩니다.

    #hostingforum.kr
    javascript
    
    let arr = [1, 2, 3];
    
    
    
    // map
    
    arr = arr.map((value) => value * 2);
    
    console.log(arr);
    
    // 결과: [2, 4, 6]
    
    

    2025-07-09 16:32

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,635건 / 46 페이지

검색

게시물 검색