>백엔드 개발 >C#.Net 튜토리얼 >C 언어에서 강제 유형 변환을 수행하는 방법

C 언어에서 강제 유형 변환을 수행하는 방법

青灯夜游
青灯夜游원래의
2023-01-04 11:04:037469검색

C 언어에서는 "(type_name) 표현식" 문을 통해 강제 유형 변환을 수행할 수 있습니다. 매개변수 "type_name"은 새 유형의 이름을 나타냅니다. 예를 들어 "(float)100"은 int 유형 값을 100으로 변환합니다. float 유형에. 강제 유형 변환은 프로그래머가 명시적으로 제안하는 유형 변환으로, 특정 형식의 코드를 통해 지정해야 합니다. 프로그래밍 시 유형 변환이 필요할 때마다 강제 유형 변환 연산자를 사용하는 것이 좋은 프로그래밍 습관입니다.

C 언어에서 강제 유형 변환을 수행하는 방법

이 튜토리얼의 운영 환경: Windows 7 시스템, c99 버전, Dell G3 컴퓨터.

데이터 유형 변환은 데이터(변수, 값, 표현식 결과 등)를 한 유형에서 다른 유형으로 변환하는 것입니다.

C 언어에는 두 가지 데이터 유형 방법이 있습니다.

  • 자동 유형 변환: 컴파일러에 의해 자동, 암시적, 비밀리에 수행되는 데이터 유형 변환입니다. 이 변환은 프로그래머 개입이 필요하지 않으며 자동으로 발생합니다.

  • 강제 유형 변환

C 언어의 강제 유형 변환에 대해 자세히 살펴보겠습니다.

강제 유형 변환

자동 유형 변환은 코드의 컨텍스트를 기반으로 한 컴파일러 자체 판단의 결과입니다. 때로는 "지능적"이지 않고 모든 요구 사항을 충족할 수 없습니다. 필요한 경우 프로그래머는 코드 자체에서 유형 변환을 명시적으로 제안할 수도 있는데, 이를 강제 유형 변환이라고 합니다.

자동 유형 변환은 컴파일러에 의해 자동으로 암시적으로 수행되는 유형 변환이며 코드에 반영될 필요가 없습니다. 강제 유형 변환은 프로그래머가 명시적으로 제안한 유형 변환이며 특정 코드 형식을 통해 지정해야 합니다. 유형 변환. 즉, 자동 유형 변환에는 프로그래머 개입이 필요하지 않지만 필수 유형 변환에는 프로그래머 개입이 필요합니다.

강제 유형 변환의 형식은 다음과 같습니다.

(type_name) expression
  • type_name은 새로운 유형 이름입니다. type_name为新类型名称

  • expression

expression은 표현식

예:

(float) a;  //将变量 a 转换为 float 类型
(int)(x+y);  //把表达式 x+y 的结果转换为 int 整型
(float) 100;  //将数值 100(默认为int类型)转换为 float 类型
C 언어에서 강제 유형 변환을 수행하는 방법 부동 소수점 숫자를 얻기 위해 정수 변수를 다른 정수 변수로 나누기 위해 형변환 연산자를 사용하는 다음 예를 살펴보십시오. 따라서 sum의 값은 먼저 double 유형으로 변환된 다음 count로 나누어져 double 유형의 값이 됩니다.

유형 변환은 암시적으로 수행되거나 컴파일러에 의해 자동으로 수행되거나 명시적으로 캐스트 연산자를 사용하여 지정될 수 있습니다. 프로그래밍할 때 유형 변환이 필요할 때마다 캐스트 연산자를 사용하는 것이 좋은 프로그래밍 습관입니다.

형 변환은 일시적일 뿐입니다자동 형 변환이든 강제 형 변환이든 이 작업에 대한 임시 변환일 뿐이며 변환 결과도 임시 메모리 공간에 저장됩니다. 데이터의 원래 유형 또는 값. 다음 예를 살펴보세요.

#include <stdio.h>
 
int main()
{
   int sum = 17, count = 5;
   double mean;
 
   mean = (double) sum / count;
   printf("Value of mean : %f\n", mean );
 
}

C 언어에서 강제 유형 변환을 수행하는 방법 total 변수는 total_int 변수에 할당되기 전에 int 유형으로 변환됩니다. 이 변환은 total 변수 자체의 유형과 값에 영향을 주지 않습니다. . 합계의 값이 변경되면 합계의 출력 결과는 400.000000이 되고, 합계의 종류가 변경되면 단위의 출력 결과는 80.000000이 됩니다.

확장된 지식: 일반적으로 사용되는 산술 변환일반적으로 사용되는 산술 변환은 암시적으로 값을 동일한 유형으로 강제합니다. 컴파일러는 먼저 정수 승격을 수행하고 피연산자 유형이 다른 경우 다음 계층 구조에서 발생하는 최상위 유형으로 변환됩니다.

C 언어에서 강제 유형 변환을 수행하는 방법일반적인 산술 변환은 할당 연산자, 논리 연산자 && 및 |에 적용되지 않습니다. |. 이 개념을 이해하기 위해 다음 예를 살펴보겠습니다.

#include <stdio.h>
int main(){
    double total = 400.8;  //总价
    int count = 5;  //数目
    double unit;  //单价
    int total_int = (int)total;
    unit = total / count;
    printf("total=%lf, total_int=%d, unit=%lf\n", total, total_int, unit);
    return 0;
}

위 코드를 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

#include <stdio.h>
 
int main()
{
   int  i = 17;
   char c = &#39;c&#39;; /* ascii 值是 99 */
   float sum;
 
   sum = i + c;
   printf("Value of sum : %f\n", sum );
 
}

여기서 c는 먼저 정수로 변환되지만 최종 값은 float 유형이므로 , 따라서 일반적인 산술 변환이 적용됩니다. 컴파일러는 i와 c를 부동 소수점 유형으로 변환하고 이를 추가하여 부동 소수점 숫자를 얻습니다.

【관련 추천:

C 언어 동영상 튜토리얼

, 프로그래밍 교육

위 내용은 C 언어에서 강제 유형 변환을 수행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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