2020-02-21 20:43:16 +00:00
|
|
|
|
# varfmt
|
|
|
|
|
|
|
|
|
|
Реализуйте функцию `varfmt.Sprintf`. Функция принимает формат строку и переменное число аргументов.
|
|
|
|
|
|
2020-02-21 23:00:38 +00:00
|
|
|
|
Синтаксис формат-строки похож на формат-строки питона:
|
2020-02-21 20:43:16 +00:00
|
|
|
|
- `{}` - задаёт ссылку на аргумент
|
2020-02-22 21:35:52 +00:00
|
|
|
|
- `{number}` - ссылается на аргумент с индексом `number`
|
2020-02-21 20:43:16 +00:00
|
|
|
|
- `{}` ссылается на аргумент с индексом равным позиции `{}` внутри паттерна
|
|
|
|
|
|
2020-02-21 23:13:25 +00:00
|
|
|
|
Например, `varfmt.Sprintf("{1} {0}", "Hello", "World)` должен вернуть строку `World Hello`.
|
2020-02-21 20:43:16 +00:00
|
|
|
|
|
|
|
|
|
Аргументы функции могут быть произвольными типами. Вам нужно форматировать их так же, как это
|
|
|
|
|
делает функция `fmt.Sprint`. Вызывать `fmt.Sprint` для форматирования отдельного аргумента
|
|
|
|
|
не запрещается.
|
|
|
|
|
|
2020-02-22 20:47:44 +00:00
|
|
|
|
Ваше решение будет сравниваться с baseline-решением на бенчмарке. Сравнение будет
|
|
|
|
|
проходить независимо по трем метрикам.
|
|
|
|
|
- `time/op` - время на одну итерацию бенчмарка
|
|
|
|
|
- `alloc/op` - число выделенных байт на одну итерацию бенчмарка
|
|
|
|
|
- `allocs/op` - число выделенных объектов на одну итерацию бенчмарка
|
|
|
|
|
|
|
|
|
|
Ваш код должен быть не более чем в два раза хуже чем baseline.
|
2020-02-21 22:57:19 +00:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
goos: linux
|
|
|
|
|
goarch: amd64
|
|
|
|
|
pkg: gitlab.com/slon/shad-go/varfmt
|
2020-02-22 12:40:34 +00:00
|
|
|
|
BenchmarkFormat/small_int-4 4744729 263 ns/op 64 B/op 4 allocs/op
|
|
|
|
|
BenchmarkFormat/small_string-4 2388128 484 ns/op 168 B/op 8 allocs/op
|
|
|
|
|
BenchmarkFormat/big-4 8997 127827 ns/op 194656 B/op 41 allocs/op
|
|
|
|
|
BenchmarkSprintf/small-4 13330094 85.7 ns/op 2 B/op 1 allocs/op
|
|
|
|
|
BenchmarkSprintf/small_string-4 9351295 123 ns/op 16 B/op 1 allocs/op
|
|
|
|
|
BenchmarkSprintf/big-4 12006 108144 ns/op 16392 B/op 1 allocs/op
|
2020-02-21 22:57:19 +00:00
|
|
|
|
PASS
|
2020-02-21 23:20:16 +00:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Примеры
|
|
|
|
|
|
|
|
|
|
Как запустить все тесты и бенчмарки:
|
|
|
|
|
```
|
|
|
|
|
go test -v -bench=. ./varfmt/...
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Как запустить только бенчмарки:
|
|
|
|
|
```
|
|
|
|
|
go test -v -run=^a -bench=. ./varfmt/...
|
|
|
|
|
```
|
|
|
|
|
Здесь `^a` - регулярное выражение, задающее тесты для запуска,
|
|
|
|
|
а `.` - задаёт бенчмарки.
|
|
|
|
|
|
|
|
|
|
Как запустить только big бенчмарки:
|
|
|
|
|
```
|
|
|
|
|
go test -v -run=^a -bench=/big ./varfmt/...
|
|
|
|
|
```
|