2 <!DOCTYPE HTML PUBLIC 
"-//W3C//DTD HTML 4.01//EN"> 
   5         <link type=
"text/css" rel=
"stylesheet" href=
"style.css" /> 
  12             <img style=
"border:none" alt=
"Redis Documentation" src=
"redis.png"> 
  16             <div id=
"pagecontent"> 
  18 <!-- This is a (PRE) block.  Make sure it's left aligned or your toc title will be off. --> 
  19 <b>Strings: Contents
</b><br>  <a href=
"#Redis String Type">Redis String Type
</a><br>  <a href=
"#Implementation details">Implementation details
</a> 
  22                 <h1 class=
"wikiname">Strings
</h1> 
  29                     #sidebar 
<a href=
"StringCommandsSidebar.html">StringCommandsSidebar
</a><h1><a name=
"Redis String Type">Redis String Type
</a></h1>Strings are the most basic Redis kind of values. Redis Strings are binary safe, this means a Redis string can contain any kind of data, for instance a JPEG image or a serialized Ruby object, and so forth.
<br/><br/>A String value can be at max 
1 Gigabyte in length.
<br/><br/>Strings are treated as integer values by the 
<a href=
"IncrCommand.html">INCR
</a> commands family, in this respect the value of an intger is limited to a singed 
64 bit value.
<br/><br/>Note that the single elements contained in Redis 
<a href=
"Lists.html">Lists
</a>, 
<a href=
"Sets.html">Sets
</a> and 
<a href=
"SortedSets.html">Sorted Sets
</a>, are Redis Strings.
<h1><a name=
"Implementation details">Implementation details
</a></h1>Strings are implemented using a dynamic strings library called 
<code name=
"code" class=
"python">sds.c
</code> (simple dynamic strings). This library caches the current length of the string, so to obtain the length of a Redis string is an O(
1) operation (but currently there is no such STRLEN command. It will likely be added later).
<br/><br/>Redis strings are incapsualted into Redis Objects. Redis Objects use a reference counting memory management system, so a single Redis String can be shared in different places of the dataset. This means that if you happen to use the same strings many times (especially if you have 
<i>object sharing
</i> turned on in the configuration file) Redis will try to use the same string object instead to allocate one new every time.
<br/><br/>Starting from version 
1.1 Redis is also able to encode in a special way strings that are actually just numbers. Instead to save the string as an array of characters Redis will save the integer value in order to use less memory. With many datasets this can reduce the memory usage of about 
30% compared to Redis 
1.0.