2019-07-28 10:31:56 +08:00
|
|
|
#include "lib_acl.h"
|
2016-02-05 10:10:24 +08:00
|
|
|
#include "acl_cpp/lib_acl.hpp"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string>
|
2022-05-19 17:57:55 +08:00
|
|
|
#include <iostream>
|
2016-02-05 10:10:24 +08:00
|
|
|
|
2022-06-12 18:02:35 +08:00
|
|
|
static void test_append(acl::string& buf)
|
2016-02-05 10:10:24 +08:00
|
|
|
{
|
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);
|
|
|
|
}
|
2016-02-05 10:10:24 +08:00
|
|
|
}
|
|
|
|
|
2022-06-12 18:02:35 +08:00
|
|
|
static void test_mmap_write(int max, size_t off)
|
2016-02-05 10:10:24 +08:00
|
|
|
{
|
|
|
|
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))
|
2016-02-05 10:10:24 +08:00
|
|
|
{
|
|
|
|
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);
|
2016-02-05 10:10:24 +08:00
|
|
|
|
|
|
|
ACL_METER_TIME(">> begin acl::string");
|
|
|
|
|
|
|
|
for (int i = 0; i < max; i++)
|
|
|
|
{
|
2022-06-12 18:02:35 +08:00
|
|
|
test_append(buf);
|
2016-02-05 10:10:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
2016-02-05 10:10:24 +08:00
|
|
|
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);
|
2016-02-05 10:10:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
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);
|
2016-02-05 10:10:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
2022-06-12 18:02:35 +08:00
|
|
|
bool use_mmap = false, mapped_read = false;
|
2016-02-05 10:10:24 +08:00
|
|
|
int ch, max = 100000;
|
2022-06-12 18:02:35 +08:00
|
|
|
size_t mapped_off = 0;
|
2016-02-05 10:10:24 +08:00
|
|
|
|
2022-06-12 18:02:35 +08:00
|
|
|
while ((ch = getopt(argc, argv, "hmn:o:R")) > 0)
|
2016-02-05 10:10:24 +08:00
|
|
|
{
|
|
|
|
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;
|
2016-02-05 10:10:24 +08:00
|
|
|
case 'n':
|
|
|
|
max = atoi(optarg);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-12 18:02:35 +08:00
|
|
|
if (!use_mmap)
|
2016-02-05 10:10:24 +08:00
|
|
|
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);
|
2016-02-05 10:10:24 +08:00
|
|
|
|
2022-05-19 17:57:55 +08:00
|
|
|
acl::string buf("hello world!");
|
|
|
|
|
|
|
|
// XXX: fixme?
|
|
|
|
// std::cout << buf << std::endl;
|
|
|
|
|
|
|
|
std::string tmp = buf;
|
|
|
|
std::cout << tmp << std::endl;
|
2016-02-05 10:10:24 +08:00
|
|
|
return (0);
|
|
|
|
}
|