GO语言————8.3 for-range 的配套用法

Go语言Map遍历技巧
本文介绍了Go语言中如何利用for-range循环遍历map的基本用法,并提供了具体示例代码,展示了如何通过不同方式访问map中的键和值。

8.3 for-range 的配套用法

可以使用 for 循环构造 map:

for key, value := range map1 {
	...
}

第一个返回值 key 是 map 中的 key 值,第二个返回值则是该 key 对应的 value 值;这两个都是仅 for 循环内部可见的局部变量。其中第一个返回值key值是一个可选元素。如果你只关心值,可以这么使用:

for _, value := range map1 {
	...
}

如果只想获取 key,你可以这么使用:

for key := range map1 {
	fmt.Printf("key is: %d\n", key)
}

示例 8.5 maps_forrange.go

package main
import "fmt"

func main() {
	map1 := make(map[int]float32)
	map1[1] = 1.0
	map1[2] = 2.0
	map1[3] = 3.0
	map1[4] = 4.0
	for key, value := range map1 {
		fmt.Printf("key is: %d - value is: %f\n", key, value)
	}
}

输出结果:

key is: 3 - value is: 3.000000
key is: 1 - value is: 1.000000
key is: 4 - value is: 4.000000
key is: 2 - value is: 2.000000

注意 map 不是按照 key 的顺序排列的,也不是按照 value 的序排列的。

问题 8.1: 下面这段代码的输出是什么?

capitals := map[string] string {"France":"Paris", "Italy":"Rome", "Japan":"Tokyo" }
for key := range capitals {
	fmt.Println("Map item: Capital of", key, "is", capitals[key])
}

练习 8.1

创建一个 map 来保存每周 7 天的名字,将它们打印出来并且测试是否存在 Tuesday 和 Hollyday。

在 macOS 上为 PHP 8.3 安装和配置 `pdo-sqlsrv` 扩展,可以通过 `PECL` 或从源码编译的方式完成。以下是详细的步骤说明: ### 使用 PECL 安装 pdo-sqlsrv 扩展 1. **确保已安装 PHP 8.3 和 PHP 开发工具** macOS 上可以通过 Homebrew 安装 PHP 8.3 及其开发包: ```bash brew install php@8.3 ``` 安装完成后,确保 `phpize` 和 `php-config` 可用,它们通常位于 `/usr/local/opt/php@8.3/bin/`。 2. **安装 Microsoft ODBC Driver for SQL Server** `pdo-sqlsrv` 扩展依赖于 ODBC 驱动。使用 Homebrew 安装适用于 macOS 的 ODBC 驱动: ```bash brew tap microsoft/mssql-release https://github.com/Microsoft/homebrew-mssql-release brew update brew install --cask microsoft-odbc-driver-17-for-sql-server ``` 3. **使用 PECL 安装 pdo-sqlsrv 扩展** 运行以下命令安装 `pdo-sqlsrv`: ```bash pecl install sqlsrv pecl install pdo_sqlsrv ``` 安装过程中可能需要确认路径或配置选项,保持默认设置通常即可。 4. **启用扩展** 安装完成后,将以下两行添加到 `php.ini` 文件中以启用扩展: ```ini extension=sqlsrv.so extension=pdo_sqlsrv.so ``` 确认 `php.ini` 文件的位置,可以通过 `php --ini` 命令查找。 5. **验证安装** 使用以下命令检查扩展是否成功加载: ```bash php -m | grep -i sqlsrv ``` 如果看到 `sqlsrv` 和 `pdo_sqlsrv`,说明扩展已成功安装并启用。 ### 从源码编译安装 pdo-sqlsrv 扩展 1. **获取源码** 从 GitHub 获取 `sqlsrv` 扩展的源码: ```bash git clone https://github.com/Microsoft/msphpsql.git cd mssql/ ``` 2. **编译扩展** 运行 `phpize` 并编译扩展: ```bash /usr/local/opt/php@8.3/bin/phpize ./configure --with-php-config=/usr/local/opt/php@8.3/bin/php-config --with-sqlsrv=/usr/local make sudo make install ``` 3. **启用扩展** 同样,将以下两行添加到 `php.ini` 文件中: ```ini extension=sqlsrv.so extension=pdo_sqlsrv.so ``` 4. **验证安装** 使用以下命令检查扩展是否成功加载: ```bash /usr/local/opt/php@8.3/bin/php -m | grep -i sqlsrv ``` ### 配置注意事项 - **ODBC 驱动兼容性** 确保使用的 ODBC 驱动版本与 PHP 8.3 兼容,推荐使用 Microsoft ODBC Driver 17 for SQL Server。 - **PHP 版本匹配** 安装扩展时,确保 `php-config` 和 `phpize` 的版本与 PHP 8.3 匹配,可以通过 `/usr/local/opt/php@8.3/bin/php-config --version` 检查版本。 - **扩展加载路径** 确保 `php.ini` 文件中指定的扩展路径正确,可以通过 `extension_dir` 配置项确认。 ### 示例代码 以下是一个简单的示例,展示如何使用 `pdo-sqlsrv` 连接到 SQL Server 数据库: ```php <?php $serverName = "your_server_name"; $connectionOptions = array( "Database" => "your_database", "Uid" => "your_username", "PWD" => "your_password" ); // 使用 PDO 连接数据库 try { $conn = new PDO("sqlsrv:Server=$serverName;Database={$connectionOptions[&#39;Database&#39;]}", $connectionOptions[&#39;Uid&#39;], $connectionOptions[&#39;Pwd&#39;]); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); echo "Connected successfully"; } catch (PDOException $e) { echo "Connection failed: " . $e->getMessage(); } ?> ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值