Go语言中make和new函数的用法与区别
相同点:
make和new都是用来创建分配类型内存的。
不同点:
先看下面的代码
package main<br data-filtered="filtered"> import "fmt" <br data-filtered="filtered"> func main(){ var i *int var x = 10 *i=x fmt.Println(*i) }
编译过程会出错
panic: runtime error: invalid memory address or nil pointer dereference <br data-filtered="filtered">[signal 0xc0000005 code=0x1 addr=0x0 pc=0x48b576]
我们的想法是把 10 赋值 i指向的地址,但是这里由于 *i 没有初始化,所以并不知道 *i的地址是什么,如果直接 *i的赋值为10,那么肯定是不行的(10这个地址没有)
所以要想使用 *i,需要把 x的地址给i,修改成如下代码
var i *int var x = 10 i=&x fmt.Println(*i)
补充: * 代表取地址里内容
, &代表取地址
或者使用 new 进行初始化,代码如下:
var x = 10 var i *int i = new(int) *i=x fmt.Println(*i)
new的源代码如下
它只接受一个参数,这个参数是一个类型,分配好内存后,返回一个指向该类型内存地址的指针。同时请注意它同时把分配的内存置为零,也就是类型的零值。
make也是用于内存分配的,但是和new不同,它只用于chan、map以及slice的内存创建,
而且它返回的类型就是这三个类型本身,而不是他们的指针类型,因为这三种类型就是引用类型,所以就没有必要返回他们的指针了。
综上:
二者都是内存的分配(堆上)
区别1
- make只用于slice、map以及channel的初始化(非零值);
- new用于类型的内存分配,并且内存置为零。
区别2
- make返回的还是这三个引用类型本身;
- new返回的是指向类型的指针。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接
相关推荐
-
浅谈Golang的new与make区别是什么
目录 new make 小结: 区别:在go语言中,make和new都是内存的分配(堆上),但是make只用于slice.map以及channel的初始化(非零值):而new用于类型的内存分配,并且内存置为零.make返回的是引用类型本身:而new返回的是指向类型的指针. 本文操作环境:windows10系统.GO 1.11.2.thinkpad t480电脑. Go语言中new和make都是用来内存分配的原语(allocation primitives).简单的说,new只分配内存,make用
-
深入讲解Go语言中函数new与make的使用和区别
前言 本文主要给大家介绍了Go语言中函数new与make的使用和区别,关于Go语言中new和make是内建的两个函数,主要用来创建分配类型内存.在我们定义生成变量的时候,可能会觉得有点迷惑,其实他们的规则很简单,下面我们就通过一些示例说明他们的区别和使用,话不多说了,来一起看看详细的介绍吧. 变量的声明 var i int var s string 变量的声明我们可以通过var关键字,然后就可以在程序中使用.当我们不指定变量的默认值时,这些变量的默认值是他们的零值,比如int类型的零值是0,st
-
Go语言中new()和 make()的区别详解
概述 Go 语言中的 new 和 make 一直是新手比较容易混淆的东西,咋一看很相似.不过解释两者之间的不同也非常容易. new 的主要特性 首先 new 是内建函数,你可以从 http://golang.org/pkg/builtin/#new 这儿看到它,它的定义也很简单: 复制代码 代码如下: func new(Type) *Type 官方文档对于它的描述是: 复制代码 代码如下: 内建函数 new 用来分配内存,它的第一个参数是一个类型,不是一个值,它的返回值是一个指向新分配类型零值的
-
golang中make和new的区别示例详解
前言 本文主要给大家介绍了关于golang中make和new区别的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍: new 和 make 都可以用来分配空间,初始化类型,但是它们确有不同. new(T) 返回的是 T 的指针 new(T) 为一个 T 类型新值分配空间并将此空间初始化为 T 的零值,返回的是新值的地址,也就是 T 类型的指针 *T,该指针指向 T 的新分配的零值. p1 := new(int) fmt.Printf("p1 --> %#v \n &quo
-
Go语言中make和new函数的用法与区别
相同点: make和new都是用来创建分配类型内存的. 不同点: 先看下面的代码 package main<br data-filtered="filtered"> import "fmt" <br data-filtered="filtered"> func main(){ var i *int var x = 10 *i=x fmt.Println(*i) } 编译过程会出错 panic: runtime error:
-
C语言中scanf与scanf_s函数的使用详解
目录 1.scanf_s(是vs提供的函数) 2.scanf(标准的库函数) 3.总结 1.scanf_s(是vs提供的函数) a.代码1 int main() { char a = 0; //scanf_s("%c", &a, 1); scanf_s("%c", &a, sizeof(a)); return 0; } scanf_s有三个参数,最后一个是变量a所占据空间的大小(单位为字节),这里可以写1,也可以写sizeof(a).如果a为整型的话
-
C语言中scanf与scnaf_s函数详解
目录 scanf_s 使用scanf_s scanf 使用scanf 总结 scanf_s scanf_s()函数是Microsoft公司VS开发工具提供的一个功能相同的安全标准输入函数,从vc++2005开始,VS系统提供了scanf_s().在调用该函数时,可以提供一个数字以表明最多读取多少位字符. MSDN上scanf_s的简单模型:int scanf_s( const char *format [, argument]...);一般我们常用的格式:scanf_s(输入格式,输入流 [,输
-
C语言中sizeof()与strlen()函数的使用入门及对比
sizeof()函数 1,是什么? sizeof其实就是一个运算符,和那些+,-一样的东西,在程序编译的时候进行解析转换.虽然我们经常见到sizeof后面跟着个小括号,长得和函数差不多,但它和函数完全是两码事. 2,有什么用? sizeof其实就是用于告诉我们编译器在为某一特定数据或者某种数据类型的数据在存储空间中开辟空间时,开辟的空间大小,以字节为单位. 3,怎么用? sizeof(类型),或者sizeof(变量)都可以,得到的就是类型或者变量的存储空间.当对变量用的时
-
浅析C语言中printf(),sprintf(),scanf(),sscanf()的用法和区别
printf语法: #include <stdio.h>int printf( const char *format, ... ); printf()函数根据format(格式)给出的格式打印输出到STDOUT(标准输出)和其它参数中.返回值是输出的字符数量.sprintf语法: #include <stdio.h>int sprintf( char *buffer, const char *format, ... );sprintf()函数和printf()类似,格式控制完全一样
-
深入浅析php中sprintf与printf函数的用法及区别
PHP sprintf() 函数 把百分号(%)符号替换成一个作为参数进行传递的变量: <?php $number = 2; $str = "Shanghai"; $txt = sprintf("There are %u million cars in %s.",$number,$str); echo $txt; ?> 定义和用法 sprintf() 函数把格式化的字符串写入变量中. arg1.arg2.++ 参数将被插入到主字符串中的百分号(%)符号处
-
c语言中static修饰函数的方法及代码
1.静态函数只能在声明它的文件中可见,其他文件不能引用该函数. 2.不同的文件可以使用相同名字的静态函数,互不影响. 3.使用static声明的函数不能被另一个文件引用. 实例 /* file1.c */ #include <stdio.h> static void fun(void) { printf("hello from fun.\n"); } int main(void) { fun(); fun1(); return 0; } /* file2.c */ #inc
-
C语言中的const和free用法详解
注意:C语言中的const和C++中的const是有区别的,而且在使用VS编译测试的时候.如果是C的话,请一定要建立一个后缀为C的文件,不要是CPP的文件.因为,两个编译器会有差别的. 一.C语言中的const比较常见的用法,const做常量 #include<stdio.h> #include<malloc.h> #include<string.h> /* C中的const用法(使用VS测试的时候,要注意建立一个C后缀的文件,因为C的编译器和C++的编译器还是有区别的
-
C语言中static与sizeof查缺补漏篇
目录 前言 一.关于关键字static 1.static修饰局部变量 2.static修饰全局变量 3.static修饰函数 二.sizeof和strlen的区别 1.sizeof 2.strlen 二者区别 三.关于if()内部>与<的正确使用 前言 最近学习遇到了很多小难题,今天这篇博客就来记录一下最近学习所遇到的一些困惑我的地方,以便于复习. 一.关于关键字static 在C语言中: static是用来修饰变量和函数的 修饰局部变量-称为静态局部变量 修饰全局变量-称为静态全局变量 修饰
-
C语言中if语句加大括号和不加大括号的区别介绍
首先来回顾以下if语句 if(表达式1){ 语句1 语句2 -- } 如果表示条件的逻辑表达式的结果不是0,那么就执行后面跟着的这对大括号内的语句: 否则就跳过不执行 继续下面的其他语句. 但是if语句还有一种形式可以不用{}. 举个栗子: if(a > b) a += b + 10; if语句这一行结束的时候并没有表示语句结束的";",而后面的赋值语句写在if的下一行,而且缩进了,在这一行结束的时候有一个分号. 表明这条赋值语句是if语句的一部分,i
随机推荐
- 如何追踪入侵者
- JAVA四种基本排序方法实例总结
- VBS读网页的代码
- 解析JavaScript模仿块级作用域
- ASP.NET生成Google网站地图的代码
- 详细解析Python当中的数据类型和变量
- 浅谈SQLite时间函数的使用说明与总结分析
- 使用PHPExcel操作Excel用法实例分析
- 用css实现图片垂直居中的使用技巧
- JSP由浅入深(12)—— 表单编辑
- Ruby中嵌套对象转换成json的方法
- Debian系统下为PHP程序配置Nginx服务器的基本教程
- 验证本机的excel版本的C#代码
- javascript实现playfair和hill密码算法
- 获取Android手机中所有短信的实现代码
- java支付宝即时到帐提交订单功能
- 详解Android自定义View--自定义柱状图
- 又一个图片自动缩小的JS代码
- C++取得当前时间的方法
- Android更多条目收缩展开控件ExpandView的示例代码