function.array-reduce.html
10.6 KB
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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>Iterative Reduktion eines Arrays zu einem Wert mittels einer
Callbackfunktion</title>
</head>
<body><div class="manualnavbar" style="text-align: center;">
<div class="prev" style="text-align: left; float: left;"><a href="function.array-rand.html">array_rand</a></div>
<div class="next" style="text-align: right; float: right;"><a href="function.array-replace-recursive.html">array_replace_recursive</a></div>
<div class="up"><a href="ref.array.html">Array Funktionen</a></div>
<div class="home"><a href="index.html">PHP Manual</a></div>
</div><hr /><div id="function.array-reduce" class="refentry">
<div class="refnamediv">
<h1 class="refname">array_reduce</h1>
<p class="verinfo">(PHP 4 >= 4.0.5, PHP 5)</p><p class="refpurpose"><span class="refname">array_reduce</span> — <span class="dc-title">Iterative Reduktion eines Arrays zu einem Wert mittels einer
Callbackfunktion</span></p>
</div>
<div class="refsect1 description" id="refsect1-function.array-reduce-description">
<h3 class="title">Beschreibung</h3>
<div class="methodsynopsis dc-description">
<span class="type"><a href="language.pseudo-types.html#language.types.mixed" class="type mixed">mixed</a></span> <span class="methodname"><strong>array_reduce</strong></span>
( <span class="methodparam"><span class="type">array</span> <code class="parameter">$array</code></span>
, <span class="methodparam"><span class="type"><a href="language.types.callable.html" class="type callable">callable</a></span> <code class="parameter">$callback</code></span>
[, <span class="methodparam"><span class="type"><a href="language.pseudo-types.html#language.types.mixed" class="type mixed">mixed</a></span> <code class="parameter">$initial</code><span class="initializer"> = <strong><code>NULL</code></strong></span></span>
] )</div>
<p class="para rdfs-comment">
<span class="function"><strong>array_reduce()</strong></span> wendet die Funktion
<code class="parameter">callback</code> iterativ auf die Elemente des Arrays
<code class="parameter">array</code> so an, dass das Array auf einen einzigen
Wert reduziert wird.
</p>
</div>
<div class="refsect1 parameters" id="refsect1-function.array-reduce-parameters">
<h3 class="title">Parameter-Liste</h3>
<p class="para">
<dl>
<dt>
<code class="parameter">array</code></dt>
<dd>
<p class="para">
Das Eingabe-Array.
</p>
</dd>
<dt>
<code class="parameter">callback</code></dt>
<dd>
<div class="methodsynopsis dc-description">
<span class="type"><a href="language.pseudo-types.html#language.types.mixed" class="type mixed">mixed</a></span> <span class="methodname"><span class="replaceable">callback</span></span>
( <span class="methodparam"><span class="type"><a href="language.pseudo-types.html#language.types.mixed" class="type mixed">mixed</a></span> <code class="parameter">$carry</code></span>
, <span class="methodparam"><span class="type"><a href="language.pseudo-types.html#language.types.mixed" class="type mixed">mixed</a></span> <code class="parameter">$item</code></span>
)</div>
<dl>
<dt>
<code class="parameter">carry</code></dt>
<dd>
<p class="para">
Enthält den Rückgabewert des vorherigen Durchgangs. Im Fall des ersten
Durchlaufs enthält dies stattdessen den Wert von
<code class="parameter">initial</code>.
</p>
</dd>
<dt>
<code class="parameter">item</code></dt>
<dd>
<p class="para">
Enthält den Wert des aktuellen Durchgangs.
</p>
</dd>
</dl>
</dd>
<dt>
<code class="parameter">initial</code></dt>
<dd>
<p class="para">
Ist der optionale Parameter <code class="parameter">intial</code> angegeben,
wird er am Anfang des Prozesses benutzt oder als Resultat verwendet,
sollte das Array leer sein.
</p>
</dd>
</dl>
</p>
</div>
<div class="refsect1 returnvalues" id="refsect1-function.array-reduce-returnvalues">
<h3 class="title">Rückgabewerte</h3>
<p class="para">
Gibt den sich ergebenden Wert zurück.
</p>
<p class="para">
Falls das Array leer ist und <code class="parameter">initial</code> nicht
angegeben wurde, so wird <span class="function"><strong>array_reduce()</strong></span> <strong><code>NULL</code></strong>
zurückgeben.
</p>
</div>
<div class="refsect1 changelog" id="refsect1-function.array-reduce-changelog">
<h3 class="title">Changelog</h3>
<p class="para">
<table class="doctable informaltable">
<thead>
<tr>
<th>Version</th>
<th>Beschreibung</th>
</tr>
</thead>
<tbody class="tbody">
<tr>
<td>5.3.0</td>
<td>
Der von <code class="parameter">initial</code> akzeptierte Datentyp wurde zu
<span class="type"><a href="language.pseudo-types.html#language.types.mixed" class="type Mixed">Mixed</a></span> geändert, vorher war dies <span class="type"><a href="language.types.integer.html" class="type Integer">Integer</a></span>.
</td>
</tr>
</tbody>
</table>
</p>
</div>
<div class="refsect1 examples" id="refsect1-function.array-reduce-examples">
<h3 class="title">Beispiele</h3>
<p class="para">
<div class="example" id="example-4934">
<p><strong>Beispiel #1 <span class="function"><strong>array_reduce()</strong></span>-Beispiel</strong></p>
<div class="example-contents">
<div class="phpcode"><code><span style="color: #000000">
<span style="color: #0000BB"><?php<br /></span><span style="color: #007700">function </span><span style="color: #0000BB">sum</span><span style="color: #007700">(</span><span style="color: #0000BB">$carry</span><span style="color: #007700">, </span><span style="color: #0000BB">$item</span><span style="color: #007700">)<br />{<br /> </span><span style="color: #0000BB">$carry </span><span style="color: #007700">+= </span><span style="color: #0000BB">$item</span><span style="color: #007700">;<br /> return </span><span style="color: #0000BB">$carry</span><span style="color: #007700">;<br />}<br /><br />function </span><span style="color: #0000BB">multiplication</span><span style="color: #007700">(</span><span style="color: #0000BB">$carry</span><span style="color: #007700">, </span><span style="color: #0000BB">$item</span><span style="color: #007700">)<br />{<br /> </span><span style="color: #0000BB">$carry </span><span style="color: #007700">*= </span><span style="color: #0000BB">$item</span><span style="color: #007700">;<br /> return </span><span style="color: #0000BB">$carry</span><span style="color: #007700">;<br />}<br /><br /></span><span style="color: #0000BB">$a </span><span style="color: #007700">= array(</span><span style="color: #0000BB">1</span><span style="color: #007700">, </span><span style="color: #0000BB">2</span><span style="color: #007700">, </span><span style="color: #0000BB">3</span><span style="color: #007700">, </span><span style="color: #0000BB">4</span><span style="color: #007700">, </span><span style="color: #0000BB">5</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$x </span><span style="color: #007700">= array();<br /><br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">array_reduce</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">, </span><span style="color: #DD0000">"sum"</span><span style="color: #007700">)); </span><span style="color: #FF8000">// int(15)<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">array_reduce</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">, </span><span style="color: #DD0000">"multiplication"</span><span style="color: #007700">, </span><span style="color: #0000BB">10</span><span style="color: #007700">)); </span><span style="color: #FF8000">// int(1200), da: 10*1*2*3*4*5<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">array_reduce</span><span style="color: #007700">(</span><span style="color: #0000BB">$x</span><span style="color: #007700">, </span><span style="color: #DD0000">"sum"</span><span style="color: #007700">, </span><span style="color: #DD0000">"Keine Daten für die Reduktion"</span><span style="color: #007700">)); <br /> </span><span style="color: #FF8000">// string(29) "Keine Daten für die Reduktion"<br /></span><span style="color: #0000BB">?></span>
</span>
</code></div>
</div>
</div>
</p>
</div>
<div class="refsect1 seealso" id="refsect1-function.array-reduce-seealso">
<h3 class="title">Siehe auch</h3>
<p class="para">
<ul class="simplelist">
<li class="member"><span class="function"><a href="function.array-filter.html" class="function" rel="rdfs-seeAlso">array_filter()</a> - Filtert Elemente eines Arrays mittels einer Callback-Funktion</span></li>
<li class="member"><span class="function"><a href="function.array-map.html" class="function" rel="rdfs-seeAlso">array_map()</a> - Wendet eine Callback-Funktion auf die Elemente von Arrays an</span></li>
<li class="member"><span class="function"><a href="function.array-unique.html" class="function" rel="rdfs-seeAlso">array_unique()</a> - Entfernt doppelte Werte aus einem Array</span></li>
<li class="member"><span class="function"><a href="function.array-count-values.html" class="function" rel="rdfs-seeAlso">array_count_values()</a> - Zählt die Werte eines Arrays</span></li>
</ul>
</p>
</div>
</div><hr /><div class="manualnavbar" style="text-align: center;">
<div class="prev" style="text-align: left; float: left;"><a href="function.array-rand.html">array_rand</a></div>
<div class="next" style="text-align: right; float: right;"><a href="function.array-replace-recursive.html">array_replace_recursive</a></div>
<div class="up"><a href="ref.array.html">Array Funktionen</a></div>
<div class="home"><a href="index.html">PHP Manual</a></div>
</div></body></html>