首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

深入 char * ,char ** ,char a ,char *a[] 内核

char  str[10] = {"hello world"};          当编译器遇到这句时,会把str数组从第一个元素把hello world\0 逐个填入。。         ...(其实首地址),即第一个字符的地址,这个地址单元的数据是一个字符,    这也与 s 所指向的 char 一致。      ...用一句话来概括,就是 char *s 只是一个保存字符串首地址的指针变量, char a[ ] 是许多连续的内存单元,单元的元素为char ,之所以用 char *能达到  char a  [ ]...,他还是一个数组,数组的元素才是char * ,前面讲到char * 是一个变量,保存的地址。。            ...,从其本质来分析,"hello world",代表一个地址,比如0x003001,这个地址的内容是 'h'   ,为 char 型,而 s 也保存一个地址 ,这个地址的内容(*s) 是char *

2.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    oraclevarchar和char的区别_char跟varchar

    注意: 在oracle varchar2的最大长度为4000 bytes,即varchar2(4000),最多能储存2000个汉子或4000位的数字字母。...oracle char,varchar,varchar2的区别 区别: 1....Oracle自己开发了一个数据类型VARCHAR2,这个类型不是一个标准的VARCHAR,它将在数据库varchar列可以存储空字符串的 特性改为存储NULL值。...VARCHAR2 虽然比CHAR节省空间,但是如果一个VARCHAR2列经常被修改,而且每次被修改的数据的长度不同,这会引起‘行迁移’(Row Migration)现象,而这造成多余的I/O,是数据库设计和调整要尽力避免的...char还会自动补齐空格,因为你insert到一个char字段自动补充了空格的,但是select 后空格没有删除。

    1K31

    charchar[]、char*、 const char*、string(无效的const char *到XXXX的转化)

    自然要附上自己的使用经验了 1、std::string 和QString在网络传输的过程是不建议配套的,传过去,接到就成乱码了。 我因为这个愚蠢而把我们客户端人员坑惨了。...2、char* 使用时建议手动分配空间,不然你也不会知道它什么是就给你段错误了,那时候想改就麻烦了,集腋成裘。 3、双引号括起来的字符串是属于const的。...4、使用char[]前随手memset,不要因为它是局部的。刚刚又因为没有memset把我们客户端人员坑惨了,可能是局部变量占用空间过大,没来得及释放,将上次调用的内容留下了。...5、将char*变量作为参数传入函数,不用传出来了。 6、不要将局部变量地址作为返回值,没意义。 7、把图片里的strncp_s改成strncp.

    1.6K30

    MySQL varchar 和 char 区别

    1. varchar 和 char 共同点 ---- varchar 和 char 是 MySQL 的两种数据类型,都是用来存储字符串的。...2. varchar 和 char 区别 ---- 一、长度是否可变 varchar 类型的长度是可变的,而 char 类型的长度是固定的 char 类型是一个定长的字段,以 char(10) 为例,不管真实的存储内容多大或者是占了多少空间...,都会消耗掉 10 个字符的空间 坦通俗来讲,当定义为 char(10) 时,即使插入的内容是 'abc' 3 个字符,它依然会占用 10 个字节,其中包含了 7 个空字节 二、存储长度 char 长度最大为...255 个字符,varchar 长度最大为 65535 个字符 三、检索效率方面 varchar 类型的查找效率比较低,而 char 类型的查找效率比较高 3. varchar 和 char 的选择...使用场景:使用 md5 加密的密码长度固定为 32 位字符 总结: 可变长度使用 varchar,固定长度使用 char

    1.6K30

    char* 和char[]的差别

    比如,声明在函数中一个局部变量int b;系统自己主动在栈为b开辟空间 heap: 须要程序猿自己申请,并指明大小,在cmalloc函数 如p1=(char*)malloc(10); 在C+...+中用new运算符 如p2=(char*)malloc(10); 可是注意p1、p2本身是在栈的。...2.5堆和栈的存储内容 栈:在函数调用时,第一个进栈的是主函数后的下一条指令(函数调用语句的下一条可运行语句)的 地址,然后是函数的各个參数,在大多数的C编译器,參数是由右往左入栈的,然后是函数的局部变...,能够更改数组的字符,可是char本身是不可改变的常量。...,char[] p是局部变量,当函数结束,存在栈的数组内容均被销毁,因此返回p地址是不同意的。

    1.2K30

    char *a 与char a[] 的区别

    char *a = “hello” 的a是指向第一个字符‘h’的一个指针 char a[20] = “hello” 数组名a也是执行数组第一个字符‘h’的指针 *但二者并不相同:* 看实例...而数组是存放在栈,是可以修改的。两者区别如下: 一. ”读“ ”写“ 能力 char *a = “abcd”; 此时”abcd”存放在常量区。通过指针只可以访问字符串常量,而不可以改变它。...而char a[20] = “abcd”; 此时 “abcd”存放在栈。可以通过指针去访问和修改数组内容。 二. 赋值时刻 char *a = “abcd”; 是在编译时就确定了(因为为常量)。...而char a[20] = “abcd”; 在运行时确定 三. 存取效率 char *a = “abcd”; 存于静态存储区。在栈上的数组比指针所指向字符串快。...因此慢 而char a[20] = “abcd”; 存于栈上。

    1.4K10

    MySQLchar、varchar和text的设计

    首先普及几个常识: 1、char(n)和varchar(n)括号n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。...2、同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。...3、超过char和varchar的n设置后,字符串会被截断。 4、char的上限为255字节,varchar的上限65535字节,text的上限为65535。...总体来说: 1、char,存定长,速度快,存在空间浪费的可能,会处理尾部空格,上限255。...首先从空间方面: 从官方文档我们可以得知当varchar大于某些数值的时候,其会自动转换为text,大概规则如下: 大于varchar(255)变为 tinytext 大于varchar(500)变为

    2.1K10
    领券