shad-go/varfmt
erius bfb0daa1ef Updated .gitignore to ignore .out and .test profiling files
Replaced interface{} with any in varfmt
Implemented varfmt, could be further optimized
2024-06-03 20:26:36 +03:00
..
fmt.go Updated .gitignore to ignore .out and .test profiling files 2024-06-03 20:26:36 +03:00
fmt_test.go Updated .gitignore to ignore .out and .test profiling files 2024-06-03 20:26:36 +03:00
README.md update mod && fix links 2023-10-03 20:25:41 +03:00

varfmt

Реализуйте функцию varfmt.Sprintf. Функция принимает формат строку и переменное число аргументов.

Синтаксис формат-строки похож на формат-строки питона:

  • {number} - ссылается на аргумент с индексом number
  • {} - задаёт ссылку на аргумент с индексом, равным позиции {} среди всех ссылок (как {}, так и {number}) внутри паттерна

Например, varfmt.Sprintf("{1} {0}", "Hello", "World") должен вернуть строку World Hello, а varfmt.Sprintf("{0} {}", "Hello", "World") должен вернуть строку Hello World.

Аргументы функции могут быть произвольными типами. Вам нужно форматировать их так же, как это делает функция fmt.Sprint. Вызывать fmt.Sprint для форматирования отдельного аргумента не запрещается.

Ваше решение будет сравниваться с baseline-решением на бенчмарке. Сравнение будет проходить независимо по трем метрикам.

  • time/op - время на одну итерацию бенчмарка
  • alloc/op - число выделенных байт на одну итерацию бенчмарка
  • allocs/op - число выделенных объектов на одну итерацию бенчмарка

Ваш код должен быть не более чем в два раза хуже чем baseline.

goos: linux
goarch: amd64
pkg: gitlab.com/manytask/itmo-go/public/varfmt
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
PASS

Для поиска лишних аллокаций используйте pprof.

Примеры

Как запустить все тесты и бенчмарки:

go test -v -bench=. ./varfmt/...

Как запустить только бенчмарки:

go test -v -run=^a -bench=. ./varfmt/...

Здесь ^a - регулярное выражение, задающее тесты для запуска, а . - задаёт бенчмарки.

Как запустить только big бенчмарки:

go test -v -run=^a -bench=/big ./varfmt/...