C 언어 대소문자 변환

  • 3 minutes to read

이번 글에서는 C 언어의 strupr()strlwr() 함수에 대해 알아보겠습니다.

C 언어에서 strupr() 함수는 문자열을 대문자로 변경하고, strlwr() 함수는 문자열을 소문자로 변경합니다. 이 두 함수는 <string.h> 헤더 파일에 정의되어 있습니다.

아래는 strupr()strlwr() 함수를 사용하여 입력받은 문자열을 대문자와 소문자로 변경하는 예제 코드입니다.

코드: string_case_conversion.c

// 대문자로 변경 : strupr()
// 소문자로 변경 : strlwr()
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>

int main(void)
{
    char buffer[80];

    printf("영문 문자열을 입력 : ");
    fgets(buffer, sizeof(buffer), stdin);

    _strupr(buffer); // String UpperCase
    printf("%s", buffer);

    _strlwr(buffer); // String LowerCase
    printf("%s", buffer);

    return 0;
}
영문 문자열을 입력 : VisualAcademy
VISUALACADEMY
visualacademy

위 코드에서 fgets() 함수를 사용하여 문자열을 입력받습니다. 입력받은 문자열을 strupr() 함수와 strlwr() 함수로 각각 대문자와 소문자로 변경한 후, printf() 함수로 출력합니다.

이 예제 코드를 실행하면 입력한 문자열이 먼저 대문자로 변경되어 출력되고, 그 다음 소문자로 변경되어 출력됩니다.

위 예제 코드를 통해 strupr()strlwr() 함수가 어떻게 사용되는지 간단히 알아보았습니다. 이러한 문자열 처리 함수는 C 언어에서 매우 유용하게 사용됩니다.

주의할 점

C 언어 표준에서는 strupr()strlwr() 함수를 제공하지만, 이 함수들은 보안 취약점을 가지고 있기 때문에, 대부분의 C 라이브러리에서는 더 안전한 함수인 _strupr()_strlwr() 함수를 사용하는 것을 권장합니다.

strupr()strlwr() 함수는 입력된 문자열의 길이를 체크하지 않기 때문에, 버퍼 오버런(buffer overrun)과 같은 보안 문제를 야기할 수 있습니다. 예를 들어, 입력된 문자열이 버퍼의 크기를 초과하는 경우, strupr()strlwr() 함수는 이를 감지하지 못하고, 버퍼를 넘어서는 데이터를 다룰 수 있습니다.

이에 비해, _strupr()_strlwr() 함수는 입력된 문자열의 길이를 체크하고, 버퍼 오버런과 같은 보안 취약점을 예방할 수 있습니다. 따라서, _strupr()_strlwr() 함수를 사용하는 것이 더 안전합니다.

그러나 _strupr()_strlwr() 함수는 일부 C 라이브러리에서 지원되지 않을 수 있습니다. 따라서, 이러한 경우에는 대신 strupr_s()strlwr_s()와 같은 보안 강화 버전의 함수를 사용하거나, 직접 함수를 구현하여 사용할 수 있습니다.

따라서, 안전한 프로그래밍을 위해 _strupr()_strlwr() 함수를 사용하는 것이 좋습니다.

VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com