C 언어에서는 "(type_name) 표현식" 문을 통해 강제 유형 변환을 수행할 수 있습니다. 매개변수 "type_name"은 새 유형의 이름을 나타냅니다. 예를 들어 "(float)100"은 int 유형 값을 100으로 변환합니다. float 유형에. 강제 유형 변환은 프로그래머가 명시적으로 제안하는 유형 변환으로, 특정 형식의 코드를 통해 지정해야 합니다. 프로그래밍 시 유형 변환이 필요할 때마다 강제 유형 변환 연산자를 사용하는 것이 좋은 프로그래밍 습관입니다.
이 튜토리얼의 운영 환경: 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 类型
유형 변환은 암시적으로 수행되거나 컴파일러에 의해 자동으로 수행되거나 명시적으로 캐스트 연산자를 사용하여 지정될 수 있습니다. 프로그래밍할 때 유형 변환이 필요할 때마다 캐스트 연산자를 사용하는 것이 좋은 프로그래밍 습관입니다.
형 변환은 일시적일 뿐입니다자동 형 변환이든 강제 형 변환이든 이 작업에 대한 임시 변환일 뿐이며 변환 결과도 임시 메모리 공간에 저장됩니다. 데이터의 원래 유형 또는 값. 다음 예를 살펴보세요.
#include <stdio.h> int main() { int sum = 17, count = 5; double mean; mean = (double) sum / count; printf("Value of mean : %f\n", mean ); }
total 변수는 total_int 변수에 할당되기 전에 int 유형으로 변환됩니다. 이 변환은 total 변수 자체의 유형과 값에 영향을 주지 않습니다. . 합계의 값이 변경되면 합계의 출력 결과는 400.000000이 되고, 합계의 종류가 변경되면 단위의 출력 결과는 80.000000이 됩니다.
확장된 지식: 일반적으로 사용되는 산술 변환일반적으로 사용되는 산술 변환은 암시적으로 값을 동일한 유형으로 강제합니다. 컴파일러는 먼저 정수 승격을 수행하고 피연산자 유형이 다른 경우 다음 계층 구조에서 발생하는 최상위 유형으로 변환됩니다.
일반적인 산술 변환은 할당 연산자, 논리 연산자 && 및 |에 적용되지 않습니다. |. 이 개념을 이해하기 위해 다음 예를 살펴보겠습니다.
#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 = 'c'; /* ascii 值是 99 */ float sum; sum = i + c; printf("Value of sum : %f\n", sum ); }
여기서 c는 먼저 정수로 변환되지만 최종 값은 float 유형이므로 , 따라서 일반적인 산술 변환이 적용됩니다. 컴파일러는 i와 c를 부동 소수점 유형으로 변환하고 이를 추가하여 부동 소수점 숫자를 얻습니다.
【관련 추천:
C 언어 동영상 튜토리얼, 프로그래밍 교육】
위 내용은 C 언어에서 강제 유형 변환을 수행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!