1*9512fe85Sahl /* 2*9512fe85Sahl * CDDL HEADER START 3*9512fe85Sahl * 4*9512fe85Sahl * The contents of this file are subject to the terms of the 5*9512fe85Sahl * Common Development and Distribution License (the "License"). 6*9512fe85Sahl * You may not use this file except in compliance with the License. 7*9512fe85Sahl * 8*9512fe85Sahl * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*9512fe85Sahl * or http://www.opensolaris.org/os/licensing. 10*9512fe85Sahl * See the License for the specific language governing permissions 11*9512fe85Sahl * and limitations under the License. 12*9512fe85Sahl * 13*9512fe85Sahl * When distributing Covered Code, include this CDDL HEADER in each 14*9512fe85Sahl * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*9512fe85Sahl * If applicable, add the following below this CDDL HEADER, with the 16*9512fe85Sahl * fields enclosed by brackets "[]" replaced with your own identifying 17*9512fe85Sahl * information: Portions Copyright [yyyy] [name of copyright owner] 18*9512fe85Sahl * 19*9512fe85Sahl * CDDL HEADER END 20*9512fe85Sahl */ 21*9512fe85Sahl 22*9512fe85Sahl /* 23*9512fe85Sahl * Copyright 2006 Sun Microsystems, Inc. All rights reserved. 24*9512fe85Sahl * Use is subject to license terms. 25*9512fe85Sahl */ 26*9512fe85Sahl 27*9512fe85Sahl /* 28*9512fe85Sahl * ASSERTION: 29*9512fe85Sahl * D pointers can be used to refer to consecutive storage locations like 30*9512fe85Sahl * arrays. 31*9512fe85Sahl * 32*9512fe85Sahl * SECTION: Pointers and Arrays/Pointer and Array Relationship 33*9512fe85Sahl * 34*9512fe85Sahl * NOTES: 35*9512fe85Sahl * 36*9512fe85Sahl */ 37*9512fe85Sahl 38*9512fe85Sahl #pragma D option quiet 39*9512fe85Sahl 40*9512fe85Sahl int array[5]; 41*9512fe85Sahl BEGIN 42*9512fe85Sahl { 43*9512fe85Sahl array[0] = 100; 44*9512fe85Sahl array[1] = 200; 45*9512fe85Sahl array[2] = 300; 46*9512fe85Sahl array[3] = 400; 47*9512fe85Sahl array[4] = 500; 48*9512fe85Sahl 49*9512fe85Sahl p = &array[0]; 50*9512fe85Sahl 51*9512fe85Sahl printf("array[0]: %d\t*p: %d\n", array[0], *p); 52*9512fe85Sahl printf("array[1]: %d\t*(p+1): %d\n", array[1], *(p+1)); 53*9512fe85Sahl printf("array[2]: %d\t*(p+2): %d\n", array[2], *(p+2)); 54*9512fe85Sahl printf("array[3]: %d\t*(p+3): %d\n", array[3], *(p+3)); 55*9512fe85Sahl printf("array[4]: %d\t*(p+4): %d\n", array[4], *(p+4)); 56*9512fe85Sahl 57*9512fe85Sahl exit(0); 58*9512fe85Sahl 59*9512fe85Sahl } 60*9512fe85Sahl 61*9512fe85Sahl END 62*9512fe85Sahl /(array[0] != *p) || (array[1] != *(p+1)) || (array[2] != *(p+2)) 63*9512fe85Sahl || (array[3] != *(p+3)) || (array[4] != *(p+4))/ 64*9512fe85Sahl { 65*9512fe85Sahl printf("Error"); 66*9512fe85Sahl exit(1); 67*9512fe85Sahl } 68*9512fe85Sahl 69*9512fe85Sahl 70*9512fe85Sahl 71