0

0

Go语言中自定义整型类型的初始化方法详解

霞舞

霞舞

发布时间:2025-07-31 14:40:13

|

302人浏览过

|

来源于php中文网

原创

go语言中自定义整型类型的初始化方法详解

在Go语言中,自定义类型可以基于现有类型创建,例如基于int创建type Num int。初始化这类自定义类型时,应直接采用其底层基础类型的初始化方式进行赋值,而非使用make函数。make函数专用于创建切片、映射和通道这三种引用类型,不适用于基础类型或基于基础类型派生的自定义类型。

自定义整型类型的初始化原则

当我们在Go语言中定义一个基于基础类型(如int, string, bool等)的新类型时,这个新类型在行为上会继承其底层类型的基本特性。因此,其初始化方式也与底层类型保持一致。对于自定义的整型类型,我们可以像初始化普通的int类型一样对其进行赋值。

示例代码:

package main

import (
    "fmt"
)

// 定义一个基于int的自定义类型Num
type Num int

func main() {
    // 方式一:声明变量并直接赋值
    // 变量m被声明为Num类型,并赋值为7。
    // Go编译器会自动进行类型推断或隐式转换(如果赋值的是底层类型的值)。
    var m Num = 7 

    // 方式二:短变量声明并进行类型转换
    // 42是一个int类型字面量,通过Num(42)将其显式转换为Num类型。
    n := Num(42) 

    // 方式三:使用零值初始化
    // 如果不显式赋值,自定义整型类型会默认初始化为其底层类型的零值,即0。
    var zeroNum Num 

    fmt.Printf("m的值: %d, 类型: %T\n", m, m)
    fmt.Printf("n的值: %d, 类型: %T\n", n, n)
    fmt.Printf("zeroNum的值: %d, 类型: %T\n", zeroNum, zeroNum)
}

输出:

m的值: 7, 类型: main.Num
n的值: 42, 类型: main.Num
zeroNum的值: 0, 类型: main.Num

从上述示例可以看出,无论采用何种初始化方式,自定义的Num类型变量都能够正确地被赋值和使用。

立即学习go语言免费学习笔记(深入)”;

关于make函数的误解与正确用法

许多初学者可能会尝试使用make函数来初始化自定义类型,例如make(Num, 2)。然而,这种做法是错误的,并且会导致编译错误

Liner
Liner

由ChatGPT驱动的AI辅助学习工具,将学习知识的速度提高 10 倍。

下载

Go语言中的内置函数make有其特定的用途。它仅用于创建以下三种内置引用类型:

  1. 切片(slices):用于创建指定长度和容量的切片。
  2. 映射(maps):用于创建指定初始容量的映射。
  3. 通道(channels):用于创建指定缓冲大小的通道。

make函数的设计目的是为这些复合数据结构分配内存,并初始化它们的内部结构(如切片的底层数组指针、长度、容量,映射的哈希表结构等)。对于像int、string、bool或基于它们派生的自定义类型,它们是值类型,直接赋值即可,无需通过make来分配额外的“内部结构”。

错误的尝试示例:

package main

import "fmt"

type Num int

func main() {
    // 错误示例:尝试使用make初始化自定义整型类型
    // 这会导致编译错误:cannot make type Num
    // invalid argument Num (type Num) for make
    // x := make(Num, 2) 
    // fmt.Println(x)
}

总结与注意事项

  • 初始化方式: 自定义值类型(如基于int的类型)的初始化方式与其底层基础类型完全相同,直接通过赋值操作完成。
  • make的适用范围: make函数专用于创建切片、映射和通道,不适用于基本类型或基于基本类型派生的自定义类型。
  • 类型转换: 在将一个底层类型的值赋给自定义类型变量时,通常需要进行显式类型转换,例如n := Num(42)。虽然在某些情况下Go编译器可能允许隐式转换(如var m Num = 7),但显式转换有助于提高代码的可读性和明确性,避免潜在的类型混淆。
  • 零值: 未显式初始化的自定义值类型变量,其值将是其底层类型的零值(例如,int的零值为0)。

理解自定义类型与底层类型之间的关系,以及make函数的正确使用场景,是编写健鲁Go代码的关键。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

401

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

401

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

543

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

536

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

24

2026.01.06

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4.8万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.9万人学习

Go 教程
Go 教程

共32课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号