[완료][C]exe파일을 열어서 1바이트만큼읽어들이는건데 왜 안되나요?
글쓴이: nexusz99 / 작성시간: 금, 2009/05/08 - 5:54오후
#include <stdio.h> int main(int agrv, char **argc) { FILE *read = fopen("test2.exe","rb"); char temp; fread(&temp,1,1,read); printf("%x",temp); fclose(read); fclose(write); }
이렇게 작성했는데 Runtime 에러가나네요.. 아무래도 파일을 못읽는거 같은데 왜 그런거죠?
아 그리고
ffffffbe;
이런 숫자는 1바이트인가요 4바이트 인가요? 16진수 2자리는 1바이트라고 배운거 같은데..ㅠㅠ
char a = -1;
printf("%x",a);
하면 ffffffff 가 나오네요.ㅠㅠ
Forums:
좋은 C 언어 책을
좋은 C 언어 책을 읽어 보시길 추천해 드립니다.
int main(int agrv, char
int main(int agrv, char **argc)
잘못되었네요.
실행순간에 매우꼬이겠는데요..
총체적 난국입니다....
1. 매개변수 이름이기에 사용할 때만 잘 쓰면 괜찮지만...
argc -> argument count
argv -> argument vector
를 의미합니다.
count(개수)니까 int 타입이어야겠죠, char*의 시작주소를 받으니까 char**여야겠죠.
int argc, char** argv는 지켜주시는 게 좋습니다.
또는 오픈할 파일 이름을 명령행 인자로 전달할 게 아니시라면 void라고만 적어주세요.
2. 마지막에 fclose(write)는 왜 들어 있는 것인지요?
write로 열려 있는 것이 없는데.. 삭제하세요.
3. test2.exe가 실행프로그램이 인식할 수 있는 패스에 존재하지 않는 파일이라면
절대 경로나 상대 경로를 통해 프로그램의 위치를 인식시킬 수 있도록 하세요.
4. FILE *read = fopen("test2.exe", "rb");
이름으로 read와 같은 간단한 이름을 사용하는 것은 좋지 않습니다.
나중을 위해서 의미있는 이름으로 바꿔보세요.
5. 1바이트로는 16진수 2자리까지 표현할 수 있습니다.
0xff => f(10진수15) * 16 + f(10진수15) = 240 + 15 = 255
0x0~0xff, 0~255까지는 1바이트로 표현 가능하죠.
알고 계신 것이 맞습니다.
6. char a = -1;
char는 시스템에 따라 signed/unsigned가 결정납니다.
그러나 그것과 상관없이 내부표현 형식은 동일하지요.
아마 사용하는 시스템이 2의 보수 방식으로 음수를 표현하고 있을 것입니다.
-1은 2의 보수 표현으로 0xff이므로 ff라 출력되기 기대하셨겠지만,
가변인자이므로 integral promotion이 발생해 int(0xffffffff)로 넘어갑니다.
%x는 unsigned int를 받아 hexadecimal로 출력해 주므로, 그대로 출력하면
ffffffff이 나오게 됩니다.
7. 소스 코드를 올리실 때는
<code> </code>를 이용해 주세요.
---------------------------
Go to the U-City
----------------------------------------------------------------------------------------
Don't Feed the Trolls!
----------------------------------------------------------------------------------------
댓글 달기