>  기사  >  백엔드 개발  >  C 언어에서 강제 유형 변환을 수행하는 방법

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

青灯夜游
青灯夜游원래의
2021-04-25 16:43:5948291검색

C 언어에서는 "(새 유형 이름) 데이터 또는 표현식" 문을 통해 강제 유형 변환을 수행할 수 있습니다. 예를 들어 "(float) 100"은 값 100(기본값은 int 유형)을 float 유형으로 변환합니다. (int)(x+y)"는 "x+y"라는 수식의 결과를 정수형으로 변환하는 것입니다.

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

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

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

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

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

  • 강제 유형 변환

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

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

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

(type_name) expression

type_name은 새 유형 이름이고 표현식은 표현식입니다. 예:

(float) a;  //将变量 a 转换为 float 类型
(int)(x+y);  //把表达式 x+y 的结果转换为 int 整型
(float) 100;  //将数值 100(默认为int类型)转换为 float 类型

다음은 캐스트 유형 변환이 필요한 전형적인 예입니다.

#include <stdio.h>
int main(){
    int sum = 103;  //总数
    int count = 7;  //数目
    double average;  //平均数
    average = (double) sum / count;
    printf("Average is %lf!\n", average);
    return 0;
}

실행 결과:

Average is 14.714286!

sum과 count 모두 int 유형입니다. 개입이 수행되지 않으면 sum / count code> 연산결과도 int형이고 소수부분은 버리게 됩니다. 평균은 double형이고 소수부분을 받을 수는 있지만 충분하지 않아서 소수부분은 미리 "거세"되어 있고, 정수 부분만 받을 수 있습니다. 이는 나누기 연산의 결과가 심각하게 왜곡됩니다. <code>sum / count的运算结果也是 int 类型,小数部分将被丢弃;虽然是 average 是 double 类型,可以接收小数部分,但是心有余力不足,小数部分提前就被“阉割”了,它只能接收到整数部分,这就导致除法运算的结果严重失真。

既然 average 是 double 类型,为何不充分利用,尽量提高运算结果的精度呢?为了达到这个目标,我们只要将 sum 或者 count 其中之一转换为 double 类型即可。上面的代码中,我们将 sum 强制转换为 double 类型,这样sum / count的结果也将变成 double 类型,就可以保留小数部分了,average 接收到的值也会更加精确。

在这段代码中,有两点需要注意:

  • 对于除法运算,如果除数和被除数都是整数,那么运算结果也是整数,小数部分将被直接丢弃;如果除数和被除数其中有一个是小数,那么运算结果也是小数。

  • ( )的优先级高于/,对于表达式(double) sum / count,会先执行(double) sum,将 sum 转换为 double 类型,然后再进行除法运算,这样运算结果也是 double 类型,能够保留小数部分。注意不要写作(double) (sum / count),这样写运算结果将是 3.000000

    평균은 이중 유형이므로 이를 최대한 활용하여 연산 결과의 정확성을 향상시켜 보는 것은 어떨까요? 이 목표를 달성하려면 sum 또는 count 중 하나만 double 유형으로 변환하면 됩니다. 위 코드에서는 sum을 double형으로 강제 변환하여 sum / count의 결과도 double형이 되도록 하고, 소수 부분은 그대로 유지하며 평균으로 받는 값은 더 정확합니다.
이 코드에는 두 가지 주의할 점이 있습니다.


나눗셈 연산의 경우 제수와 피제수가 모두 정수이면 연산 결과도 정수이고 소수 부분은 직접 삭제됩니다. 제수나 피제수 중 하나가 소수이면 연산 결과도 소수입니다.

🎜🎜🎜( )/보다 우선순위가 높습니다. (double) sum / count 표현식의 경우 가 실행됩니다. 첫 번째 (이중) 합계, 합계를 이중 유형으로 변환한 다음 나눗셈 연산을 수행하여 연산 결과도 이중 유형이 되고 소수 부분을 유지할 수 있습니다. (double) (sum / count)를 쓰지 않도록 주의하세요. 그렇지 않으면 연산 결과는 3.000000이 되고 소수 부분은 여전히 ​​유지되지 않습니다. 🎜🎜🎜🎜관련 추천: "🎜C 언어 비디오 튜토리얼🎜"🎜🎜

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

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