Memcached::get

(PECL memcached >= 0.1.0)

Memcached::getLit un élément

Description

public Memcached::get(string $key, ?callable $cache_cb = null, int $get_flags = 0): mixed

Memcached::get() lit un élément qui a été stocké précédemment avec la clé key. Si l'élément est trouvé, et que get_flags est fournit Memcached::GET_EXTENDED, la valeur du jeton CAS du l'élément sera aussi retournée. Voir Memcached::cas() pour savoir comment utiliser les jetons CAS. Une Fonction de rappel en cas d'absence peut être spécifiée avec le paramètre cache_cb.

Liste de paramètres

key

La clé de l'élément à lire.

cache_cb

Une fonction de rappel en cas d'absence ou null.

get_flags

Drapeaux pour contrôler le résultat retourné. Quand Memcached::GET_EXTENDED est fournit, la fonction retournera aussi le jeton CAS.

Valeurs de retour

Retourne la valeur stockée dans le cache, ou bien false sinon. Si get_flags est définit à Memcached::GET_EXTENDED, un tableau contenant la valeur et le jeton CAS est retourné au lieu d'uniquement la valeur. La méthode Memcached::getResultCode() retourne Memcached::RES_NOTFOUND si la clé n'existe pas.

Historique

Version Description
PECL memcached 3.0.0 Le paramètre &cas_tokens a été supprimé. Memcached::GET_EXTENDED a été ajoutée et quand passé en tant que drapeau il s'assure que les jetons CAS sont récupérés.

Exemples

Exemple #1 Exemple avec Memcached::get() 1

<?php
$m
= new Memcached();
$m->addServer('localhost', 11211);

$m->set('foo', 100);
var_dump($m->get('foo'));
?>

L'exemple ci-dessus va afficher :

int(100)

Exemple #2 Exemple avec Memcached::get() 2

<?php
$m
= new Memcached();
$m->addServer('localhost', 11211);

if (!(
$ip = $m->get('ip_block'))) {
if (
$m->getResultCode() == Memcached::RES_NOTFOUND) {
$ip = array();
$m->set('ip_block', $ip);
} else {
/* log error */
/* ... */
}
}
?>

Voir aussi