-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy patharray-walk.xml
152 lines (146 loc) · 4.97 KB
/
array-walk.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<?xml version="1.0" encoding="UTF-8"?>
<!-- splitted from ./it/functions/array.xml, last change in rev 1.1 -->
<!-- last change to 'array-walk' in en/ tree in rev 1.2 -->
<!-- EN-Revision: n/a Maintainer: cucinato Status: ready -->
<!-- OLD-Revision: 1.173/EN.1.2 -->
<refentry xml:id="function.array-walk" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>array_walk</refname>
<refpurpose>
Esegue una funzione su ogni elemento dell'array
</refpurpose>
</refnamediv>
<refsect1>
<title>Descrizione</title>
<methodsynopsis>
<type>bool</type><methodname>array_walk</methodname>
<methodparam><type>array</type><parameter>&array</parameter></methodparam>
<methodparam><type>callback</type><parameter>funzione</parameter></methodparam>
<methodparam choice="opt"><type>mixed</type><parameter>datiutente</parameter></methodparam>
</methodsynopsis>
<simpara>
&return.success;
</simpara>
<simpara>
Esegue la funzione definita dall'utente identificata da <parameter>funzione</parameter>
su ogni elemento di <parameter>array</parameter>. Normalmente
<parameter>funzione</parameter> accetta due parametri.
Il valore del parametro <parameter>array</parameter> viene passato per primo,
la chiave/indice per secondo. Se il parametro <parameter>datiutente</parameter>
è specificato, verrà passato come terzo parametro alla
<parameter>funzione</parameter> callback.
</simpara>
<simpara>
Se <parameter>funzione</parameter> richiede più parametri di
quanti gliene vengono passati, un errore di livello <link linkend="errorfunc.constants">
E_WARNING</link> verrà generato ogni volta che <function>array_walk</function>
la chiama. Questi avvertimenti possono essere soppressi
apponendo l'operatore d'errore
<link linkend="language.operators.errorcontrol">@</link> alla
chiamata di <function>array_walk</function>, oppure usando
<function>error_reporting</function>.
</simpara>
<note>
<para>
Se <parameter>funzione</parameter> deve lavorare con i
reali valori dell'array, specificare che il primo parametro di
<parameter>funzione</parameter> deve essere passato come
<link linkend="language.references">riferimento</link>. A qesto punto
ogni modifica a questi elementi verrà effettuata sull'array
stesso.
</para>
</note>
<note>
<para>
Il passaggio della chiave e di <parameter>datiutente</parameter> a <parameter>func</parameter> è
stato aggiunto nella versione 4.0.
</para>
</note>
<para>
<function>array_walk</function> non è influenzato dal puntatore
interno dell'array <parameter>array</parameter>. <function>
array_walk</function> percorrerà l'intero array
indipendentemente dalla posizione del puntatore. Per reinizializzare il puntatore, utilizzare
<function>reset</function>. In PHP 3,
<function>array_walk</function> reinizializza il puntatore.
</para>
<para>
Gli utenti non possono modificare l'array attraverso la funzione
di callback, ad esempio aggiungere/togliere un elemento, o cancellare l'array su cui
<function>array_walk</function> è applicata. Se l'array viene
cambiato, il comportamento di questa funzione non è definito ed
è imprevedibile.
</para>
<para>
<example>
<title>esempio di <function>array_walk</function></title>
<programlisting role="php">
<![CDATA[
<?php
$frutta = array("d"=>"limone", "a"=>"arancia", "b"=>"banana", "c"=>"mela");
function modifica(&$elemento1, $chiave, $prefisso)
{
$elemento1 = "$prefisso: $elemento1";
}
function stampa($elemento2, $chiave)
{
echo "$chiave. $elemento2<br />\n";
}
echo "Prima ...:\n";
array_walk($frutta, 'stampa');
array_walk($frutta, 'modifica', 'frutto');
echo "... e dopo:\n";
array_walk($frutta, 'stampa');
?>
]]>
</programlisting>
<para>
Il risultato del programma sarà:
</para>
<screen role="php">
<![CDATA[
Prima ...:
d. limone
a. arancia
b. banana
c. mela
... e dopo:
d. frutto: limone
a. frutto: arancia
b. frutto: banana
c. frutto: mela
]]>
</screen>
</example>
</para>
<simpara>
Vedere anche <function>array_walk_recursive</function>,
<function>create_function</function>,
<function>list</function>,
<link linkend="control-structures.foreach">foreach</link>,
<function>each</function>,
<function>call_user_func_array</function> e
<function>array_map</function>
</simpara>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->