함수: 문자열 s에 대해 작동하고 delim의 문자를 구분 기호로 사용하고 s가 null 값 NULL인 경우 s를 하위 문자열로 나눕니다. 함수에 의해 저장된 포인터 SAVE_PTR이 다음으로 호출됩니다. 시간 중장이 시작 위치가 됩니다.strtok 함수 사용법: 1. 문자열 s에 대해 실행하고 구분 기호로 문자를 사용하고 s를 하위 문자열로 나눕니다. 2. s가 NULL인 경우 함수에 의해 저장된 포인터 [SAVE_PTR]은 다음과 같습니다. 통화의 시작 위치로 사용됩니다. ㅋㅋㅋ : char *strtok(char * s , char *delim)
반환 값: 구분 기호와 일치하는 첫 번째 하위 문자열
2.첫 번째 하위 문자열 추출이 완료된 후 소스 문자열 s를 계속 추출하려면 후속(두 번째, 세 번째,...n번째) 호출에서 strtok의 첫 번째 매개 변수에 null 값 NULL을 할당해야 합니다(
는 함수가 계속해서 추출을 수행함을 나타냄). 이전 호출의 소스 문자열) 한 호출에서 암시적으로 저장된 위치는 이전 호출에 대한 문자열을 계속 분해하며, this 포인터는 첫 번째 호출이 끝나기 전에 구분 기호의 다음 비트를 가리키는 데 사용됩니다.
3.이때 포인터는 "
첫 번째 호출 결과는 위에서 언급한 대로 ",Fred"가 추출됩니다. 또한 계속해서 공백을 경계로 사용하여 다음 "남성" 등을 추출하고자 합니다. 위 그림에서 알 수 있듯이 첫 번째 호출 이후 첫 번째 호출에서는 strtok의 첫 번째 매개변수에 널값 NULL을 전달했습니다(는 함수가 이전 호출에서 암시적으로 저장된 위치에서 문자열을 계속 분해한다는 의미입니다) ; 위의 경우 두 번째 호출의 경우 첫 번째 호출이 끝나기 전에 this 포인터는 구분 기호의 다음 비트('m')를 가리키는 데 사용됩니다. 따라서
및이 될 수 있습니다. 순차적으로 추출됩니다. . . . 등. . . . .
null 값을 할당해야 하는 이유는 결론을 기억하거나 strtok의 소스 코드를 확인하면 됩니다. 이 글의 마지막 부분에 몇 가지 소개가 있을 것입니다.
물론, 문제가 발생하는 것을 좋아하는 사람들도 있으며 루틴에 따라 카드를 플레이해야 합니다. 그들은 할당하지 않고 버퍼에 값을 계속 할당하면 어떤 결과가 나올지 보고 싶어합니다. 널값. 사실, 대답은 상상할 수 있습니다. 다시 버퍼를 전달하는 것은 문자열의 시작 부분부터 구분 기호 구분 기호를 검색하는 것과 동일하며 이때 버퍼가 수정되었습니다(보이는 부분에는 ",Fred"만 남음). 따라서 결과는 다음과 같습니다. 구분 기호 delim 을(를) 찾을 수 없습니다.
"1"에서 언급한 바와 같이,부분 문자열이 추출되면 strtok의 반환 값(반환 값이 포인터 buf에 할당된다고 가정)이 부분 문자열에 대한 포인터입니다. 이 포인터는 소스 문자열에서 부분 문자열의 시작 위치를 가리킵니다. 하위 문자열 끝의 다음 문자는 추출 전 구분 기호이지만 추출 후에는 '/0'으로 수정됩니다.따라서 buf의 값을 출력하면 하위 문자열의 내용을 성공적으로 출력할 수 있습니다.
하위 문자열이 추출되지 않으면 함수는 어떤 값을 반환하나요?
위 그림에서 볼 수 있듯이 버퍼에는 구분 기호 delim이 포함되어 있지 않습니다. strtok를 호출한 후 buf의 값은
입니다. 찾을 수 없기 때문에 buf는 소스 문자열의 첫 번째 주소를 가리키며 인쇄된 출력 값은 의 전체 값입니다. 전체 문자열.
함수의 반환값이 NULL이 되는 경우는 언제인가요?
바이두백과사전에 "분할된 문자열이 없으면 NULL이 반환된다."라고 되어 있는데, 굉장히 모호한 문장이다. 이 문제를 명확하게 이해하려면 strtok의 구현 원리를 살펴봐야 할 수도 있습니다. 먼저 실험적인 설명이 있습니다.
strtok이 처음 호출되면 buf가 ",Fred"를 가리킨다는 것은 의심의 여지가 없습니다.
두 번째로 strtok을 호출합니다. 첫 번째 매개변수가 NULL이므로 함수가 마지막 호출에서 저장된 이 포인터의 위치에서 계속 분해된다는 의미입니다. 즉, "male 25"가 분해됩니다. 분해가 완료된 후 buf는 "male"을 가리킵니다.
strtok이 세 번째 호출되면 매개변수가 계속 NULL로 설정됩니다. 이때 두 번째로 저장된 이 포인터의 위치가 분해되기 시작합니다. 즉, "25"가 분해됩니다. 구분 기호 delim을 포함하는 하위 문자열을 찾을 수 없기 때문에 buf는 "25"를 가리킵니다.
네 번째 호출에서는 매개변수가 여전히 NULL입니다. 이때 세 번째 호출에서 저장된 this 포인터는 문자열 '/0'의 끝을 가리키고 있으며 더 이상 분해할 수 없습니다. 따라서 함수는 NULL을 반환하는데, 이는 바이두 백과사전에서 "분할된 문자열이 없을 때 NULL을 반환하는 함수입니다.")
많은 사람들이 strtok을 사용할 때 함수가 구분 기호와 완전히 일치하는 것을 당연하게 여깁니다. 예를 들어 delim="ab"이면 문자열 "acdab"에 대해 함수는 "acd "를 추출합니다. 적어도 제가 처음 사용했을 때는 그렇게 생각했습니다. 사실 우리는 모두 틀렸습니다. 다음 예제를 살펴보면서 이 문제를 발견했습니다.
첫 번째 통화 결과는 우리가 예상했던 것과는 다르게 '프레드'였습니다.이게 왜요?
GNU C 라이브러리에 있는 strtok의 함수 정의인 "DELIM에서 문자로 구분된 토큰으로 S를 구문 분석합니다"로 돌아갑니다.즉, delim에 포함된 문자를 엄격한 일치 대신 구분 기호로 사용할 수 있습니다. 구분 기호는 구분 기호 모음으로 이해될 수 있습니다. 이 점이 매우 중요합니다~
물론 문자열을 분해할 때 여러 개의 구분 기호를 사용하는 경우는 거의 없습니다. 이로 인해 많은 사람들이 예제를 작성할 때 구분 기호가 하나인 경우에만 논의하게 됩니다. 예시를 볼 때 delim의 역할을 오해하는 사람들이 더 많습니다.
첫 번째 문자가 구분 기호인 경우는 매우 특별한 경우로 간주할 수 없습니다. 문자열은 기존 분해 아이디어에 따라 올바르게 분해될 수도 있습니다.
제가 지적하고 싶은 점은 strtok이 이러한 상황에 대해 일반적인 처리 방법보다 빠른 처리 방법을 채택한다는 것입니다.
위 예시와 같습니다. 쉼표로 구분된 문자열 "Fred Male 25"는 단 한 번의 호출로 얻을 수 있으며, F 앞의 ','는 무시됩니다.strtok은 호출 시 시작 위치부터 시작하는 구분 기호를 무시하는 것을 볼 수 있습니다.이 내용은 strtok 소스코드에서 확인할 수 있습니다.
이 문서의 예제는 모두 소스 문자열을 문자열 배열 변수로 저장합니다. 소스 문자열을 문자열 상수로 정의하면 strtok 함수가 소스 문자열의 값을 수정하려고 시도하기 때문에 프로그램에서 예외가 발생한다고 상상할 수 있습니다.
위 내용은 strtok 함수의 사용법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!