文章目录

  • strncpy, strncpy_s参考文档用法
  • strcpy, strncpy实例
    • strcpy, strncpy用法举例
    • 运行结果
  • stpcpy()和stpncpy()用法上的区别(C语言版)
  • stpcpy()和stpncpy()用法
    • stpcpy()和stpncpy()用法**区别:**
  • 补充:C/C++编程笔记:C语言字符数组初始化,有些赋值方式千万注意!
    • 一、字符数组的定义和初始化
    • 二、字符数组与字符串
    • 三、赋值方式

strncpy, strncpy_s参考文档用法

C++ API参考文档 cppreference

C++字符串库链接 字符串库

定义于头文件 <string.h>
char *strncpy( char *dest, const char *src, size_t count ); (C99前)
char *strncpy( char *restrict dest, const char *restrict src, size_t count ); (C99起)
errno_t strncpy_s(char *restrict dest, rsize_t destsz, const char *restrict src, rsize_t count); (C11 起)

​ (1)、复制 src 所指向的字符数组的至多 count 个字符(包含空终止字符,但不包含后随空字符的任何字符)到 dest 所指向的字符数组。

  • 若在完全复制整个 src 数组前抵达 count ,则结果的字符数组不是空终止的。
  • 若在复制来自 src 的空终止字符后未抵达 count ,则写入额外的空字符到 dest ,直至写入总共 count 个字符。
  • 若字符数组重叠,若 destsrc 不是指向字符数组的指针(包含若 destsrc 为空指针),若 dest 所指向的数组大小小于 count ,或若 src 所指向的数组大小小于 count 且它不含空字符,则行为未定义。

​ (2)、同 (1) ,除了函数不持续写入零到目标数组以填满 count ,它在写入空终止字符后停止(若源中无空字符,则它于 dest[count] 写入一个然后停止)。并且在运行时检测下列错误并调用当前安装的制约处理函数:

  • dest 所指的字符数组大小 < strnlen_s(src, destsz) <= destsz 则行为未定义;换言之,错误的 destsz 值不暴露行将发生的缓冲区溢出。若 src 所指的字符数组大小 < strnlen_s(src, count) < destsz 则行为未定义;换言之,错误的 count 值不暴露行将发生的缓冲区溢出。

参数

dest 指向要复制到的字符数组的指针
src 指向复制来源的字符数组的指针
count 要复制的最大字符数
destsz 目标缓冲区的大小

返回值

  1. 返回 dest 的副本
  2. 成功时返回零,错误时返回非零。而且,在错误时写入零到 dest[0] (除非 dest 为空指针,或 destsz 为零或大于 RSIZE_MAX ),而且可能以未指定值破坏目标数组的剩余部分。

注解

按 C11 后的 DR 468 更正, strncpy_s 不同于strcpy_s,仅若错误发生才被允许破坏目标数组的剩余部分。

不同于 strncpystrncpy_s 不以零填充目标数组。这是转换既存代码到边界检查版本的常见错误源。

尽管适合目标缓冲区的截断是安全风险,从而是 strncpy_s 的运行时制约违规,还是可通过指定 count 等于目标数组大小减一以获取截断行为:它会复制首 count 个字节,并照常添加空终止符: strncpy_s(dst, sizeof dst, src, (sizeof dst)-1);

strcpystrcpy_s(C11) 复制一个字符串给另一个 (函数)
memcpymemcpy_s(C11) 将一个缓冲区复制到另一个 (函数)
strndup(动态内存 TR) 分配字符串副本,至多到指定的大小 (函数)

strcpy, strncpy实例

strcpy, strncpy用法举例

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <string>
using namespace std;
int main()
{//char src[] = "hi";//char dest[7] = "abcdef"; // 有一个'\0'结束字符//cout << strncpy(dest, src, 5) << endl;string _str = "aaabbbccc";char _d1[10] = "00000";char _d2[100] = "\0";//char _d2[100] = "00000";//char _d2[100] = { '\0' } ;//char _d2[100] = '\0';//马上报错,error C2440: “初始化”: 无法从“char”转换为“char [100]”//cout << strcpy(_d1, _str) << endl;//马上报错cout << strcpy(_d1, _str.c_str()) << endl;//转化cout << strncpy(_d2, _str.c_str(), 3) << endl;//"aaa"return 0;
}

运行结果

调试错误: 目标字符串内存空间太小,内存溢出

stpcpy()和stpncpy()用法上的区别(C语言版)

**参考代码链接地址:**https://www.apiref.com/c-zh/stpcpy.htm

函数名: stpcpy
功  能: 拷贝一个字符串到另一个
用  法: #include <string.h>char *stpcpy(char *destin, char *source);
程序例:
#include <stdio.h>
#include <string.h>
int main(void)
{char string[10];char *str1 = "abcdefghi";stpcpy(string, str1);printf("%s\n", string);return 0;
}

stpcpy()和stpncpy()用法

用途:用法和作用和strcpy()和strncpy()一样,都是复制字符串

stpcpy()和stpncpy()用法区别:
  • strcpy()和strncpy()返回:复制之后的起始地址
  • stpcpy()和stpncpy()返回:复制之后的末尾地址
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <cstring>
using namespace std;
int main()
{const char _str[20] = { "abcdefg " };char _d1[1024] = "0";char _d2[1024] = "0";cout << strcpy(_d1, _str) << endl;cout << stpcpy(_d2, _str) << endl;  //extern char *stpcpy(char *dest,char *src)cout << strncpy_s(_d2, _str, 4) << endl;}

//总代码

// stpcpy()和stpncpy()用法上的区别 //   用途:复制字符串//   区别:
//  strcpy()和strncpy()返回:复制之后的起始地址
//  stpcpy()和stpncpy()返回:复制之后的末尾地址//  举例//   stpcpy()和stpncpy()返回:复制之后的末尾地址
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <cstring>
using namespace std;
int main()
{//const char _str[20] = { "abcdefg " };//char _d1[1024] = "0";//char _d2[1024] = "0";//cout << strcpy(_d1, _str) << endl;//cout << stpcpy(_d2, _str) << endl;  //extern char *stpcpy(char *dest,char *src)//cout << strncpy_s(_d2, _str, 4) << endl;char source[1024] = { "abcdef" };char _dst1[1024];char _dst2[1024];std::cout << strcpy(_dst1, source) + 1 << std::endl;///"bcdef"//std::cout << stpcpy(_dst2, source) - 1 << std::endl;}/*
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <string>
using namespace std;
int main()
{//char src[] = "hi";//char dest[7] = "abcdef"; // 有一个'\0'结束字符//cout << strncpy(dest, src, 5) << endl;string _str = "aaabbbccc";char _d1[10] = "00000";char _d2[10] = "\0";//char _d2[100] = "00000";//char _d2[100] = { '\0' } ;//char _d2[100] = '\0';//马上报错,error C2440: “初始化”: 无法从“char”转换为“char [100]”//cout << strcpy(_d1, _str) << endl;//马上报错cout << strcpy(_d1, _str.c_str()) << endl;//转化cout << strncpy(_d2, _str.c_str(), 3) << endl;//"aaa"return 0;
}*/

补充:C/C++编程笔记:C语言字符数组初始化,有些赋值方式千万注意!

一、字符数组的定义和初始化

字符数组的初始化,最容易理解的方式就是逐个字符赋给数组中各元素。

charstr[10]={‘I’,‘’,‘a’,‘m’,‘’,‘h’,‘a’,‘p’,‘p’,‘y’};

即把10个字符分别赋给str[0]到str[9]10个元素

如果花括号中提供的字符个数大于数组长度,则按语法错误处理;若小于数组长度**,则只将这些字符数组中前面那些元素,其余的元素自动定为空字符(即’\0’)**。

如char str[10] = {‘\0’}; //结果里面元素全都为\0.其实这样赋值只是把第1个元素赋值为\0,后面的都默认用\0填充,如果是char str[10]={‘1’};

只有第一个为‘1’,后面都是\0。但千万不要以为写成char str[10];不赋值也可以。这样写里面的内容是乱的。

这是细节,值得注意。

所以我们最好每次想写char str[5]都写成

char str[5]=‘\0’;

这样做最好。

int a[10]={4,5};

第一个赋值为4,第二个为5,后面的为0.如果直接int a[10]; 内容很乱。

规律:用某个值给数组赋值,没有被赋值的元素会自动调用默认的构造函数,如char默认为\0,int默认为0.等等.

二、字符数组与字符串

在 c语言中,将字符串作为字符数组来处理。(c++中不是)

在实际应用中人**们关心的是有效字符串的长度而不是字符数组的长度,**例如,

定义一个字符数组长度为100,而实际有效字符只有40个,为了测定字符串的实际长度,C语言规定了一个“字符串结束标志”,以字符’\0’代表。如果有一个字符串,其中第10个字符为’\0’,则此字符串的有效字符为9个。也就是说,在遇到第一个字符’\0’时,表示字符串结束,由它前面的字符组成字符串。

系统对字符串常量也自动加一个’\0’作为结束符。例如"C Program”共有9个字符,但在内存中占10个字节,最后一个字节’\0’是系统自动加上的。(通过 sizeof()函数可验证)

了结束标志’\0’后,字符数组的长度就显得不那么重要了,在程序中往往依靠检测’\0’的位置来判定字符串是否结束,而不是根据数组的长度来决定字符串长度。当然,在定义字符数组时应估计实际字符串长度,保证数组长度始终大于字符串实际长度。(在实际字符串定义中,常常并不指定数组长度,如 char str[ ])

说明:'\n’代表 ASCII 码为0的字符,从 ASCII码表中可以查到 ASCII 码为0的字符不是一个可以显示的字符,而是一个“空操作符”,即它什么也不干。用它来作为字符串结束标志不会产生附加的操作或增加有效字符,只起一个供辨别的标志。

对C 语言处理字符串的方法由以上的了解后,再对字符数组初始化的方法补充一种方法——即可以用字符串常量来初始化字符数组:

注意sizeof与strlen的不同:

char a[40]={‘0’};

printf(“%d”,sizeof(a));//开辟的数组的总大小40*1

printf(“%d”,strlen(a));

输出 40,1.

char str[ ]={“I am happy”}; 可以省略花括号,如下所示

char str[ ]=“I am happy”;

注意:上述这种字符数组的整体赋值只能在字符数组初始化时使用,不能用于字符数组的赋值,字符数组的赋值只能对其元素一一赋值,如:

char d[5];

d=“hell”;

错误。vs2010提示表达式d必须是可修改的左值。

这跟

int a[5]={1,2,3};

而不能

int a[5];

a={1,2,3}

数组只能在初始化的时候一次性赋值,其他时候必须要一个一个赋值。

看来数组名和指针是有区别的。

下面的赋值方法是错误的

char str[ ];

str=“I am happy”;

不是用单个字符作为初值,而是用一个字符串(注意:字符串的两端是用双引号“”而不是单引号‘’括起来的)作为初值。显然,这种方法更直观方便。(注意:数组str的长度不是10,而是11,这点请务必记住,因为字符串常量"I am happy"的最后由系统自动加上一个’\0’)

因此,上面的初始化与下面的初始化等价

char str[ ]={‘I’,’ ‘,‘a’,‘m’,’ ‘,‘h’,‘a’,‘p’,‘p’,‘y’,’\0’};必须要人为加上一个\0,否则strlen不正确。

而不与下面的等价

char str[ ]={‘I’,’ ‘,‘a’,‘m’,’ ',‘h’,‘a’,‘p’,‘p’,‘y’};//strlen错误,后面没有\0

前者的长度是11,后者的长度是10.

说明:字符数组并不要求它的最后一个字符为’\0’,甚至可以不包含’\0’,向下面这样写是完全合法的。

char str[5]={‘C’,‘h’,‘i’,‘n’,‘a’};

可见,用两种不同方法初始化字符数组后得到的数组长度是不同的。

三、赋值方式

对字符数组只能对各个元素赋值,不能用以下方法对字符数组赋值

char str[14];

str=“I love China”; (但在字符数组初始化时可以,即 charstr[14]=“I love China”;)

而对字符指针变量,采用下面方法赋值:

char* a;

a=“I love China”;

或者是 char* a=“I love China”; 都可以

对字符指针变量赋初值(初始化):

char* a=“I love China”;

等价于:

char* a

a=“I love China”;

而对于字符数组的初始化

char str[14]=“I love China”;

不能等价于:

char str[14];

str=“I love China”; (这种不是初始化,而是赋值,而对数组这样赋值是不对的)

stpcpy和stpncpy用法 strcpy和strncpy用法相关推荐

  1. strncpy 用法

    strncpy 用法 原型:extern char *strncpy(char *dest, char *src, int n);用法:#include <string.h>功能:把src ...

  2. strcpy()与strncpy()的区别

    头文件:#include <string.h> strcpy() 函数用来复制字符串,其原型为: char *strcpy(char *dest, const char *src); [参 ...

  3. strcpy()、strncpy()函数

    本片博客简单写下关于strcpy().strncpy()两函数的用法.区别及使用时需要注意的地方. 一.使用介绍 1. strcpy()函数用法 char * strcpy ( char * dest ...

  4. c语言 字符串 strncpy,详解c语言中的 strcpy和strncpy字符串函数使用

    详解c语言中的 strcpy和strncpy字符串函数使用 strcpy 和strcnpy函数--字符串复制函数. 1.strcpy函数 函数原型:char *strcpy(char *dst,cha ...

  5. C语言 - strcpy和strncpy的编程实现及总结

    一.字符串的strcpy与strncpy函数 1.编程实现strcpy函数(笔试很容易考到) 要求: 原型:char *stpcpy(char *strDest,char *strSrc); 头文件: ...

  6. c语言strncpy源码,C语言 - strcpy和strncpy的编程实现及总结

    一.字符串的strcpy与strncpy函数 1.编程实现strcpy函数(笔试很容易考到) 要求: 原型:char *stpcpy(char *strDest,char *strSrc); 头文件: ...

  7. strcpy和memcpy的区别 | strcpy和strncpy的区别

    strcpy和memcpy都是标准C库函数,它们有下面的特点. strcpy提供了字符串的复制.即strcpy只用于字符串复制,并且它不仅复制字符串内容之外,还会复制字符串的结束符. 已知strcpy ...

  8. strcpy和strncpy区别 memcpy strcpy strncpy lstrcpy lstrncpy wstrcpy, memmove

    strcpy和strncpy区别(2009-04-27 15:48:52) 转载标签:杂谈 分类:C++/C 第一种情况: char* p="how are you ?"; cha ...

  9. Compound Words UVA - 10391(c++用法中substr函数用法+map实现)

    题意: 给出字典中一堆单词,单词的输入方式是以字典序输入的.问:在这一堆单词中,有那些单词是通过其它两个单词组合而来的.按字典序升序输出这些单词. 题目: You are to find all th ...

最新文章

  1. Vue.js 组件注册
  2. PPT 下载 | 数据治理中的一些挑战与应用
  3. phpstudy sqlsrv v8.1_phpStudy
  4. 【数据结构与算法】之深入解析“两数相除”的求解思路与算法示例
  5. java按钮权限控制_详解Spring Security 中的四种权限控制方式
  6. 电脑键盘上每个键的作用_眼看着淡出大众视野 键盘上Esc键的隐秘往事
  7. 查找算法——折半查找(JAVA)
  8. ARM栈帧与编译选项
  9. TensorFlow书籍
  10. etcd3 安装与运维
  11. hadoop在windows上的环境配置及HDFS API编程示范
  12. 51蜂鸣器播放提示音和音乐(完整代码可附赠Proteus仿真)
  13. java版教材管理系统源码
  14. jQuery实现点击复制文本效果
  15. excel如何把顺序倒过来_excel表格数据前后顺序颠倒-求助:怎样使excel的数据顺序倒过来...
  16. 【OpenCV】计算两幅图片视觉差
  17. 78 python - 打飞机案例(让敌机移动)
  18. 社保及公积金转外省流程
  19. 在电脑屏幕上截图的5种方式
  20. microLED应该会取代OLED的

热门文章

  1. 解决Word文章表格中无法自动换页的问题,表格结尾处像是被下一页覆盖掉了
  2. (转载)书蕴——基于书评的人工智能推荐系统
  3. Android7以上的手机通过fiddler抓包
  4. Android 监听屏幕唤醒、关闭和解锁的广播
  5. 安卓SDK——人脸识别
  6. phpstudy端口被占用
  7. 模态对话框和非模态对话框的区别
  8. tif文件转为shp文件_ArcGIS栅格数据与矢量数据的转换
  9. 01-数据结构和算法入门
  10. 2021 PyTorch官方实战教程(一)Tensor 详解