1. strncpy和strncpy_s使用区别
时间: 2023-10-17 11:36:15 浏览: 238
strncpy和strncpy_s都是用来复制字符串的函数,但是它们有一些使用上的区别。
strncpy函数的原型是:
```c
char *strncpy(char *dest, const char *src, size_t n);
```
它将src字符串的前n个字符复制到dest字符串中,如果src字符串长度小于n,则在复制完毕后,dest字符串的剩余部分会用'\0'进行填充。需要注意的是,当src字符串的长度大于等于n时,dest字符串不会以'\0'结尾。
而strncpy_s函数是C11新增的安全版字符串复制函数,其原型是:
```c
errno_t strncpy_s(char *dest, rsize_t destsz, const char *src, rsize_t count);
```
它的使用方式与strncpy函数类似,但是多了两个参数:destsz和count。destsz表示目标字符串dest的大小,count表示要复制的字符个数。
strncpy_s函数会在以下情况下返回非零错误码errno:
- dest为空指针
- src为空指针
- destsz为0或小于count
- destsz小于dest字符串的长度(包括'\0')
总结来说,strncpy_s函数在使用上更加安全,可以避免一些潜在的缓冲区溢出问题。而strncpy函数则需要开发者自行确保目标字符串的大小和正确处理'\0'的添加。
相关问题
strncpy 替换为 strncpy_s
strncpy_s是strncpy的安全版本,它始终确保目标缓冲区以空字符结尾,并且在缓冲区溢出时会触发运行时错误。因此,如果您需要在预定义的接口中使用strncpy功能,可以将其替换为strncpy_s以提高安全性。但是,如果您需要在长度超过1的字符串上使用strncpy_s,则需要注意返回值E_UNEXPECTED,因为它不会像strncpy一样截断字符串。
解释一下这段代码void erase_wifi(char* ssid) { int i = 0; uint8_t is_wifi_exist = 0; if (NULL == ssid || 0 == strcmp(ssid, "")) { wifi_error("ssid is NULL or ssid empty"); goto exit; } for (i = 0; i < s_wifi_list->wifi_cnt; i++) { if (0 == strcmp(s_wifi_list->wifi_info[i].ssid, ssid)) { is_wifi_exist = 1; break; } } OS_MutexLock(&record_wifi_list_opt_mutex, OS_WAIT_FOREVER); if (!is_wifi_exist) { wifi_error("wifi [%s] not exist.", ssid); goto exit; } else { app_wifi_set_erase_wifi_info(s_wifi_list->wifi_info[i].ssid, s_wifi_list->wifi_info[i].pwd); strncpy(s_wifi_list->wifi_info[i].ssid, s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].ssid, MAX_SSID_LEN); strncpy(s_wifi_list->wifi_info[i].pwd, s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].pwd, MAX_PWD_LEN); memset(s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].ssid, 0, MAX_SSID_LEN); memset(s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].pwd, 0, MAX_PWD_LEN); if (s_wifi_list->wifi_cnt == WIFI_INFO_CNT) { s_wifi_list->write_idx = 9; } else { s_wifi_list->write_idx -= 1; } s_wifi_list->wifi_cnt -= 1; } #if CFG_USE_LFS _wifi_info_save_to_lfs(); #else _wifi_info_save(); #endif exit: OS_MutexUnlock(&record_wifi_list_opt_mutex); return; }
这段代码是一个函数,用于删除特定的Wi-Fi网络信息。函数接受参数ssid,表示要删除的Wi网络的名称。
首函数会检查参数的有效性。如果ssid为NULL或为空字符串会打印错误消息并跳转到末尾。
接下来,函数会遍存储Wi-Fi信息的s_wifi_list,查与参数ssid匹配的-Fi网络。如果找到了匹的网络,则将is_wifi_exist志设置为1,并循环。
在进入临界区之前,函数会使用互斥锁(OS_MutexLock)锁定对记录Wi-Fi列表进行操作的互斥访问。
如果is_wifi_exist标志为0,表示未找到与参数ssid匹配的Wi-Fi网络,则会打印错误消息并跳转到函数末尾。
如果找到了匹配的Wi-Fi网络,函数会使用app_wifi_set_erase_wifi_info函数设置要删除的Wi-Fi网络的信息,并将该网络信息替换为数组中最后一个Wi-Fi网络的信息。然后,将最后一个Wi-Fi网络的信息清空。
接下来,根据Wi-Fi网络信息的数量进行一些调整。如果当前Wi-Fi网络数量等于WIFI_INFO_CNT,则将write_idx设置为9;否则,将write_idx减1。然后,将Wi-Fi网络数量减1。
最后,根据预编译指令选择调用_wifi_info_save_to_lfs函数将Wi-Fi网络信息保存到LFS(Local File System)中,或调用_wifi_info_save函数将Wi-Fi网络信息保存到其他存储介质中。
最后,释放临界区的互斥锁(OS_MutexUnlock)并返回函数。
这段代码的作用是从Wi-Fi网络列表中删除指定的Wi-Fi网络信息,并将修改后的列表保存到存储介质中。
阅读全文