C#的指针只能指向一个一维数组,有时候我们需要指向一个二维数组,这篇BLOG就是讲解这个问题的。
上代码:
public static void Main(string[] args)
{
Stopwatch ss = new Stopwatch();
ss.Start();
//定义一个指针数组
double*[] p = new double*[8];
IntPtr[] c = new IntPtr[8];
//定义一个指向p指针数组的指针
fixed (double** pg = p)
{
//这里等同于我们用交叉数组的:
//Int[][] a = New Int[8][10];
for (int i = 0; i < p.Length; i++)
{
//分配内存空间,并使用p指针数组里面的每个指针指向每一个分配的内存空间。
c[i] = Marshal.AllocHGlobal(sizeof(double) * 10);
*(pg + i) = (double*)c[i];
}
//指针赋值
//这里等同于我们用交叉数组的赋值
//Int[][] a = New Int[8][10];
//a[i][j]=i*j;
for (int i = 1; i <= p.Length; i++)
for (int j = 1; j <= 10; j++)
*((*(pg + (i - 1))) + (j - 1)) = i * j;
//输出指针
//这里等同于输出交叉数组
//Console.Write(a[i][j])
for (int i = 0; i < p.Length; i++)
{
for (int j = 0; j < 10; j++)
{
Console.Write(*((*(pg + i)) + j) + " ");
if (j == 10 - 1)
Console.WriteLine();
}
}
//回收分配的内存空间
for (int i = 0; i < p.Length; i++)
Marshal.FreeHGlobal(c[i]);
}
ss.Stop();
Console.WriteLine(ss.Elapsed.TotalMilliseconds);
这样,一个指向交叉数组的指针就完成了。
主要是分3步:
1、创建一个指针数组
2、指针数组的每一个指针指向一个一维的数组
3、创建一个指向该指针数组的指针
这就完成了。
不明白的可以看下列代码:
private static double[][] a2 = new double[][]
{
new double[]{ 0,1 },
new double[]{ 2,3 },
new double[]{ 4,5 },
new double[]{ 6,7 },
new double[]{ 8,9 },
new double[]{ 10,11 },
new double[]{ 12,13 },
new double[]{ 14,15 }
};
public static void Main(string[] args)
{
double*[] p = new double*[8];
fixed (double** pg = p)
{
for (int i = 0; i < a2.Length; i++)
{
fixed (double* ap1 = a2[i])
*(pg+i) = ap1;
}
Console.WriteLine(*((*(pg+1)) + 1));
}
}
再不明白的可以加Q:87648714
分享到:
相关推荐
在C#中实现交叉排序,需要两个指针分别指向数组的开头和结尾,同时还有一个中间指针用于分隔小于、等于和大于目标值的元素。 这些排序算法各有优缺点:冒泡排序简单直观,但效率较低;选择排序的时间复杂度较优,但...
第一部分 C#语言概述.4 第一章 第一章第一章 第一章 .NET 编 编 编程语言 程语言编程语言 程语言 C#.4 1.1 Microsoft.NET——一场新的革命.4 1.2 .NET 与 C#.6 1.3 C#语言的特点.8 1.4 小 结 .11...
2. **找到旋转点**:使用两个指针,一个从数组开头向后移动,另一个从数组结尾向前移动,直到两个指针相遇或交叉。相遇点可能是旋转点,也可能是原数组的一部分。 3. **分情况讨论**:根据旋转点,将数组分为两部分...
初始化两个指针,一个指向数组的起始位置,另一个指向数组的末尾。 2. 计算中间索引,并与目标值进行比较。 3. 如果中间值等于目标值,搜索结束,返回中间索引。 4. 如果中间值小于目标值,舍弃左半部分,更新左...
这个过程通过两个指针I和J实现,I指向数组开始,J指向数组末尾。 3. **前后搜索**:从J开始向前搜索,找到第一个小于关键数据的元素,然后从I开始向后搜索,找到第一个大于关键数据的元素。将这两个元素交换位置。 4...
单链表是一种线性数据结构,每个节点包含数据和指向下一个节点的引用(指针)。在C#中,可以定义一个简单的单链表节点类`Link`,如文件中所示: ```csharp public class Link { public Link Next; public string ...
21. **指针数组声明**:`int (*p)[3]`声明了一个指针变量p,它指向一个有三个整数元素的一维数组,答案C正确。 22. **数组数据类型**:数组的所有元素必须具有相同的类型,答案A正确。 23. **日期条件**:在SQL...
- 当使用replace命令时,如果范围短语为ALL或REST,则执行该命令后记录指针将指向末记录的后面。 - 正确答案为**C**:`末记录的后面`。 ### 12. VBA程序流程控制 - VBA支持三种基本的流程控制结构:顺序控制、分支...