리눅스와 유닉스의 차이?
어떤 구조체를 만들어 놓고 해당 구조체에 모든 객체 정보를 저장하여 바이너리 파일로 생성하는 프로그램을 만들었는데요.
해당 바이너리 파일의 정보를 읽어와서 처리도중에 문제가 발생했답니다.
해당 구조체내에 어떤 정보를 참조하려구 호출을 했는데 문제가 발생해서 쓰레기 값이 호출됐는데 유닉스로 컴파일한거랑 리눅스로 컴파일한것이 차이가 나네요...
예를 들어
구조체내의 변수를
float Address[3];
이렇게 선언해 놓고 값을 아래와 같이 입력했습니다.
Address[0] = 1.0;
Address[1] = 0.143;
Address[2] = 1.0;
그리고 바이너리 파일로 생성했습니다.
그리고 처리 프로그램으로 해당 바이너리 파일을 읽어와서 작업합니다.
(참고로 입력 프로그램과 처리 프로그램의 구조체는 동일한 구조체로 되어있습니다. 입력프로그램에서 입력된 구조체의 값이 바이너리 파일을 읽어와서 처리 프로그램의 구조체에 입력되는 방식입니다.)
처리 프로그램의 어떤 루틴에서 Address 배열에 저장된 값을 이용해 처리를 수행하는데 아래와 같은 문제가 발생했습니다.
void Process_Address(int number) <-- 여기서 number가 0~2가 와야하는데 50이 들어왔습니다.
{
float AddressX = 0.0;
AddressX = 구조체->Address[number];
...
}
입력프로그램에서 입력한 데이터가 순차적으로 저장되었기 때문에 입력된 값들중 하나가 호출이 되긴했는데...
주소는 같은데 유닉스와 리눅스가 참조하는 값이 서로 다르게 나오더군요..(때문에 처리 결과가 다르게 나타났습니다.)
유닉스는 AddressX 가 152이 나오고 리눅스는 20이 나오네요.(해당값은 항상 동일하게 나왔답니다...)
오류처리 하면 되는데 이렇게 다른 결과가 나오니 궁금해 지네요..
양 OS 의 endian 은
양 OS 의 endian 은 같은가요?
Neogeo - Future is Now.
Neogeo - Future is Now.
어떤 유닉스말하는건지 궁금
즐린
freebsd같은 BSD계열인지
solaris계열인지
sco unix인지
xenix인지
xnu인지
A/UX인지
궁금
즐린
유닉스 리눅스의 차이라기보단..
윗분 말씀처럼 엔디안의 차이 같은데요..
little endian인지 big endian인지 OS의 엔디안이 같은지 확인해보시는게 좋을것 같아요..
그리고 메모리주소를 이용할때 물리적으로 메모리 주소를 직접 가져오지 못하는 것도 있어요.. 그래서 세그먼트오류가 날때도 있으니 세그먼트오류가 나오면 가상메모리 주소를 이용해서 가져와야하는것도 있고요.. 저도 잘은 모르지만 불러오는 값이 다르다는것은 엔디안 차이가 아닐까 생각합니다.
혹시 GDB가 가능하다면.. 불러오는 값의 헥사값을 확인해보세요.. 예를 들어0xef11 값이들어와야 하는데 0x11ef로 들어오는지
바이너리 파일...을 읽는 거라면...
바이너리 파일...을 읽는 거라면...
엔디안 문제일꺼 같군요 ^^
댓글 달기