현재 위치: > 최신 기사 목록> 첫 번째 매개 변수가 문자열이 될 수없는 이유는 무엇입니까?

첫 번째 매개 변수가 문자열이 될 수없는 이유는 무엇입니까?

M66 2025-06-06

php에서 array_fill () 함수는 배열을 채우는 데 사용되며 세 가지 매개 변수를 수용합니다.

  1. 시작 인덱스 : 채우기 시작 색인을 지정합니다.

  2. 길이 : 채울 요소 수를 지정합니다.

  3. : 배열을 채우는 요소 값을 지정합니다.

일반적으로 array_fill () 에 대한 첫 번째 인수는 배열의 시작 인덱스를 나타내는 숫자입니다. String을 Array_Fill () 에 첫 번째 인수로 전달하려고하면 PHP는 함수가 문자열 유형의 인덱스를 처리 할 수 ​​없음을 나타내는 경고 오류를 던집니다. 이게 왜?

1. PHP 배열은 숫자로 인덱싱됩니다

PHP의 배열은 일반적으로 array_fill () 로 배열을 채울 때 일반적으로 인덱스로 숫자로 작동됩니다. Array_fill ()은 지정된 시작 번호에서 시작하여 배열을 순서대로 채우는 "숫자 색인"의 배열 채우기 메커니즘을 기반으로 설계되었습니다. 첫 번째 매개 변수의 값은 정수 (또는 정수로 변환 될 수있는 숫자)이어야합니다. 이것은 PHP 배열의 정상적인 동작이기 때문입니다.

첫 번째 매개 변수가 문자열 인 경우 PHP가 비 숫자 문자열 값을 합리적인 숫자 인덱스로 변환 할 수 없기 때문에 PHP는 유효한 배열 인덱스에 올바르게 매핑 할 수 없습니다. 따라서 숫자 유형의 인덱스 만 처리 할 수 ​​있습니다.

2. PHP 배열은 연관 어레이가 아닌 주문됩니다

PHP에서 배열은 숫자 인덱스 또는 연관 배열 일 수 있습니다 (키는 문자열입니다). 그러나 array_fill () 함수를 설계 할 때 기본값은 숫자 색인 배열을 작동하는 것입니다. 숫자를 색인으로 제공하면 PHP는 채우기가 해당 위치에서 시작해야한다는 것을 알고 있습니다.

인덱스로서의 문자열은 일반적으로 연관 배열에 사용되며 각 키 값 쌍은 문자열 키 으로 구성됩니다. Array_Fill ()은 지정된 시작 위치에서 문자열로 키로 연결 배열을 채우기 시작하지 않기 때문에이 상황에서는 작동하지 않습니다.

3. 메모리 최적화 및 성능 문제

PHP 배열의 기본 구현 메커니즘은 디지털 인덱스 어레이의 성능을 최적화하며 이는 디지털 인덱스를 작동하는 데 더 효율적입니다. 숫자 인덱스를 사용하는 경우 PHP는 숫자 인덱스를 메모리 위치에 직접 바인딩하므로 불필요한 추가 계산을 피할 수 있습니다. 또한 문자열을 인덱스로 사용하려고하면 PHP에는 추가 메모리 처리 및 계산이 필요하므로 성능 저하가 발생합니다.

4. Array_Fill ()을 올바르게 사용하는 방법

Array_fill () 에서 첫 번째 매개 변수는 정수 여야합니다. 예를 들어, 인덱스 2 에서 시작하여 5 가지 요소로 배열을 채우십시오.

 $arr = array_fill(2, 5, 'Hello');
print_r($arr);

출력 결과 :

 Array
(
    [2] => Hello
    [3] => Hello
    [4] => Hello
    [5] => Hello
    [6] => Hello
)

이 예에서 Array_fill ()은 인덱스 2 에서 시작하여 5 개의 요소를 채우며 각 요소는 'hello' 입니다. 모든 인덱스는 문자열이 아닌 숫자입니다.

5. 결론

Array_fill () 의 원래 의도는 연관 배열보다는 숫자 인덱스가있는 배열에 대한 충전 기능을 제공하는 것이 었습니다. 연관 배열을 채우려면 문자열 인덱싱과 함께 루핑과 같은 다른 메소드를 사용하여 값을 할당 할 수 있습니다.

 $arr = [];
$startIndex = 'a';
for ($i = 0; $i < 5; $i++) {
    $arr[$startIndex] = 'Hello';
    $startIndex++;
}
print_r($arr);

이 예에서는 배열을 문자열 키로 채 웁니다.

이 기사가 PHP에서 Array_Fill () 함수의 사용 및 제한 사항을 더 잘 이해하는 데 도움이되기를 바랍니다. 다른 질문이 있으시면 웹 사이트를 방문하십시오!