acl/lib_acl_cpp/samples/string/string5/main.cpp

128 lines
2.5 KiB
C++
Raw Normal View History

#include "lib_acl.h"
#include "acl_cpp/lib_acl.hpp"
#include <stdio.h>
#include <string>
#include <iostream>
2022-06-12 18:02:35 +08:00
static void test_append(acl::string& buf)
{
2022-06-12 18:02:35 +08:00
for (size_t i = 0; i < 50; i++) {
buf.format_append("%zd->hello world!\r\n", i);
}
}
2022-06-12 18:02:35 +08:00
static void test_mmap_write(int max, size_t off)
{
const char* filename = "local.map";
acl::fstream fp;
2022-06-12 18:02:35 +08:00
if (!fp.open(filename, O_RDWR | O_CREAT /* | O_TRUNC */, 0600))
{
printf("open %s error %s\r\n", filename, acl::last_serror());
return;
}
size_t max_len = 1024 * 1024 * 500, init_len = 4096;
2022-06-12 18:02:35 +08:00
acl::string buf(fp.file_handle(), max_len, init_len, off);
ACL_METER_TIME(">> begin acl::string");
for (int i = 0; i < max; i++)
{
2022-06-12 18:02:35 +08:00
test_append(buf);
}
ACL_METER_TIME(">> end acl::string");
}
2022-06-12 18:02:35 +08:00
static void test_mmap_read(size_t off)
{
const char* filename = "local.map";
acl::fstream fp;
if (!fp.open(filename, O_RDWR | O_CREAT, 0600))
{
printf("open %s error %s\r\n", filename, acl::last_serror());
return;
}
size_t max_len = 1024 * 1024 * 500, init_len = 0;
acl::string buf(fp.file_handle(), max_len, init_len, off);
char tmp[256];
memcpy(tmp, buf.c_str(), sizeof(tmp) - 1);
tmp[sizeof(tmp) - 1] = 0;
printf("[%s]\r\n", tmp);
}
static void test_mem(int max)
{
size_t max_len = 1024 * 1024 * 500, init_len = 4096;
acl::string buf(init_len);
buf.set_max(max_len);
ACL_METER_TIME(">> begin acl::string");
for (int i = 0; i < max; i++)
{
2022-06-12 18:02:35 +08:00
test_append(buf);
}
ACL_METER_TIME(">> end acl::string");
}
static void usage(const char* procname)
{
2022-06-12 18:02:35 +08:00
printf("usage: %s -h [help]\r\n"
" -m [use_mmap]\r\n"
" -o mapped_offset[default 0]\r\n"
" -R [mapping for reading]\r\n"
" -n max_count\r\n"
, procname);
}
int main(int argc, char* argv[])
{
2022-06-12 18:02:35 +08:00
bool use_mmap = false, mapped_read = false;
int ch, max = 100000;
2022-06-12 18:02:35 +08:00
size_t mapped_off = 0;
2022-06-12 18:02:35 +08:00
while ((ch = getopt(argc, argv, "hmn:o:R")) > 0)
{
switch (ch)
{
case 'h':
usage(argv[0]);
return 0;
case 'm':
use_mmap = true;
break;
2022-06-12 18:02:35 +08:00
case 'o':
mapped_off = (size_t) atoi(optarg);
break;
case 'R':
mapped_read = true;
break;
case 'n':
max = atoi(optarg);
break;
default:
break;
}
}
2022-06-12 18:02:35 +08:00
if (!use_mmap)
test_mem(max);
2022-06-12 18:02:35 +08:00
else if (mapped_read)
test_mmap_read(mapped_off);
else
test_mmap_write(max, mapped_off);
acl::string buf("hello world!");
// XXX: fixme?
// std::cout << buf << std::endl;
std::string tmp = buf;
std::cout << tmp << std::endl;
return (0);
}