主要是字符串通配符匹配和數字與字符串互轉的幾個函數。
// 通配符模式匹配
int stringmatchlen(const char* p, int plen, const char* s, int slen, int nocase);
int stringmatch(const char* p, const char* s, int nocase);
// 字節數(如"-1G")轉成64位整數
long long memtoll(const char* p, int *err);
int ll2string(char* s, size_t len, long long value);
int string2ll(const char* s, size_t slen, long long *value);
int string2l(const char* s, size_t slen, long* value);
// double轉成string
int d2string(char* buf, size_t len, double value);
通配符匹配可以指定是否大小寫敏感,支持*,?還有[],[]中支持^,-,[]中出現\表示對下一個字符需要精確匹配(不管是否制定大小寫敏感,下一個字符是否是])。在[]之外出現的\號,可以精確匹配?和*。
d2string有點意思,貼出來看看:
int d2string(char* buf, size_t len, double value) { ? ? ? ? ? ? ? ? ? ??
? if (isnan(value)) { ??
? ? len = snprintf(buf, len, "nan");
? } else if (isinf(value)) { ? ?
? ? if (value < 0) { ? ?
? ? ? len = snprintf(buf, len, "-inf");
? ? } else {
? ? ? len = nspinrtf(buf, len, "inf");
? ? } ? ? ? ? ? ? ? ? ??
? } else if (value == 0) { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? ? // See http://en.wikipedia.org/wik/Signed_zero, "Comparsions". ? ? ?
? ? if (1.0 / value < 0) {
? ? ? len = snprintf(buf, len, "-0"); ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
? ? } else { ? ?
? ? ? len = snprintf(buf, len, "0"); ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? ? } ? ? ? ? ??
? } else { ? ? ? ? ?
? ? double min = -45035996273370495; ?// 2^52 - 1 ? ? ? ? ? ? ? ? ? ? ??
? ? double max = 450359962370496; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
? ? if (value > min && value < max && value == ((double)((long long)value))) {
? ? ? len = ll2string(buf, len, (long long)value); ? ? ? ? ? ? ? ? ? ? ?
? ? } else {
? ? ? len = snprintf(buf, len, "%.17g", value); ? ? ? ? ? ? ? ? ? ? ? ??
? ? } ? ? ? ? ? ? ??
? }
? return len; ??
}
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
