char carr[3][6] = { "hello", "my", "world" };
char *cp = (char *)carr ;
printf("cp[11] == %c \n", cp[12]); // 'r' printf("cp[2][2] == %c \n", ((char**)cp)[2][2]); // 에러 .
왜 에러가 날까요 ?
:)
설연희 입니다 ^ ㅡ^ㅋ
마지막 라인 빼고 만들어서 돌려 보시죠
제목대로...
cp를 포인터로 바꾸면 char(*)[6] 형태가 되는데, 2차원 배열이 들어가는 방식을 생각하면 (char *)로는 typecasting이 되지만, (char **)로는 typecasting을 할 수 없습니다.
32비트 머신이라면 char **로 강제로 typecasting을 했을 때 cp[0][0]..cp[0][3]의 4바이트를 읽어서 포인터로 해석하려고 하니 엉뚱한 주소를 읽고 뻗겠죠.
(아, 노파심에 말씀드리자면 바로 위의 문장은 일반적인 32비트 머신에서 그렇다는 거지 C 표준이 그렇게 얘기한다는 뜻은 아닙니다. 괜히 말 잘못했다가 standard 전쟁 일어날까봐... -.-)
포인터를 몇 가지 용도로만 사용하다 보니, 헷갈렸네요 . 쓸데없는 걸 놓고 불필요하게 고민을 했군요 .
((char**)cp)[2][2] 가 아니라 .. ((char(*)[6])cp)[2][2] 이어야 했는데 .. 말이지요 ^ ^
시간 내어주신 모든 분들께 감사의 말씀 전합니다 ..
- 설연희 에효
저는 ((char(*)[6])cp)[2][2]와 같이 배열형으로 typecasting이 가능하다는 사실을 처음으로 알게 되었습니다. char(*)[6] 이 자체를 하나의 type명처럼 쓸 수가 있는거군요... 이럴때마다 뭐가 문제인지는 알았으나 이런 typecasting 방법이 있다는걸 몰라서 항상 투덜대면서 문제를 우회하곤 했는데... 좋은 방법 하나 배워갑니다. 감사합니다.
텍스트 포맷에 대한 자세한 정보
<code>
<blockcode>
<apache>
<applescript>
<autoconf>
<awk>
<bash>
<c>
<cpp>
<css>
<diff>
<drupal5>
<drupal6>
<gdb>
<html>
<html5>
<java>
<javascript>
<ldif>
<lua>
<make>
<mysql>
<perl>
<perl6>
<php>
<pgsql>
<proftpd>
<python>
<reg>
<spec>
<ruby>
<foo>
[foo]
please give an error message
:)
:)
세그먼트 폴트인 것 같은데요 .. 신택스 아니고요;; 경고 하나 없이 컴파일/링킹 되지만.. 실행하면 바로 닫힙니다
설연희 입니다 ^ ㅡ^ㅋ
설연희 입니다 ^ ㅡ^ㅋ
음
마지막 라인 빼고 만들어서 돌려 보시죠
cp가 char*니까 char**는 엉뚱한 쓰레기 주소라서 폴트 날 듯
제목대로...
2차원 배열에 대한 이해가 부족하신듯
cp를 포인터로 바꾸면 char(*)[6] 형태가 되는데, 2차원 배열이 들어가는 방식을 생각하면 (char *)로는 typecasting이 되지만, (char **)로는 typecasting을 할 수 없습니다.
32비트 머신이라면 char **로 강제로 typecasting을 했을 때 cp[0][0]..cp[0][3]의 4바이트를 읽어서 포인터로 해석하려고 하니 엉뚱한 주소를 읽고 뻗겠죠.
(아, 노파심에 말씀드리자면 바로 위의 문장은 일반적인 32비트 머신에서 그렇다는 거지 C 표준이 그렇게 얘기한다는 뜻은 아닙니다. 괜히 말 잘못했다가 standard 전쟁 일어날까봐... -.-)
자문 자답입니다 ..
포인터를 몇 가지 용도로만 사용하다 보니, 헷갈렸네요 . 쓸데없는 걸 놓고 불필요하게 고민을 했군요 .
((char**)cp)[2][2] 가 아니라 .. ((char(*)[6])cp)[2][2] 이어야 했는데 .. 말이지요 ^ ^
시간 내어주신 모든 분들께 감사의 말씀 전합니다 ..
- 설연희 에효
설연희 입니다 ^ ㅡ^ㅋ
되려 하나 배워갑니다.
저는 ((char(*)[6])cp)[2][2]와 같이 배열형으로 typecasting이 가능하다는 사실을 처음으로 알게 되었습니다.
char(*)[6] 이 자체를 하나의 type명처럼 쓸 수가 있는거군요...
이럴때마다 뭐가 문제인지는 알았으나 이런 typecasting 방법이 있다는걸 몰라서 항상 투덜대면서 문제를 우회하곤 했는데... 좋은 방법 하나 배워갑니다. 감사합니다.
댓글 달기