"엔디언, 빅엔디언, 리틀엔디언"의 두 판 사이의 차이

잔글 (봇: 자동으로 텍스트 교체 (-source +syntaxhighlight))
 
(사용자 3명의 중간 판 11개는 보이지 않습니다)
8번째 줄: 8번째 줄:
* Byte Order과 연관된 개념
* Byte Order과 연관된 개념
* 엔디언은 메모리의 배열하는 방법
* 엔디언은 메모리의 배열하는 방법
* 메모리 같은 1차원 공간에 여러 개의 연속된 대상을 배열하는 방법


==빅엔디언, 리틀엔디언==
==빅엔디언, 리틀엔디언==
13번째 줄: 14번째 줄:
* 리틀 엔디언 - 메모리 증가 방향과 반대로 저장
* 리틀 엔디언 - 메모리 증가 방향과 반대로 저장


==32비트 정수 예시==
{| class='wikitable'
{| class='wikitable'
! 10진수 !! 16진수 !! 빅 엔디언 || 리틀 엔디언
! 10진수 !! 16진수 !! 빅 엔디언 || 리틀 엔디언
|-
|-
| 255 || 0xFF || <code>00 00 00 FF</code> || <code>FF 00 00 00</code>
| 255 || 0xFF || <code>00 00 00 FF</code> || <code>FF 00 00 00</code>
|-
| 4660 || 0x1234 || <code>00 00 12 34</code> || <code>34 12 00 00</code>
|-
|-
| 168496141 || 0x0A0B0C0D || <code>0A 0B 0C 0D</code> || <code>0D 0C 0B 0A</code>
| 168496141 || 0x0A0B0C0D || <code>0A 0B 0C 0D</code> || <code>0D 0C 0B 0A</code>
|-
| 305419896 || 0x12345678 || <code>12 34 56 78</code> || <code>78 56 34 12</code>
|}
|}


25번째 줄: 31번째 줄:
https://upload.wikimedia.org/wikipedia/commons/thumb/e/ed/Little-Endian.svg/200px-Little-Endian.svg.png
https://upload.wikimedia.org/wikipedia/commons/thumb/e/ed/Little-Endian.svg/200px-Little-Endian.svg.png


==리눅스 리틀엔디언 예시==
==C언어로 실습==
<source lang="c">
<syntaxhighlight lang="c">
#include <stdio.h>
#include <stdio.h>


32번째 줄: 38번째 줄:
{
{
     int a = 255;
     int a = 255;
     char *pC = (char *)&a;
     char *p = (char *)&a;
     int i;
     int i;


     for (i = 0; i < sizeof(a); i++)
     for (i = 0; i < sizeof(a); i++)
     {
     {
         printf("%02x ", (unsigned char)*pC++);
         printf("%02x ", (unsigned char)*p++);
     }
     }
}
}
// ff 00 00 00  
// ff 00 00 00  
// 리눅스는 실제 값과 메모리 순서값이 반대임 - 리틀엔디언
// 리눅스는 실제 값과 메모리 순서값이 반대임 리틀엔디언
</source>
</syntaxhighlight>
 
==같이 보기==
*[[기계어]]


==참고 자료==
==참고==
* https://ko.wikipedia.org/wiki/엔디언
* https://ko.wikipedia.org/wiki/엔디언
* http://terms.naver.com/entry.nhn?docId=860398&cid=42346&categoryId=42346


[[분류: C]]
[[분류: C]]
[[분류: 메모리]]
[[분류: 메모리]]

2020년 11월 2일 (월) 02:41 기준 최신판

endianness
엔디언
big-endian, little-endian
빅엔디언, 리틀엔디언

1 엔디언[ | ]

  • Byte Order과 연관된 개념
  • 엔디언은 메모리의 배열하는 방법
  • 메모리 같은 1차원 공간에 여러 개의 연속된 대상을 배열하는 방법

2 빅엔디언, 리틀엔디언[ | ]

  • 빅 엔디언 - 메모리 증가 방향과 동일하게 저장
  • 리틀 엔디언 - 메모리 증가 방향과 반대로 저장

3 32비트 정수 예시[ | ]

10진수 16진수 빅 엔디언 리틀 엔디언
255 0xFF 00 00 00 FF FF 00 00 00
4660 0x1234 00 00 12 34 34 12 00 00
168496141 0x0A0B0C0D 0A 0B 0C 0D 0D 0C 0B 0A
305419896 0x12345678 12 34 56 78 78 56 34 12

 

 

4 C언어로 실습[ | ]

#include <stdio.h>

void main()
{
    int a = 255;
    char *p = (char *)&a;
    int i;

    for (i = 0; i < sizeof(a); i++)
    {
        printf("%02x ", (unsigned char)*p++);
    }
}
// ff 00 00 00 
// 리눅스는 실제 값과 메모리 순서값이 반대임 → 리틀엔디언

5 같이 보기[ | ]

6 참고[ | ]

문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}