Python-Go python模块与包 - GO问题 - GO容量测试

目录

go 模块与包复习(Init函数 - go mod)

init函数有什么用?init函数是什么?

go.mod文件是什么?有什么作用?

python的模块与包

python中包的分类

1、内置模块:不需要安装,直接使用

2、三方模块:需要安装,再使用

3、自定义模块

python中自定义模块的简述

导入模块的两种方式:绝对导入、相对导入

python自定义文件实验文件包:   

main.py文件(__init__.py文件、绝对导入、相对导入的实现)

GO语言问题:

1、在 Go 语言中,有以下基本数据类型:

2、GO语言中指针的作用?

3、:= 和 = 的区别是什么? :=只能使用在哪里?

4、go语言文件操作,可以使用哪些包?

5、go语言函数参数传递方式,支持默认参数传递吗?

go中的容量测试:

 参考文档:go slice 扩容实现  Go 语言切片是如何扩容的?

 测试代码:

 运行结果:


go 模块与包复习(Init函数 - go mod)

init函数初始化文件,当导入包时,会自动执行init函数

init函数是可以重复声明的

init函数有什么用?init函数是什么?

init函数是一个用于做初始化的函数,当导入包的时候,会自动执行init函数,当运行主文件的时候,该文件的init函数会在main函数前自动执行

文件中函数的运行顺序 --》 const --》var --> init --> main

go mod init <包名>  --》生成go.mod文件
go mod tidy  --》自动整理依赖关系 go.sum(自动下载依赖包)
go build  --》可以把go包编译成一个二进制文件,而这个二进制文件可以在没有go环境的机器上去执行

go.mod文件是什么?有什么作用?

go.mod 文件是 Go 语言项目中的模块管理文件,用于定义和管理项目的依赖关系。

它用于定义模块信息、管理依赖关系和版本控制

go.mod 文件中包含了当前项目的模块定义信息,包括模块名称和模块的版本

go.mod 文件也用于管理项目的依赖关系。

go.mod 文件支持多版本的模块依赖。

go.mod 文件还可以用于自动生成和维护项目的版本号。

python的模块与包

python中包的分类

1、内置模块:不需要安装,直接使用

import os
import math
import sys
import requests

2、三方模块:需要安装,再使用

# pip install <模块名>  (也可以使用pip3下载)
# >pip install Flask
# 慢,timeout => 配置国内源
# pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple  #配置国内源

3、自定义模块

python中自定义模块的简述

模块 => python文件

包   => 目录

初始化 __init__.py => 初始化文件,当导入包的时候会自动执行

python包中的文件是独立的,(与go区分)

注意:当模块被导入的时候,模块中的代码都会被执行一次,建议每次导入模块的时候就导入模块的某个函数即可,否则很容易出现错误

导入模块的两种方式:绝对导入、相对导入

绝对导入:要内存中查找(内建) -> sys.path目录下查找目录 --》路径不理想,我们就需要添加路径: sys.path.append("路径")

相对导入:自己多层目录级别 top-level =>当前执行的主文件所在的目录

                                           => top-level的子孙目录才能使用相对导入

# 当前执行的文件所在的目录,被称为top-level
# top-level是不能直接被导入的

python自定义文件实验文件包:   

链接:https://pan.baidu.com/s/12jZiYPEmHDpWOQMlGTGEUQ?pwd=zouh 
提取码:zouh

main.py文件(__init__.py文件、绝对导入、相对导入的实现)

"""
@author: wy
@file: main.py.py
@time: 2023/7/22 10:37
"""
import sys
# python模块查找路径
print(sys.path)# 在pycharm中如果目录下有__init__.py文件,那么它就会识别成一个包,
# 会自动加到sys.path目录# 绝对路径导入 => 内建模块 -> sys.path路径去查找
# 可以导入到包/模块/函数(变量)
# 被导入的代码都会执行一遍
import pack1
from pack1 import pk0
from pack1.pk0 import student
# student()from pack1 import pk1
pk1.student()
from pack2 import pk2# 相对导入
# . => 当前路径
# .. => 上级路径# from . import pack1     #出现下面的错误
# ImportError: attempted relative import with no known parent package 
# 出现错误的原因是这个. 代表的是sanchaung这个包,而sanchuang则代表的是top-level
# 当前执行的文件所在的目录,被称为top-level
# top-level是不能直接被导入的
# . => sanchuang => top-level
# top-level下面的子包才可以使用相对导入(top-level本身这一层不可以)
# 比如说我们可以在pack1包下的pk1.py文件内使用相对导入,也就是使用top-level

pack1包内的pk1.py 和 pk0.py

pk1.py 文件# 相对导入
# . => sanchuang/pack1
# .pk0 => sanchuang/pack1/pk0
from .pk0 import test# 如果我们在pack1包的目录下上运行pk1.py 会出现错误:ImportError: attempted relative import with no known parent package
# 因此我们不能直接在pk1上直接运行程序,因为如果它运行了,就代表他现在是top-level, 而top-level不能在本层包中使用相对导入的,必须要在子孙目录才能使用相对导入
# top-level => pack1
# . => pack1   
# 因此不能再pk1上直接运行相对导入,而需要父文件调用pk1才能运行pk1.py内的程序# .. => sanchuang => top-level
# from ..pack2 import pk2def student():print("this is pack1.pk0.student")print(test())=======================
pk0.py 文件A = 100
sc_num = 50
print("this is pack1.pk0 file")def student():print("this is pack1.pk0.student")def test():print("this is pack1.pk0.test")

pack2包中的pk2.py


def download_pic():print("this is pack2.pk2.download_pic")print(__name__)
print(__file__)# 直接运行当前文件
# 当文件被直接运行的时候 => __name__ => __main__
# 当文件被其他文件导入的时候 => __name__ => 包名.文件名
if __name__ == "__main__":  #目的就是当该文件被直接运行的时候,会运行下面的语句,因为__name__ == "__main__"# 当该文件作为模块导入的时候,不希望调用语句被执行的!!# 我们通过使用__name__ 可以使自己运行该文件的时候能运行download_pic()语句,# 但是当pk2被调用的时候,download_pic()不会被执行download_pic()

GO语言问题:

1、在 Go 语言中,有以下基本数据类型:

  1. 值类型(Value Types):(存放的是数据)

    • bool:布尔类型,表示真或假。
    • intint8int16int32int64:整数类型,分别表示不同位数的有符号整数。
    • uintuint8uint16uint32uint64:整数类型,分别表示不同位数的无符号整数。
    • float32float64:浮点数类型,分别表示单精度和双精度浮点数。
    • complex64complex128:复数类型,分别表示具有 64 位实部和虚部、128 位实部和虚部的复数。
    • string:字符串类型,表示文本字符串值。
    • byte:别名类型,表示 uint8
    • rune:别名类型,表示 int32,用于表示 Unicode 码点。
    • uintptr:整数类型,用于存储指针地址。
  2. 引用类型(Reference Types):(引用的是对象的地址)

    • slice:切片类型,用于动态数组的管理。
    • map:映射类型,用于存储键值对的集合。
    • chan:通道类型,用于协程之间的通信。
    • func:函数类型,表示函数的类型。
    • interface:接口类型,用于定义一组方法的集合。

2、GO语言中指针的作用?

Go 语言中,指针(pointer)是一种特殊的数据类型,用于存储变量的内存地址。指针可以让我们直接访问和修改变量所在内存地址上的数据,而不是通过值拷贝。

函数可以利用指针来传递数据,实现在函数修改数据的同时影响原数据的效果

指针的作用如下:

  1. 传递引用:通过将指针作为参数传递给函数,可以在函数内部修改指针指向的变量的值。这样可以避免对大型数据结构进行复制,提高了性能。
  2. 动态分配内存:使用指针可以在程序运行时动态地分配内存,创建灵活的数据结构,如链表、树等。
  3. 与底层系统交互:指针常用于与 C 语言库进行交互,通过指针可以直接访问底层数据结构。
  4. 避免副本:有些情况下,将变量传递给函数会生成该变量的副本,占用额外的内存和时间。使用指针可以避免这种情况,节省资源。

在 Go 中,使用 & 运算符可以获取一个变量的地址,使用 * 运算符可以获取指针指向的值,也可以修改指针指向的值。

下面是一个简单的示例代码,展示了指针的使用:

func main() {x := 10fmt.Println("x =", x)   // 输出:x = 10p := &xfmt.Println("p =", p)   // 输出:p = 内存地址*p = 20fmt.Println("x =", x)   // 输出:x = 20
}

在这个示例中,&x 获取了变量 x 的地址,并将其赋值给指针变量 p。然后,通过 *p 可以修改指针 p 指向的变量的值。

要小心在使用指针时避免出现空指针(nil pointer)错误,确保在使用指针之前进行有效的初始化。

3、:= 和 = 的区别是什么? :=只能使用在哪里?

  1. := 赋值操作符:

    • := 是用于声明和初始化变量的简写方式。它会根据右侧表达式的类型自动推断出变量的类型,并将变量的作用域限定在当前代码块内。
    • := 只能用于函数内部,用于声明和初始化局部变量,不能用于全局变量的声明。
  2. = 赋值操作符:

    • = 是普通的赋值操作符,用于给已经声明的变量赋新的值或修改变量的值。
    • = 可以在任何地方使用,不仅限于函数内部,包括全局变量的赋值和变量的重新赋值。

下面是使用 :== 的示例代码:

func main() {x := 10       // 使用 := 声明并初始化局部变量 xy := 20       // 使用 := 声明并初始化局部变量 yfmt.Println(x, y)   // 输出:10 20x = 30       // 使用 = 给变量 x 赋新值fmt.Println(x)      // 输出:30z := "hello"   // 使用 := 声明并初始化局部变量 zfmt.Println(z)      // 输出:helloz = "world"   // 使用 = 给变量 z 赋新值fmt.Println(z)      // 输出:world
}

需要注意的是,:= 只能用于声明新的变量,如果想要对已经存在的变量赋值,则必须使用 =

4、go语言文件操作,可以使用哪些包?

在 Go 语言中,可以使用以下几个包进行文件操作:

  1. os 包:提供了与操作系统交互的函数和类型,用于创建、打开、读取、写入和关闭文件等基本的文件操作。常用函数有:CreateOpenReadWriteClose 等。

  2. io 包:提供了基本的 I/O 操作,包括读取和写入数据到文件。常用函数有:CopyCopyNReadAllWriteFile 等。

  3. ioutil 包:提供了一些方便的 I/O 函数,用于简化文件操作。常用函数有:ReadFileWriteFileReadDirTempFile 等。

  4. filepath 包:提供了对文件路径的各种操作,比如获取文件扩展名、获取文件名、判断路径是否为绝对路径等。常用函数有:BaseExtJoinAbs 等。

go语言怎么处理异常,有异常类型吗?如何自定义异常呢?

go语言错误处理通常是通过返回值的方式,把处理权交给用户

Go 语言中没有像其他语言一样的异常类型,而是使用了内置的 error 接口类型作为错误的表示。标准库包中的很多函数都会返回一个 error 类型的值,用于指示函数是否执行成功。

通常情况下,一个函数在执行过程中如果发生了错误,会将错误信息封装在一个 error 类型的值中返回。调用该函数的代码负责根据返回的错误值进行判断和处理。

package mainimport ("fmt""os"
)func main() {file, err := os.Open("test.txt")if err != nil {fmt.Println("打开文件出错:", err)return}defer file.Close()// 使用 file 进行文件操作// ...
}

在上面的代码中,我们打开了一个名为 test.txt 的文件,如果打开过程中发生错误,就会返回一个非空的 error 值。通过判断 err 是否为 nil 来确定函数是否执行成功,如果不为 nil,则表示发生了错误,可以通过 err.Error() 方法获取详细的错误信息。

除了使用标准库提供的错误类型,你也可以自定义错误类型。只需定义一个实现了 error 接口的结构体即可,该结构体需要实现 Error() string 方法来返回错误信息。

Panic 错误 --》 defer+recover

                 --》defer --》延迟执行 --》通常出现在可能出现错误的位置的前面

                 --》recover --》 获取并处理panic信息,其实就相当于python中的except一样

以下是一个自定义错误类型的示例代码:

package mainimport ("errors""fmt"
)type MyError struct {ErrMsg string
}func (e *MyError) Error() string {return e.ErrMsg
}func main() {err := &MyError{ErrMsg: "自定义错误"}fmt.Println(err.Error())
}

在上面的代码中,我们定义了一个名为 MyError 的结构体,并实现了 Error() 方法。然后,创建一个 MyError 类型的实例并打印出错误信息。

通过自定义错误类型,可以给错误信息添加更多的上下文和可读性。

5、go语言函数参数传递方式,支持默认参数传递吗?

在 Go 语言中,函数参数的传递方式是值传递(pass by value)。这意味着函数调用时,实参的值会被复制到形参中,函数内对形参的修改不会影响到实参。

默认参数传递是指在函数定义时为参数提供默认值,在函数调用时可以省略该参数。然而,Go 语言并不支持原生的默认参数传递的语法,但可以通过函数重载和可变参数来模拟实现一种类似的行为。

以下是一个使用函数重载和可变参数模拟默认参数传递的示例代码:

package mainimport "fmt"func PrintNameWithAge(name string, age ...int) {if len(age) > 0 {fmt.Printf("Name: %s, Age: %d\n", name, age[0])} else {fmt.Printf("Name: %s\n", name)}
}func main() {// 调用函数时只传递 name 参数PrintNameWithAge("Alice")// 调用函数时传递 name 和 age 参数PrintNameWithAge("Bob", 25)
}

在上面的代码中,PrintNameWithAge 函数定义了一个名为 name 的必需参数和一个名为 age 的可变参数。如果调用函数时只传递了 name 参数,则 age 参数被省略,默认为零值。如果同时传递了 nameage 参数,则按照传入的值进行输出。

main 函数中,我们分别调用了 PrintNameWithAge 函数,一次只传递了 name 参数,一次同时传递了 nameage 参数。结果会根据参数的情况进行输出。

go中的容量测试:

 参考文档:go slice 扩容实现  Go 语言切片是如何扩容的?

 测试代码:

package mainimport "fmt"func main() {// 定义了一个切片,长度为0s := make([]int, 0)// 底层数组长度oldCap := cap(s)for i := 0; i < 2048; i++ {s = append(s, i)// append之后底层数组长度newCap := cap(s)// 条件成立表示数组增长了if newCap != oldCap {fmt.Printf("[%d -> %4d] cap = %-4d  |  after append %-4d  cap = %-4d\n", 0, i-1, oldCap, i, newCap)oldCap = newCap}}
}// 源代码 :src/runtime/slice.go
// 1. 计算newCap
//    a.如果期望的容器大于当前cap的2倍,newcap = 期望容器值
//    b.
//    c.
// 2. 内存优化

 运行结果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/10158.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端工作中常用 CSS 知识点整理

1.1文字溢出省略号 文字单行溢出: overflow: hidden; // 溢出隐藏 text-overflow: ellipsis; // 溢出用省略号显示 white-space: nowrap; // 规定段落中的文本不进行换行 多行文字溢出: overflow: hidden; // 溢出隐藏 text-overflow: …

Java电子招投标采购系统源码-适合于招标代理、政府采购、企业采购

功能描述 1、门户管理&#xff1a;所有用户可在门户页面查看所有的公告信息及相关的通知信息。主要板块包含&#xff1a;招标公告、非招标公告、系统通知、政策法规。 2、立项管理&#xff1a;企业用户可对需要采购的项目进行立项申请&#xff0c;并提交审批&#xff0c;查看…

【简单认识MySQL主从复制与读写分离】

文章目录 一、MySQL主从复制1、配置主从复制的原因&#xff1a;2、主从复制原理1、 MySQL的复制类型2、 MySQL主从复制的工作过程;1、 MySQL主从复制延迟2、优化方案&#xff1a;3、 MySQL 有几种同步方式&#xff1a; 三种4、异步复制&#xff08;Async Replication&#xff0…

【宝藏系列】20个常用的Python技巧

【宝藏系列】20个常用的Python技巧 文章目录 【宝藏系列】20个常用的Python技巧&#x1f349;文末推荐【Python之光】 Python的可读性和简单性是其广受欢迎的两大原因&#xff0c;本文介绍20个常用的Python技巧来提高代码的可读性&#xff0c;并能帮助你节省大量时间&#xff0…

springboot整合ELK+kafka采集日志

一、背景介绍 在分布式的项目中&#xff0c;各功能模块产生的日志比较分散&#xff0c;同时为满足性能要求&#xff0c;同一个微服务会集群化部署&#xff0c;当某一次业务报错后&#xff0c;如果不能确定产生的节点&#xff0c;那么只能逐个节点去查看日志文件&#xff1b;lo…

工业自动化数据485采集网关支持modbus协议

S475/S475E系列是一种功能丰富的设备&#xff0c;支持多种通信方式和输入输出功能。以下是对其功能的详细介绍&#xff1a; 通信方式&#xff1a; S475/S475E系列支持多种通信方式&#xff0c;包括短信、RS485、语音拨号、GPRS/3G/4G无线数据网络四种告警方式。这意味着用户可…

AXI协议之AXILite开发设计(二)

微信公众号上线&#xff0c;搜索公众号小灰灰的FPGA,关注可获取相关源码&#xff0c;定期更新有关FPGA的项目以及开源项目源码&#xff0c;包括但不限于各类检测芯片驱动、低速接口驱动、高速接口驱动、数据信号处理、图像处理以及AXI总线等 二、AXI-Lite关键代码分析 1、时钟与…

营销系统积分数据库设计

营销系统总体数据-业务功能模型 在当今日益竞争的市场中&#xff0c;如何提高客户留存率和忠诚度&#xff0c;已成为各大企业迫切需要解决的问题。而积分商城/系统作为一种新型的营销方式&#xff0c;受到青睐。 积分商城/系统是指将用户在使用产品或服务时产生的积分&#xf…

X - Transformer

回顾 Transformer 的发展 Transformer 最初是作为机器翻译的序列到序列模型提出的&#xff0c;而后来的研究表明&#xff0c;基于 Transformer 的预训练模型&#xff08;PTM&#xff09; 在各项任务中都有最优的表现。因此&#xff0c;Transformer 已成为 NLP 领域的首选架构&…

mac m1 触控栏TouchBar功能栏异常

电脑可能在高温下运行时间过长&#xff0c;导致TouchBar之前正常显示的调整屏幕亮度与调整声音等功能的按钮均丢失&#xff0c;然后看了一眼键盘设置&#xff0c;设置也是正常的&#xff0c;已勾选显示功能栏 下面请看 如何在MacBook Pro&#xff08;macOS Monterey&#xff0…

基于Java+SpringBoot+vue前后端分离社区医院信息平台设计实现

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专…

【C++】智能指针

文章目录 1. 为什么需要智能指针&#xff1f;2. 智能指针的使用智能指针的常见问题1.使用对象的生命周期去控制资源2. 像指针一样使用3. 拷贝问题auto_ptr ——管理权转移unique_ptr ——防拷贝C98版本C11版本 shared_ptr (根本解决拷贝问题)赋值代码实现 weak_ptr —— 循环引…

RocketMQ教程-(4)-领域模型-消费者(Consumer)

本文介绍 Apache RocketMQ 中消费者&#xff08;Consumer&#xff09;的定义、模型关系、内部属性、行为约束、版本兼容性及使用建议。 定义​ 消费者是 Apache RocketMQ 中用来接收并处理消息的运行实体。 消费者通常被集成在业务系统中&#xff0c;从 Apache RocketMQ 服务…

【JVM】详解对象的创建过程

文章目录 1、创建对像的几种方式1、new关键字2、反射3、clone4、反序列化 2、创建过程步骤 1、检查类是否已经被加载步骤 2、 为对象分配内存空间1、指针碰撞针对指针碰撞线程不安全&#xff0c;有两种方案&#xff1a; 2、空闲列表选择哪种分配方式 步骤3、将内存空间初始化为…

如何在armv6 armv7 armv8(aarch64)嵌入式板子上面安装nginx服务器,支持H265码流

如何在armv6 armv6 armv8 aarch64 嵌入式板子上面安装nginx服务器支持推送H265的视频流 开始吧 一&#xff0c;准备工作二&#xff0c;configure时遇到的出错问题1、checking for C compiler … found but is not working2&#xff0c;error: can not detect int size3&#xf…

【博客682】k8s apiserver bookmarks机制以更高效检测变更

k8s apiserver bookmarks机制以更高效检测变更 list-watch背景&#xff1a; List-Watch 是kubernetes中server和client通信的最核心的机制&#xff0c; 比如说api-server监听etcd&#xff0c; kubelet监听api-server&#xff0c; scheduler监听api-server等等&#xff0c;其实…

Jmeter场景设置与监听

Jmeter场景设置 场景的概念: 场景是用来尽量真实模拟用户操作的工作单元&#xff0c;场景设计源自于用户真实操作。 场景设计: 场景设计是根据收集分析用户的实际操作而定义的Jmeter脚本的执行策略。 性能测试中涉及的基本场景有两种&#xff0c;即单一业务场景和混合业务场景…

链表是否有环、环长度、环起点

问题引入 如何检测一个链表是否有环&#xff0c;如果有&#xff0c;那么如何确定环的长度及起点。 引自博客&#xff1a;上述问题是一个经典问题&#xff0c;经常会在面试中被问到。我之前在杭州一家网络公司的电话面试中就很不巧的问到&#xff0c;当时是第一次遇到那个问题&…

RocketMQ集群4.9.2升级4.9.6版本

本文主要记录生产环境短暂停机升级RocketMQ版本的过程 一、整体思路 1.将生产环境MQ4.9.2集群同步到测试环境&#xff0c;并启动&#xff0c;确保正常运行。 2.参照4.9.2配置4.9.6集群 3.停掉4.9.2集群&#xff0c;启动4.9.6集群&#xff0c;测试确保正常运行。 4.停掉4.9.6集…

git使用教程

一 创建环境 参考 Git 安装配置 | 菜鸟教程 (runoob.com)https://www.runoob.com/git/git-install-setup.html 1.1 配置 $ git config --global user.name "runoob" $ git config --global user.email test@runoob.com 1.2 创建一个新文件夹 在新的文件夹执行(…