草庐IT

struct - 声明结构变量 VS 将空结构分配给变量有什么区别

coder 2023-06-28 原文

type person struct {
    age    int
    gender string
}
(1)var tom person
(2)var jim person = person{}

在第一行,tom被声明为person,第二行,jim被声明为person并赋给一个空的person,这两者有什么区别?两种方式的默认值是一样的。请问第1行声明后分配内存存储而不分配任何内容?

一样
var i int

上面的代码是分配内存还是仅仅表示一个地址来做这件事

var i *int = new(int)

我知道i变量在这两段代码中有不同的含义,第一个是int类型的变量,第二个是指针,但是第一个i也应该代表内存中的某个地址,这意味着它分配了某个地址到 i 并将“i”默认为 0?

最佳答案

声明一个变量与用零值初始化它

在 Go 中,所有没有初始化器声明的变量都被初始化为适合其类型的所谓的零值。由于对于 person 结构,它的零值是表达式 person{} 这两种情况,(1) 和 (2) 做同样的事情。我估计编译器会为它们生成相同的代码。

引用the spec :

A variable declaration creates a variable, binds an identifier to it and gives it a type and optionally an initial value.

If a list of expressions is given, the variables are initialized by assigning the expressions to the variables in order; all expressions must be consumed and all variables initialized from them. Otherwise, each variable is initialized to its zero value.

通过声明变量分配内存

声明 var i int 声明一个变量并对其进行初始化。从某种意义上说,这确实意味着分配内存(并初始化它),但我不会深入:编译器会安排变量存在。

至于它是否“表示地址”取决于你如何看待它:考虑变量在内存中的布局不是程序员的事——变量的名称是其值的句柄,并且编译器可以随意提供此类访问。我的意思是,编译器可能会在某个地方内部存储这个变量的地址并使用它,但你不应该关心它。

var i *int = new(int) 声明声明了一个指向匿名变量(具有“附加”到它的某种类型的语义的内存块)的指针,初始化内存该变量具有适合其类型的零值,然后将该内存块的地址分配给您正在声明的变量。

引用the spec :

The built-in function new takes a type T and returns a value of type *T. The memory is initialized as described in the section on initial values.

在这种情况下,您对指针进行操作,而不是对变量本身进行操作。所以这两个声明做了完全不同的事情,因为它们声明了不同类型的变量,并且生成的变量具有不同的语义。

可能 var i intvar p *int = new(int) 之间的主要区别在于,在前一种情况下,变量是“立即”创建的(静态)而在后一种情况下,匿名变量的内存是动态初始化的。但同样不要太执着于此:当执行遇到 var i int 声明时,除了名为 i 的变量之外,您无法确定程序中到底发生了什么> int 类型变得可用。例如,编译器可以自由使用“堆”来分配它,而不是“堆栈”(假设是典型的硬件架构)。

关于struct - 声明结构变量 VS 将空结构分配给变量有什么区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23136725/

有关struct - 声明结构变量 VS 将空结构分配给变量有什么区别的更多相关文章

  1. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  2. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  3. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  4. ruby-on-rails - Railstutorial : db:populate vs. 工厂女孩 - 2

    在railstutorial中,作者为什么选择使用这个(代码list10.25):http://ruby.railstutorial.org/chapters/updating-showing-and-deleting-usersnamespace:dbdodesc"Filldatabasewithsampledata"task:populate=>:environmentdoRake::Task['db:reset'].invokeUser.create!(:name=>"ExampleUser",:email=>"example@railstutorial.org",:passwo

  5. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  6. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  7. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

  8. ruby-on-rails - 如何使用 instance_variable_set 正确设置实例变量? - 2

    我正在查看instance_variable_set的文档并看到给出的示例代码是这样做的:obj.instance_variable_set(:@instnc_var,"valuefortheinstancevariable")然后允许您在类的任何实例方法中以@instnc_var的形式访问该变量。我想知道为什么在@instnc_var之前需要一个冒号:。冒号有什么作用? 最佳答案 我的第一直觉是告诉你不要使用instance_variable_set除非你真的知道你用它做什么。它本质上是一种元编程工具或绕过实例变量可见性的黑客攻击

  9. ruby - 通过 ruby​​ 进程共享变量 - 2

    我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是

  10. ruby-on-rails - active_admin 目录中的常量警告重新声明 - 2

    我正在使用active_admin,我在Rails3应用程序的应用程序中有一个目录管理,其中包含模型和页面的声明。时不时地我也有一个类,当那个类有一个常量时,就像这样:classFooBAR="bar"end然后,我在每个必须在我的Rails应用程序中重新加载一些代码的请求中收到此警告:/Users/pupeno/helloworld/app/admin/billing.rb:12:warning:alreadyinitializedconstantBAR知道发生了什么以及如何避免这些警告吗? 最佳答案 在纯Ruby中:classA

随机推荐