부동 소수점 연산의 불일치: x86 대 x64
부동 소수점 연산과 관련된 코드 조각에서 MS VS 사이에 불일치가 발생합니다. 2010은 x86 및 x64 아키텍처를 대상으로 하는 빌드입니다. 코드는 다음과 같습니다.
float a = 50.0f; float b = 65.0f; float c = 1.3f; float d = a*c; bool bLarger1 = d <p><strong>불일치:</strong></p>
- x86 빌드: 변수 bLarger1이 false입니다(d와 b 모두) 65.0으로 설정됨), bLarger2는 true입니다.
- x64 Build: bLarger1과 bLarger2는 모두 false입니다.
기본 문제:
이 불일치는 bool bLarger2 = (a*c)
부동 소수점 단위의 차이점:
중요한 차이점은 둘이 사용하는 부동 소수점 단위에 있습니다. 아키텍처. x86 아키텍처는 단정밀도(일반적으로 배정밀도)보다 더 높은 정밀도로 계산을 수행하는 x87 부동 소수점 단위를 사용합니다. 이와 대조적으로 x64 아키텍처는 순수 단정밀도 계산을 수행하는 SSE 부동 소수점 단위를 사용합니다.
곱셈에 미치는 영향:
bLarger1 표현식에서, a와 c의 곱셈은 하드웨어 곱셈 명령에 의해 수행됩니다. 이 명령어는 배정밀도 정밀도를 사용하므로 d가 65.0으로 설정됩니다.
그러나 bLarger2 표현식에서는 유형 변환(a*c)으로 인해 곱셈이 명시적으로 단정밀도로 수행됩니다. 결과적으로 (a*c)는 64.999992로 설정됩니다.
x87 정밀 제어:
기본적으로 x87 장치는 배정밀도로 작동합니다. 하지만 _controlfp 함수를 사용하여 단정밀도 계산을 수행하도록 장치를 설득할 수 있습니다.
_controlfp(_PC_24, _MCW_PC);
이 줄을 32비트 코드에 추가하면 bLarger1과 bLarger2가 모두 false로 설정됩니다.
컴파일러 옵션:
최신 버전의 Visual Studio에서는 컴파일러가 32비트 대상에 대해서도 SSE 명령을 내보낼 수 있습니다. 이는 다양한 아키텍처 전반에 걸쳐 부동 소수점 연산의 일관성을 보장합니다.
위 내용은 x86 아키텍처와 x64 아키텍처 간에 부동 소수점 연산이 다른 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

GULC는 최소 오버 헤드, 공격적인 인라인 및 컴파일러 최적화 우선 순위를 정하는 고성능 C 라이브러리입니다. 고주파 거래 및 임베디드 시스템과 같은 성능 크리티컬 애플리케이션에 이상적 인 디자인은 단순성, 모듈을 강조합니다.

이 기사는 기본 (int, float, char 등), 파생 (배열, 포인터, 스트러크) 및 공극 유형을 포함하는 C 함수 리턴 유형에 대해 자세히 설명합니다. 컴파일러는 함수 선언과 반환 명령문을 통해 반환 유형을 결정합니다.

이 기사는 C 함수 선언 대 정의, 인수 통과 (값 및 포인터 별), 리턴 값 및 메모리 누출 및 유형 불일치와 같은 일반적인 함정을 설명합니다. 모듈성 및 Provi에 대한 선언의 중요성을 강조합니다.

이 기사는 문자열 케이스 변환에 대한 C 기능을 자세히 설명합니다. ctype.h의 toupper () 및 tolower ()를 사용하고 문자열을 통한 반복 및 널 터미네이터를 처리합니다. ctype.h를 잊어 버리고 문자 그럴을 수정하는 것과 같은 일반적인 함정은 다음과 같습니다.

이 기사에서는 C 기능 반환 값 저장을 검사합니다. 작은 반환 값은 일반적으로 속도 레지스터에 저장됩니다. 더 큰 값은 포인터에 메모리 (스택 또는 힙)를 사용하여 수명에 영향을 미치고 수동 메모리 관리가 필요할 수 있습니다. 직접 ACC

이 기사에서는 컨테이너, 반복자, 알고리즘 및 함수 인 핵심 구성 요소에 중점을 둔 C 표준 템플릿 라이브러리 (STL)에 대해 설명합니다. 일반적인 프로그래밍을 가능하게하기 위해 이러한 상호 작용, 코드 효율성 및 가독성 개선 방법에 대해 자세히 설명합니다.

이 기사는 형용사 "별개", 문법 기능, 공통 문구 (예 : "구별", "뚜렷하게 다른") 및 공식 대 비공식의 미묘한 응용 프로그램의 다각적 인 사용을 분석합니다.

이 기사는 효율적인 STL 알고리즘 사용을 자세히 설명합니다. 데이터 구조 선택 (벡터 대 목록), 알고리즘 복잡성 분석 (예 : std :: sort vs. std :: partial_sort), 반복자 사용 및 병렬 실행을 강조합니다. 일반적인 함정과 같은


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)
