Ich war neugierig auf das Verhalten des String-Bereichs von Crystal und habe verschiedene Dinge in anderen Sprachen untersucht.
Perl
% perl -v | head -2 | tail -1
This is perl 5, version 14, subversion 2 (v5.14.2) built for x86_64-linux
% perl -e 'print chr ++($foo = ord "Z");'
[
% perl -e 'print ++($foo = "Z");'
AA
% perl -e 'print "A".."Z";'
ABCDEFGHIJKLMNOPQRSTUVWXYZ
% perl -e 'print "A".."z";'
ABCDEFGHIJKLMNOPQRSTUVWXYZ
Das ist intensiv.
% perl -e 'print "a".."Z";'
abcdefghijklmnopqrstuvwxyz
% perl -e 'print "ZZ".."z";'
%
Ruby
$ ruby -v
ruby 2.2.2p95 (2015-04-13 revision 50295) [x86_64-darwin13]
> "Z".ord.succ.chr
=> "["
> "Z".succ
=> "AA"
("A".."z").to_a
=> ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "[", "\\", "]", "^", "_", "`", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"]
> ("A".."AA").to_a
=> ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "AA"]
> ("ZZ".."z").to_a
=> ["ZZ"]
Python
$ python -V
Python 3.4.2
In [1]: x = ord("Z"); x += 1; chr(x)
Out[1]: '['
Kann nicht.
Es gibt keine solche Syntax, aber sie kann geschrieben werden.
for x in range(ord("A"), ord("[")):
print(chr(x), end="")
#=> ABCDEFGHIJKLMNOPQRSTUVWXYZ
Sie können auch "string.ascii_letters" mit "import string" verwenden, jedoch nur im Fall des Alphabets.
for x in string.ascii_letters:
print(x, end="")
#=> abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ
Kann nicht.
% dmd -v | head -1
DMD64 D Compiler v2.068.0
import std.stdio;
void main()
{
char x;
(++(x = 'Z')).writeln;
}
% rdmd x.d
[
import std.stdio;
import std.string;
void main()
{
"Z".succ.writeln;
}
% rdmd xx.d
AA
import std.stdio;
import std.range;
void main()
{
iota('A', '[').writeln;
}
% rdmd xxx.d
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
Kann nicht.
Crystal
% crystal -v
Crystal 0.7.7 [170f859](Sat Sep 5 02:53:51 UTC 2015)
Z
puts 'Z'.succ
% crystal x.cr
[
Z
puts "Z".succ
% crystal x.cr
AA
% cat xx.cr
p ('A'..'z').to_a
% crystal xx.cr
['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '[', '\\', ']', '^', '_', '`', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
Das ist in Ordnung.
% cat xxx.cr
p ("A".."Z").to_a
% crystal xxx.cr
["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]
Problemfall.
% cat xxx.cr
p ("A".."z").to_a
"A" -> "Z" -> "AA" -> "ZZ" -> "AAA" -> "AAA .." -> "ZZZ .." wird auf unbestimmte Zeit aufgerufen.
% crystal xxx.cr
^C
Die Implementierung des String-Bereichs ist ganz anders. Ich habe es hier nicht angegeben, aber Julia und Elixir scheinen den String-Bereich oder das Äquivalent von "String # succ" nicht zu implementieren.
Recommended Posts