> 
> > Enjoyed Andrei's talk at the NYPHP Conference last week 
> about unicode in
> > PHP 6.  He mentioned that when unicode.semantics is on, 
> strlen() will
> > return the number of characters rather than the number of 
> bytes, like
> > mb_string() does or strlen() if mbstring.func_overload is on.
> >
> > The hitch here is there are situations where one needs to 
> know how many
> > bytes are in a string.  Is there a function I've overlooked 
> that does
> > this or will do this, please?
> >
> My first question is: Why do you need to know the number of 
> bytes occupied
> by a textual string?  Is it because you want to work with 
> binary strings?
> Because that's still very possible:
> 
> Even with unicode.semantics=on, the binary string type may be 
> explicitly
> used in a few ways:
> 
> $a = b"This string contains an 0xF0 byte: \xF0";
> $alen = strlen($a);
> 
> This being the simplest, the lowercase b (or u) characters 
> denote a string
> as being a binary (or unicode) string explicitly.  Leaving 
> these specifiers
> off yield whatever type is appropriate to unicode.semantics.
> 
> In other cases, such as reading from a binary mode file:
> 
> $fp = fopen('foo.bin', 'rb');
> $str = fread($fp, 100);

Hi,

What happens with

$fp = fopen('foo.bin', 'wb');
$written = fwrite($fp, $str);
if (strlen($str) != $written)
{
   echo 'Not written', "\n";
} 

Jared

-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to