Для тех из вас, кто предпочитает более сжатый и легкий для чтения стиль лямбда-кодирования ...
В этом примере из широкой строки удаляются все не буквенно-цифровые символы и символы пробела. Вы можете смешать его с любым другим ctype.h вспомогательной функцией чтобы удалить сложные на вид символьные тесты.
(Я не уверен, как эти функции будут обрабатывать языки CJK, так что не торопитесь.)
// Boring C loops: 'for(int i=0;i<str.size();i++)'
// Boring C++ eqivalent: 'for(iterator iter=c.begin; iter != c.end; ++iter)'
Посмотрите, не кажется ли вам это проще для понимания, чем шумные циклы C / C ++ для / итератора:
TSTRING label = _T("1. Replen & Move RPMV");
TSTRING newLabel = label;
set<TCHAR> badChars; // Use ispunct, isalpha, isdigit, et.al. (lambda version, with capture list parameter(s) example; handiest thing since sliced bread)
for_each(label.begin(), label.end(), [&badChars](TCHAR n){
if (!isalpha(n) && !isdigit(n))
badChars.insert(n);
});
for_each(badChars.begin(), badChars.end(), [&newLabel](TCHAR n){
newLabel.erase(std::remove(newLabel.begin(), newLabel.end(), n), newLabel.end());
});
Результат newLabel после выполнения этого кода: " 1ReplenMoveRPMV "
Это чисто академический вопрос, так как было бы явно более точным, кратким и эффективным объединить логику if из lambda0 (сначала for_each ) в одну lambda1 (вторая for_each ), если вы уже установили, какие символы являются «badChars» .