Table of Contents
이 사용자 가이드에서는 t_check_for_sizeof_st_index_t 배열 맞춤 오류를 일으킬 수 있는 몇 가지 가능한 원인을 주장하고 문제를 확인하기 위해 시도할 수 있는 가능한 수리를 제안합니다.
승인됨
집의 길이를 설명할 수 없습니다. arr
때문에 확인하는 방법에 관계없이 sizeof (arr)
는 확실히 항상 반환 절과 가장 일반적으로 연결된 크기일 것입니다. 따라서 의 청크에 대한 번호를 구별 인수로 전달하는 것도 바람직합니다.
sizeof
기능은 원래 어레이를 확인할 수 있도록 이점이 있는 경우에만 어레이와 관련된 길이를 결정하는 데 더 좋습니다.
정수 arr [5]; // 실제 다양성. 실마리 없음크기(샘플); // :)
그러나 포인터에 따라 배열을 나눌 때 sizeof는 포인터 크기의 작은 부분을 나타내며 실제로 배열의 크기보다 작습니다.
<사전> <코드> 무효 getArraySize (int arr [])크기(샘플); // 필요한 경우 포인터의 크기를 지정할 수 있습니다.
우리는 왜 이런 일이 일어날 수 있는지 찾고 있습니다. 남편과 나는 C 어레이의 길이를 어떻게 알 수 있습니까?
배열이 일반적으로 함수에 전달될 때 배열을 어드바이스로 분할하지 않고 유형 시스템과 관련하여 배열의 길이를 실제로 슈퍼마켓으로 만드는 것이 좋은 전략입니다.
개인이 배열을 It 속성에 전달하면 모든 종류의 포인터로 분해됩니다. sizeof
는 부작용, 즉 int 3 을 통해 크기를 반환합니다. . 이것은 경고입니다. 컴파일러가 자주 불평하는 곳은
많은 함수 매개변수에 대한
sizeof는 'int []'를 가리키는 대신 'int *'에 대한 참조로 크기를 반환합니다.
남편과 제가 제안한 것처럼, 거의 모든 기능에 뛰어난 사람 배열을 전달할 때 이후의 점 수도 보내야 합니다.
<사전> <코드> getArraySize(배열, 5); // 1 - 배열에서 가장 많은 특성 수
빈 getArraySize (int arr [], int 요소)// 몇 가지 물건
gap getArraySize (int arr [], int len) // 현재 업무 printf("배열 길이:% d n", len);정수 메인() 배열 int []는 1,2,3,4,5와 같습니다. int len은 (sizeof (arr) / sizeof (arr [0])에서 같음; // 새 배열의 범위를 반환 getArraySize(배열, 길이); 복원 0;
cool() 요소는 과도한 매개변수 arr []를 취하고 sizeof 소유자를 사용하여 arr []로 요소 수를 결정하려고 시도합니다.
C에서 배열 매개변수는 포인터처럼 취급됩니다. 따라서 sizeof(arr [0])당 표현식 sizeof(arr)는 sizeof(int *) / sizeof(int)가 됩니다. 이는 IA 비트 32비트 기계의 경우 아마도 1일 것입니다(int 및 int(blank)가 있는 크기는 4입니다. ) 및 부산물로 for 루프는 배열의 크기에 관계없이 좋은 시간에 () 한 번만 실행됩니다.
따라서 특정 특정 수의 요소를 얻으려면 이러한 경우 sizeof를 최대한 사용해야 하지 마십시오. fun()을 사용하려면 배열과 관련된 수(또는 길이)에 대한 이산 매개변수를 얻어야 합니다. 따라서 수정된 교육 프로그램:
위의 기사에서 실제와 동떨어진 것을 발견하거나 초과하여 논의된 주제에 대해 훨씬 더 많은 정보를 공유하고 싶은 경우 의견을 확장하십시오.
Hello Worlds 교육 프로그램의 상승. 힙, 스택, 연결 목록 등의 구조 유형을 구현하는 방법을 배우십시오! 오늘 아침에 시작하려면 C 데이터 구조 과정을 확인하십시오.
sizeof
드라이버는 실제 피연산자의 크기(바이트 단위)를 부여합니다. 이는 실제로 좋은 표현식이나 괄호를 사용하는 유형 사양일 수 있습니다. 그러나 키 sizeof
연산자를 사용하여 배열의 몸체 모양을 결정하는 것은 약해집니다.
네트워크
크기는 종종 malloc()
를 적용하여 메모리를 정확하게 할당해야 하는지 결정하는 데 사용됩니다. 그러나 현재 잘못된 크기를 사용하면 MEM35-C가 손상될 수 있습니다. + 할당 + + 개체로 인한 충분한 메모리 + “> MEM35-C. 할당 + + 주제에 대한 충분한 메모리 .
호환되지 않는 코드 예제
잘못된 코드의 이 예에서 특정 clear ()
레이아웃은 in 요소를 각각의 새 배열을 0으로 모델링합니다. 첫 번째 함수에 대한 함수 매개변수는 int array []
로 선언되거나 실제로 12 int
에 대한 정적 배열을 좋은 인수로 전달했습니다. clear ()
요소는 배열의 요소 그룹을 결정하는 각 sizeof (array [0]) 값에 대해 sizeof (array) 관용구를 사용합니다. 단,
array
는 일종의 매개변수이기 때문에 tip 타입이다. 완전한 결과로 sizeof (array)
는 좋은 *) sizeof (int. 예를 들어 주요
sizeof (int ) == 4
및 a of sizeof (int *) == 5
, 단어 sizeof (배열) / sizeof (배열 [0])
는 전달된 다양성의 길이로 간주되는 1 을 살펴보고 나머지 과잉은 일반적으로 그대로 둡니다.