c언어 공부중인데 자꾸 이상한 결과가 나옵니다
한봄찬
질문 제목 : 질문 내용 :
128bit 자료형을 내가 정의해서 덧셈하는 함수를 만드는중인데 안되는 실력으로 막 만들다보니까 코드가 개판인데
원래는 double op1,op2를 memcpy로 비트시퀀스를 변형시키지 않고 그대로 다른 자료형으로 옮겨서 부동소수점
부호, 지수부, 가수부를 따로 연산해서 다 합쳐서 super.data에다가 다 넣으면 덧셈연산한 결과가 되도록 하려고 한건데
지금 다른것도 엉망인거같긴한데 이해가 안가는게 맨밑에 찐하게 한 부분입니다//addtion// e를 올리고 m을 나눠서 e을 맞춘다. e는 그대로 두고 m끼리 더한다.
//-e랑 m을 구하는 함수가 필요하다.#include stdio.h
#include memory.h
#include stdlib.h
#include string.h
#include math.htypedef struct{
char data[16];
}super;int main(void)
{
super super1;
unsigned int dif,i;
unsigned short expnum1,expnum2;
unsigned long long int bitseq,m1,m2,exponent,addm;
double op1,op2;
op1=1;
op2=0;//e와 m을 구하는 부분. e는 unsigned short에 부호부와 지수부를 집어넣고 쉬프트로 부호부를 잘라낸다.
//m 은unsigned long long int에 op1,op2를 복사해서 쉬프트로 지수부와 부호부를 잘라내고 m을 덧셈 할때를 위해 한칸을 남긴다.
memcpy(&bitseq,&op1,sizeof(double));
exponent=(bitseq1)53;
memcpy(&expnum1,&exponent,sizeof(short));
m1=(bitseq12)1;memcpy(&expnum2,&op2,sizeof(short));
exponent=(bitseq1)53;
memcpy(&expnum2,&exponent,sizeof(short));
m2=(bitseq12)1;//e를 올려서 맞추고 m은 나누는 부분
if(expnum1expnum2){
expnum2=expnum1;
m2=m2(expnum1-expnum2);
}
else{
expnum1=expnum2;
m1=m1(expnum2-expnum1);
}
//e의 앞에 부호부를 설정한다. 이제 부호부+지수부가 만들어졌다.
if(op1+op20)
expnum1=expnum1+pow(2.0,16.0);
//m을 더함. 지수부+e+m만 하면 된다. 문제)가수가 2를 넘어갈경우.addm=m1+m2;
//super에다가 다 집어넣자
memcpy(super1.data,&expnum1,sizeof(short));
memcpy(super1.data+2,&addm,14);for(i=0;i16;i++)
printf(%.2x\n,super1.data[i]);return 0;
}
원래 없어도 되는건데 비트시퀀스로 어떻게 나오는지 확인해볼려고 저렇게 넣어봤습니다.
근데 char 형은 분명히 1바이트라고 알고 있고 16진수로 출력시켰는데 결과가
ffffffff
03
00
00
00
00
00
00
00
00
ffffffff
03
00
00
00
00
이렇게나오는데 ffffffff이런건 왜나오는거죠? %.2x로 두개씩 나오도록 했는데도 저렇게 나오네요
100%국비, 훈련수당지급, 1:1취업지원, PLC, HMI, SCADA, IoT
게임개발, 게임아트, 포트폴리오로 게임회사 취업 & 게임학과 입시 모두 잡다!
C언어 인강만으로 합격가능, 단기완성, 무한반복 전 강좌 스마트폰 학습가능
어디서도 느끼지 못한 새로운 온라인 강의! 당신의 꿈을 이루어드립니다.
유아,초,중,고등까지 자바스크립트. 파이썬, 사고력키우기, 앱창작, 게임개발 코딩
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2704557 | Sleep 함수에 대해 궁금한게 생겼습니다. (10) | 횃대비 | 2025-08-11 |
2704529 | 메모리 동적 할당 관련해서 질문 있습니다~ | 궁수자리 | 2025-08-11 |
2704497 | int double char 같은것좀 좀만 더 가르쳐 주세요 (6) | 로지 | 2025-08-10 |
2704473 | 구조체 배열 초기화 질문 | 꽃은별 | 2025-08-10 |
2704445 | 배열과 조건문에 관한질문 (3) | 찬솔큰 | 2025-08-10 |
2704417 | 이진 트리 깊이 값 구하는것 질문입니다. | 푸른잎 | 2025-08-10 |
2704391 | 자료 유형에 관련된 문제입니다. (2) | 늘솜 | 2025-08-09 |
2704365 | c언어 문제안되서물어봅니다 (3) | 맑은가람 | 2025-08-09 |
2704338 | 다항식의 뺄셈에 대해 질문드립니다... (1) | 여자 | 2025-08-09 |
2704311 | 센서를 이용한 라인 주행인데 명령어좀 알려주세요 ㅠ_ㅠ (3) | 초록이 | 2025-08-09 |
2704284 | 배열for문;; (3) | 은솜 | 2025-08-08 |
2704255 | readline(int fd, char *buf, int nbytes)함수를 구현하는법좀..ㅠㅠ | 파라나 | 2025-08-08 |
2704196 | 간단한 c언어좀 만들어주세요 (2) | 슬S2아 | 2025-08-08 |
2704118 | 성적에서 등수 구하기 (4) | 딥레드 | 2025-08-07 |
2704062 | 알고리즘 알려주세요 | 나리 | 2025-08-06 |
2704035 | 답은 나오는데 과정에서 `` 약간 이상합니다.ㅎㅎ 답만나와버려요 | 핫블랙 | 2025-08-06 |
2703979 | 문자열 EEPROM 작성 방법 문의드립니다. | 그녀는귀여웠다 | 2025-08-06 |
2703954 | 키보드를 입력하면 캐릭터를 움직이기 질문 (7) | 좋아해 | 2025-08-05 |
2703924 | 계속 에러가... (4) | 눈꽃 | 2025-08-05 |
2703897 | 배열의 최댓값과 최솟값 차이 구하기 (1) | 하늬 | 2025-08-05 |