>백엔드 개발 >C++ >'auto' 변수에 할당된 Spirit 파서가 문제를 일으키는 이유는 무엇이며 어떻게 해결할 수 있습니까?

'auto' 변수에 할당된 Spirit 파서가 문제를 일으키는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-21 11:23:13566검색

Why Do Spirit Parsers Assigned to `auto` Variables Cause Issues, and How Can I Fix Them?

Spirit에서 구문 분석된 표현식 관리

이 쿼리에서는 Spirit 파서를 자동 변수에 할당할 때 직면하는 문제를 살펴봅니다. 파서는 qi::parse()와 직접 사용하면 원활하게 작동할 수 있지만 파서가 자동 변수에 할당되어 재사용되면 문제가 발생합니다.

이 동작의 핵심은 Spirit 파서가 구현되는 방식에 있습니다. . Spirit의 기초를 형성하는 프로토 표현식 템플릿은 임시 변수에 대한 참조를 유지합니다. 파서가 자동 변수에 할당되면 기본 Proto 표현식은 임시 파서에 대한 참조도 설정합니다.

이 문제를 해결하기 위해 여러 옵션을 사용할 수 있습니다.

  • qi ::copy(): Boost V2의 트렁크에 도입된 이 방법을 사용하면 파서 복사를 허용하여 고유한 복사본을 보장하고 참조를 끊을 수 있습니다. chain.
  • boost::proto::deep_copy: 이 함수는 파서 참조 문제도 해결할 수 있는 깊은 복사 기능을 제공합니다.
  • BOOST_SPIRIT_AUTO: 이전 스택 오버플로 응답에서 소개된 이 매크로는 복사를 위한 편리한 약식으로 사용할 수 있습니다.

예:

namespace qi = boost::spirit::qi;

int main()
{
    auto bracketed_z = qi::copy( '[' >> +qi::char_('z') >> ']' ); // Uses qi::copy()

    string line = "[z]";
    auto p = line.cbegin();
    printf("%d", qi::parse(p, line.cend(), bracketed_z)); // Now works with auto variable

    // Alternative using BOOST_SPIRIT_AUTO
    BOOST_SPIRIT_AUTO(bracketed_z, '[' >> +qi::char_('z') >> ']');
}

이러한 접근 방식은 파서와 임시 변수 사이의 참조 체인을 끊고 자동 변수를 Spirit과 함께 효과적으로 사용할 수 있도록 하여 문제를 해결합니다. 파서.

위 내용은 'auto' 변수에 할당된 Spirit 파서가 문제를 일으키는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.