------ art_5194_21906654.1159679001304
Content-Type: text/plain; charset=ISO-8859-1; format=flowed
Content-Transfer-Encoding: 7bit
Content-Disposition: inline
Hello,
I'm working on the Fast JSON project, and have come against some puzzling
performance quirk.
Most of the Hash#to_json functionality is implemented in C and performs much
better. However there is one section that performs 6 time better when
implemented in ruby vs c.
I wrote a benchmark that calls to_json on 50000 hashes.
Here is the method in Ruby. The benchmark takes around 1.7 seconds:
def process_internal_json(json, state, depth, delim)
first rue
each { |key,value|
if first
first alse
else
json << delim
end
generate_key_value_json(json, state, depth, key, value)
}
json
end
Here is the method in C. The benchmark takes around 9.5 seconds:
static VALUE process_internal_json(VALUE self, VALUE json, VALUE state,
VALUE depth, VALUE delim) {
int first ;
VALUE key_value_pairs b_funcall(self, rb_intern("to_a"), 0);
VALUE key_value nil;
while((key_value b_ary_pop(key_value_pairs)) ! nil) {
if(first 1) {
first ;
}
else {
rb_str_concat(json, delim);
}
VALUE value b_ary_pop(key_value);
VALUE key b_ary_pop(key_value);
generate_key_value_json(self, json, state, depth, key, value);
}
}
It seems like there is some optimization in the Hash#each method. I'm trying
to figure out how to get that same performance benefit using C. Perhaps its
is not worth it though.
Does anybody know what going on?
Thank you,
Brian Takita
------ art_5194_21906654.1159679001304--