[visual-studio] std :: string으로 조건부 중단 점을 만드는 방법

이 기능이 있다고 가정합니다.

std::string Func1(std::string myString)
{
   //do some string processing
   std::string newString = Func2(myString)
   return newString;
}

newString특정 값이 있을 때 조건부 중단을 어떻게 설정 합니까? (소스를 변경하지 않고)

조건 설정 newString == "my value"

작동하지 않음 중단 점이 “오버로드 된 연산자를 찾을 수 없음”오류와 함께 비활성화되었습니다.



답변

일부 검색은이를 수행하는 방법을 찾지 못했습니다. 제안 된 대안은 코드에 테스트를 넣고 표준 중단 점을 추가하는 것입니다.

if (myStr == "xyz")
{
    // Set breakpoint here
}

또는 개별 문자 비교에서 테스트를 구축 할 수 있습니다. 문자열의 개별 문자를 보는 것조차 약간 어색합니다. Visual Studio 2005에서는 다음과 같은 멤버 변수를 파헤쳐 야했습니다.

myStr._Bx._Buf[0] == 'x' && myStr._Bx._Buf[1] == 'y' && myStr._Bx._Buf[2] == 'z'

이러한 접근 방식 중 어느 것도 매우 만족스럽지 않습니다. 표준 라이브러리의 유비쿼터스 기능에 더 잘 액세스 할 수 있어야합니다.


답변

Visual Studio 2010/2012에는 훨씬 더 쉬운 방법이 있습니다.

ANSI에서 원하는 것을 달성하려면 다음을 사용하십시오.

strcmp(newString._Bx._Ptr,"my value")==0

그리고 유니 코드에서 (newString이 유니 코드 인 경우) 다음을 사용하십시오.

wcscmp(newString._Bx._Ptr, L"my value")==0

비교하는 것보다 할 수있는 일이 더 많습니다. 여기에서 더 많은 것을 읽을 수 있습니다.

http://blogs.msdn.com/b/habibh/archive/2009/07/07/new-visual-studio-debugger-2010-feature-for-cc-developers-using-string-functions-in-conditional- breakpoints.aspx


답변

VS2017에서는 할 수 있습니다.

strcmp(newString._Mypair._Myval2._Bx._Buf,"myvalue")==0


답변

VS2017에서 조건을 다음과 같이 설정할 수있었습니다.

strcmp(&newString[0], "my value") == 0


답변

Brad의 답변과 유사한 것을 사용하여이 문제를 해결해야했지만 ( 코드에서 바로 분리하기 위해 DebugBreak () 사용 ) 때로는 약간의 코드를 편집 / 재 컴파일 / 재실행하는 것이 너무 시간이 많이 걸리거나 불가능합니다. .

운 좋게도 std :: string 클래스의 실제 멤버로 스펠링하는 것이 가능합니다. 여기에 한 가지 방법이 언급되어 있습니다. 그가 VS2010을 구체적 으로 언급 했지만 이전 버전에서는 여전히 개별 문자에 수동으로 액세스 할 수 있습니다. 따라서 2010을 사용하는 경우 멋진 strcmp()기능 등을 사용할 수 있습니다 ( 추가 정보) .하지만 저와 같고 2008 년 이전 버전을 사용하고 있다면 거칠고 끔찍하지만 기능적인 대안을 생각 해낼 수 있습니다. 중단 점 조건을 다음과 같이 설정하여 :

strVar._Bx._Ptr[0] == 'a' && strVar._Bx._Ptr[1] == 'b' &&
   strVar._Bx._Ptr[2] == 'c'

strVar의 처음 세 문자가 “abc”이면 중단됩니다. 물론 추가 문자로 계속 진행할 수 있습니다. 못 생겼어 .. 근데 시간이 좀 절약 됐어.


답변

VS2012 :

newString._Bx._Ptr OBWANDO의 답변에서와 같이 불법 메모리를 참조 했기 때문에 아래 조건을 사용했습니다.

strcmp( newString._Bx._Buf, "my value")==0

그리고 그것은 작동했습니다 …


답변

@OBWANDO (거의)에는 해결책 이 있지만 여러 주석이 올바르게 지적했듯이 실제 버퍼는 문자열 크기에 따라 다릅니다. 나는 16이 문턱이라고 본다. 적절한 버퍼의 strcmp 앞에 크기 검사를 추가하면 작동합니다.

newString._Mysize < 16 && strcmp(newString._Bx._Buf, "test value") == 0

또는

newString._Mysize >= 16 && strcmp(newString._Bx._Ptr, "ultra super long test value") == 0