Funções Genéricas
Array
array array(...);
É a função que cria um array a partir dos parâmetros forncidos. É possível fornecer o índice de cada
elemento. Esse índice pode ser um valor de qualquer tipo, e não apenas de inteiro. Se o índice não for fornecido o PHP
atribui um valor inteiro sequencial, a partir do 0 ou do último índice inteiro explicitado. Vejamos alguns exemplos:
Exemplo 1
$teste = array("um", "dois","tr"=>"tres",5=>"quatro","cinco");
Temos o seguinte mapeamento:
0 => “um” (0 é o primeiro índice, se não houver um explicito)
1 => “dois” (o inteiro seguinte)
“tr” => “tres”
5 => “quatro” (valor explicitado)
6 => “cinco” (o inteiro seguinte ao último atribuído, e não o próximo
valor, que seria 2)
Exemplo 2
$teste = array("um", 6=>"dois","tr"=>"tres",5=>"quatro","cinco");
Temos o seguinte mapeamento:
0 => “um”
6 => “dois”
“tr” => tres
5 => “quatro” (seria 7, se não fosse explicitado)
7 => “cinco” (seria 6, se não estivesse ocupado)
Em geral, não é recomendável utilizar arrays com vários tipos de índices, já que isso pode confundir o
programador. No caso de realmente haver a necessidade de utilizar esse recurso, deve-se ter bastante atenção ao manipular
os índices do array.
range
array range(int minimo, int maximo);
A função range cria um array cujos elementos são os inteiros pertencentes ao intervalo fornecido,
inclusive. Se o valor do primeiro parâmetro for maior do que o do segundo, a função retorna false (valor vazio).
shuffle
void shuffle(array &arr);
Esta função “embaralha” o array, ou seja, troca as posições dos elementos aleatoriamente e não retorna
valor algum.
sizeof
int sizeof(array arr);
Retorna um valor inteiro contendo o número de elementos de um array. Se for utilizada com uma variável
cujo valor não é do tipo array, retorna 1. Se a variável não estiver setada ou for um array vazio, retorna 0.
Funções de “navegação”
Toda variável do tipo array possui um ponteiro interno indicando o próximo elemento a ser acessado no
caso de não ser especificado um índice. As funções seguintes servem para modificar esse ponteiro, permitindo assim
percorrer um array para verificar seu conteúdo (chaves e elementos).
reset
mixed reset(array arr);
Seta o ponteiro interno para o primeiro elemento do array, e retorna o conteúdo desse elemento.
end
mixed end(array arr);
Seta o ponteiro interno para o último elemento do array, e retorna o conteúdo desse elemento.
next
mixed next(array arr);
Seta o ponteiro interno para o próximo elemento do array, e retorna o conteúdo desse elemento.
Obs.: esta não é uma boa função para determinar se um elemento é o último do array, pois pode retornar
false tanto no final do array como no caso de haver um elemento vazio.
prev
mixed prev(array arr);
Seta o ponteiro interno para o elemento anterior do array, e retorna o conteúdo desse elemento. Funciona
de maneira inversa a next.
pos
mixed pos(array arr);
Retorna o conteúdo do elemento atual do array, indicado pelo ponteiro interno.
key
mixed key(array arr);
Funciona de maneira bastante semelhante a pos, mas ao invés de retornar o elemento atual indicado pelo
ponteiro interno do array, retorna seu índice.
each
array each(array arr);
Retorna um array contendo o índice e o elemento atual indicao pelo ponteiro interno do array. o valor de
retorno é um array de quatro elementos, cujos índices são 0, 1, “key” e “value”. Os elementos de índices 0 e “key”
armazenam o índice do valor atual, e os elementos de índices 1 e “value” contém o valor do elemento atual indicado pelo
ponteiro.
Esta função pode ser utilizada para percorrer todos os elementos de um array e determinar se já foi
encontrado o último elemento, pois no caso de haver um elemento vazio, a função não retornará o valor false. A função
each só retorna false depois q o último elemento do array foi encontrado.
Exemplo:
/*função que percorre todos os elementos de um array e imprime seus
índices e valores */
function imprime_array($arr) {
reset($arr);
while (list($chave,$valor) = each($arr))
echo “Chave: $chave. Valor: $valor”;
}
0 comentários:
Postar um comentário