Hacker News new | past | comments | ask | show | jobs | submit login

I don't know any in particular, but a few tips here.

I would say rule 1 is to not use strings unless needed :-)

My rule 2 would be to not use a library because that would probably add too much complexity (especially with regards to integrating memory allocation).

There are different valid ways to represent strings, but a basic approach is of course to use arrays of bytes, i.e. pointer + length (struct String { char buffer; int length; }). An important consideration is the choice of allocation scheme for the byte buffer. I'd recommend to use statically allocated strings (like char buffer[32];*) where possible, and to look into memory arenas. Don't make "resizable" strings unless absolutely needed (with resizeable strings you might run into dangling reference problems more easily, and you will probably need a "capacity" field in addition to pointer + length). Most dynamically-sized use cases do not need resizing; you can conveniently cover them with a separate string builder (which can be implemented using a large statically allocated storage or using a resized-as-needed storage. Once the string is assembled, the string builder can create the final immutable string by allocating for example from a memory arena.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: