PHP 8.5.0 Alpha 2 available for testing

Memcached::get

(PECL memcached >= 0.1.0)

Memcached::getLee un elemento

Descripción

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

Memcached::get() lee un elemento que ha sido almacenado previamente con la clave key. Si el elemento es encontrado, y que get_flags es proporcionado Memcached::GET_EXTENDED, el valor del token CAS del elemento también será retornado. Ver Memcached::cas() para saber cómo utilizar los tokens CAS. Una función de retrollamada en caso de ausencia puede ser especificada con el parámetro cache_cb.

Parámetros

key

La clave del elemento a leer.

cache_cb

Una función de retrollamada en caso de ausencia o null.

get_flags

Bandera para controlar el resultado retornado. Cuando Memcached::GET_EXTENDED es proporcionada, la función retornará también el token CAS.

Valores devueltos

Retorna el valor almacenado en la caché, o bien false en caso contrario. Si get_flags es definido a Memcached::GET_EXTENDED, un array conteniendo el valor y el token CAS es retornado en lugar de solo el valor. El método Memcached::getResultCode() retorna Memcached::RES_NOTFOUND si la clave no existe.

Historial de cambios

Versión Descripción
PECL memcached 3.0.0 El parámetro &cas_tokens ha sido eliminado. Memcached::GET_EXTENDED ha sido añadida y cuando es pasada como bandera asegura que los tokens CAS sean recuperados.

Ejemplos

Ejemplo #1 Ejemplo con Memcached::get() 1

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

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

El ejemplo anterior mostrará :

int(100)

Ejemplo #2 Ejemplo con 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 */
/* ... */
}
}
?>

Ver también

add a note

User Contributed Notes 3 notes

up
12
letynsoft at gmail dot com
8 years ago
As of some version of php7 (i was not able to determine which exactly).
The $cas_token is no longer valid argument. It has been removed in favor of flags argument, as it appears to be causing issues when subclassing the Memcached class.

See https://github.com/php-memcached-dev/php-memcached/pull/214 for more details.

Basically you need to
<?php
function memcacheGet($key, $cb = null, &$cas = null) {
$m = memcacheGetObject();
if(empty(
$m))
return
false;
if(
defined('Memcached::GET_EXTENDED')) {
//Incompatible change in php7, took me 2 hours to figure this out, grrr
$_o = $m->get($key, $cb, Memcached::GET_EXTENDED);
$o = $_o['value'];
$cas = $_o['cas'];
} else {
$o = $m->get($key, $cb, $cas);
}
return
$o;
}
?>
up
10
miha at hribar dot info
16 years ago
This method also returns false in case you set the value to false, so in order to have a proper fault mechanism in place you need to check the result code to be certain that a key really does not exist in memcached.

<?php
$Memcached
= new Memcached();
$Memcached->addServer('localhost', 11211);
$Memcached->set('key', false);
var_dump($Memcached->get('key')); // boolean false
var_dump($Memcached->getResultCode()); // int 0 which is Memcached::RES_SUCCESS
?>

Or just make sure the values are not false :)
up
-2
denis_truffaut[A-T]hotmail[D-O-T]com
14 years ago
Note that this function can return NULL as FALSE, so don't make checks with === FALSE as with the old Memcache class, because it won't work. :O

Use the not (!) operator and check the result code with getResultCode() as mentioned in the documentation :)
To Top