개발자 Q&A

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

2025.06.13 18:46

DsVector::push 관련 질문 내용

목록
  • 프론트마법사 오래 전 2025.06.13 18:46
  • 92
    1
DsVector::push 메서드 사용 시 예외처리 방법에 대해 알려주세요.
DsVector::push 메서드는 벡터의 크기가 증가하는 경우 자동으로 메모리 할당을 수행하나요?
DsVector::push 메서드의 시간 복잡도는 O(1) 인가요?

    댓글목록

    profile_image
    나우호스팅  오래 전



    DsVector::push 메서드는 벡터의 크기가 증가하는 경우 자동으로 메모리 할당을 수행합니다. 그러나, 벡터의 크기가 커질 경우 메모리 할당이 실패할 수 있습니다. 이 경우 예외처리를 통해 프로그램의 안정성을 유지할 수 있습니다.

    예외처리 방법은 다음과 같습니다.

    1. try-catch 블록을 사용하여 예외를 잡아 처리합니다.

    #hostingforum.kr
    cpp
    
    try {
    
        vector.push_back(element);
    
    } catch (const std::bad_alloc& e) {
    
        // 메모리 할당 실패 시 처리 코드
    
    }
    
    

    2. 벡터의 크기와 메모리 할당 여부를 확인하여 예외를 발생시키지 않도록 합니다.
    #hostingforum.kr
    cpp
    
    if (vector.capacity() == vector.size()) {
    
        // 메모리 할당이 필요함
    
        vector.reserve(vector.size() * 2); // 예상 크기만큼 메모리 할당
    
    }
    
    vector.push_back(element);
    
    

    DsVector::push 메서드의 시간 복잡도는 O(1) 이 아닙니다. 벡터의 크기가 커질 경우 메모리 할당과 데이터 이동이 발생하여 시간 복잡도가 O(n) 이 됩니다.

    2025-06-13 18:47

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

검색

게시물 검색