#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "test.h"
#define LEN 200000
static int bstrstr(int N, const char *needle) {
size_t l = strlen(needle);
size_t cnt = 10000;
int i;
int cs = 0;
char *haystack = malloc(l * cnt + 1);
for (i=0; i<cnt-1; i++) {
memcpy(haystack + l*i, needle, l);
haystack[l*i+l-1] ^= 1;
}
memcpy(haystack + l*i, needle, l+1);
reset_timer();
for (i=0; i<N; i++) {
haystack[0]^=1;
cs += (int)strstr(haystack, needle);
}
free(haystack);
return cs;
}
void bench_string_strstr1(int N) {
bstrstr(N, "abcdefghijklmnopqrstuvwxyz");
}
void bench_string_strstr2(int N) {
bstrstr(N, "azbycxdwevfugthsirjqkplomn");
}
void bench_string_strstr3(int N) {
bstrstr(N, "aaaaaaaaaaaaaacccccccccccc");
}
void bench_string_strstr4(int N) {
bstrstr(N, "aaaaaaaaaaaaaaaaaaaaaaaaac");
}
void bench_string_strstr5(int N) {
bstrstr(N, "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaac");
}
void bench_string_memset(int N) {
char *buf = malloc(LEN);
int i;
for (i=0; i<N; i++)
memset(buf+i, i, LEN-i);
free(buf);
}
void bench_string_strchr(int N) {
char *buf = malloc(LEN);
int i;
int cs = 0;
memset(buf, 'a', LEN);
buf[LEN-1] = 0;
buf[LEN-2] = 'b';
reset_timer();
for (i=0; i<N; i++) {
buf[i] = '0'+i%8;
cs ^= (int)strchr(buf, 'b');
}
buf[0] = cs;
free(buf);
}
void bench_string_strlen(int N) {
char *buf = malloc(LEN);
int i;
int cs = 0;
memset(buf, 'a', LEN-1);
buf[LEN-1] = 0;
reset_timer();
for (i=0; i<N; i++) {
buf[i] = '0'+i%8;
cs ^= strlen(buf);
}
buf[0] = cs;
free(buf);
}